forked from eden-emu/eden
		
	Merge pull request #1939 from DarkLordZach/web-applet
applets: Implement HLE web browser applet (LibAppletOff)
This commit is contained in:
		
						commit
						ea894adaf5
					
				
					 30 changed files with 1413 additions and 623 deletions
				
			
		|  | @ -23,6 +23,7 @@ | |||
| #include "core/hle/service/am/applets/profile_select.h" | ||||
| #include "core/hle/service/am/applets/software_keyboard.h" | ||||
| #include "core/hle/service/am/applets/stub_applet.h" | ||||
| #include "core/hle/service/am/applets/web_browser.h" | ||||
| #include "core/hle/service/am/idle.h" | ||||
| #include "core/hle/service/am/omm.h" | ||||
| #include "core/hle/service/am/spsm.h" | ||||
|  | @ -44,6 +45,7 @@ constexpr ResultCode ERR_SIZE_OUT_OF_BOUNDS{ErrorModule::AM, 0x1F7}; | |||
| enum class AppletId : u32 { | ||||
|     ProfileSelect = 0x10, | ||||
|     SoftwareKeyboard = 0x11, | ||||
|     LibAppletOff = 0x17, | ||||
| }; | ||||
| 
 | ||||
| constexpr u32 POP_LAUNCH_PARAMETER_MAGIC = 0xC79497CA; | ||||
|  | @ -730,10 +732,10 @@ void IStorageAccessor::Write(Kernel::HLERequestContext& ctx) { | |||
|     IPC::RequestParser rp{ctx}; | ||||
| 
 | ||||
|     const u64 offset{rp.Pop<u64>()}; | ||||
|     LOG_DEBUG(Service_AM, "called, offset={}", offset); | ||||
| 
 | ||||
|     const std::vector<u8> data{ctx.ReadBuffer()}; | ||||
| 
 | ||||
|     LOG_DEBUG(Service_AM, "called, offset={}, size={}", offset, data.size()); | ||||
| 
 | ||||
|     if (data.size() > backing.buffer.size() - offset) { | ||||
|         LOG_ERROR(Service_AM, | ||||
|                   "offset is out of bounds, backing_buffer_sz={}, data_size={}, offset={}", | ||||
|  | @ -753,10 +755,10 @@ void IStorageAccessor::Read(Kernel::HLERequestContext& ctx) { | |||
|     IPC::RequestParser rp{ctx}; | ||||
| 
 | ||||
|     const u64 offset{rp.Pop<u64>()}; | ||||
|     LOG_DEBUG(Service_AM, "called, offset={}", offset); | ||||
| 
 | ||||
|     const std::size_t size{ctx.GetWriteBufferSize()}; | ||||
| 
 | ||||
|     LOG_DEBUG(Service_AM, "called, offset={}, size={}", offset, size); | ||||
| 
 | ||||
|     if (size > backing.buffer.size() - offset) { | ||||
|         LOG_ERROR(Service_AM, "offset is out of bounds, backing_buffer_sz={}, size={}, offset={}", | ||||
|                   backing.buffer.size(), size, offset); | ||||
|  | @ -791,6 +793,8 @@ static std::shared_ptr<Applets::Applet> GetAppletFromId(AppletId id) { | |||
|         return std::make_shared<Applets::ProfileSelect>(); | ||||
|     case AppletId::SoftwareKeyboard: | ||||
|         return std::make_shared<Applets::SoftwareKeyboard>(); | ||||
|     case AppletId::LibAppletOff: | ||||
|         return std::make_shared<Applets::WebBrowser>(); | ||||
|     default: | ||||
|         LOG_ERROR(Service_AM, "Unimplemented AppletId [{:08X}]! -- Falling back to stub!", | ||||
|                   static_cast<u32>(id)); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei