 8406ec6272
			
		
	
	
		8406ec6272
		
	
	
	
	
		
			
			* Refactor Ryujinx.Common and HLE Stub Logging * Resolve review comments * Rename missed loop variable * Optimize PrintStub logging function * Pass the call-sites Thread ID through to the logger * Remove superfluous lock from ConsoleLog * Process logged data objects in the logger target Pass the data object all the way to the output logger targets, to allow them to "serialize" this in whatever appropriate format they're logging in. * Use existing StringBuilder to build the properties string * Add a ServiceNotImplemented Exception Useful for printing debug information about unimplemented service calls * Resolve Style Nits * Resolve Merge Issues * Fix typo and align declarations
		
			
				
	
	
		
			51 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using Ryujinx.Common.Logging;
 | |
| using Ryujinx.HLE.HOS.Ipc;
 | |
| using Ryujinx.HLE.HOS.Kernel.Common;
 | |
| using Ryujinx.HLE.HOS.Kernel.Threading;
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| 
 | |
| namespace Ryujinx.HLE.HOS.Services.Am
 | |
| {
 | |
|     class IHomeMenuFunctions : IpcService
 | |
|     {
 | |
|         private Dictionary<int, ServiceProcessRequest> _commands;
 | |
| 
 | |
|         public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => _commands;
 | |
| 
 | |
|         private KEvent _channelEvent;
 | |
| 
 | |
|         public IHomeMenuFunctions(Horizon system)
 | |
|         {
 | |
|             _commands = new Dictionary<int, ServiceProcessRequest>
 | |
|             {
 | |
|                 { 10, RequestToGetForeground        },
 | |
|                 { 21, GetPopFromGeneralChannelEvent }
 | |
|             };
 | |
| 
 | |
|             //ToDo: Signal this Event somewhere in future.
 | |
|             _channelEvent = new KEvent(system);
 | |
|         }
 | |
| 
 | |
|         public long RequestToGetForeground(ServiceCtx context)
 | |
|         {
 | |
|             Logger.PrintStub(LogClass.ServiceAm);
 | |
| 
 | |
|             return 0;
 | |
|         }
 | |
| 
 | |
|         public long GetPopFromGeneralChannelEvent(ServiceCtx context)
 | |
|         {
 | |
|             if (context.Process.HandleTable.GenerateHandle(_channelEvent.ReadableEvent, out int handle) != KernelResult.Success)
 | |
|             {
 | |
|                 throw new InvalidOperationException("Out of handles!");
 | |
|             }
 | |
| 
 | |
|             context.Response.HandleDesc = IpcHandleDesc.MakeCopy(handle);
 | |
| 
 | |
|             Logger.PrintStub(LogClass.ServiceAm);
 | |
| 
 | |
|             return 0;
 | |
|         }
 | |
|     }
 | |
| }
 |