mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2025-01-10 16:25:15 +00:00
a33dc2f491
* Logger class changes only Now compile-time checking is possible with the help of Nullable Value types. * Misc formatting * Manual optimizations PrintGuestLog PrintGuestStackTrace Surfaceflinger DequeueBuffer * Reduce SendVibrationXX log level to Debug * Add Notice log level This level is always enabled and used to print system info, etc... Also, rewrite LogColor to switch expression as colors are static * Unify unhandled exception event handlers * Print enabled LogLevels during init * Re-add App Exit disposes in proper order nit: switch case spacing * Revert PrintGuestStackTrace to Info logs due to #1407 PrintGuestStackTrace is now called in some critical error handlers so revert to old behavior as KThread isn't part of Guest. * Batch replace Logger statements
80 lines
2.5 KiB
C#
80 lines
2.5 KiB
C#
using Ryujinx.Common.Logging;
|
|
using Ryujinx.Cpu;
|
|
using Ryujinx.HLE.Utilities;
|
|
using System.IO;
|
|
using System.Reflection;
|
|
using System.Text;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Account.Acc
|
|
{
|
|
class IProfile : IpcService
|
|
{
|
|
private UserProfile _profile;
|
|
private Stream _profilePictureStream;
|
|
|
|
public IProfile(UserProfile profile)
|
|
{
|
|
_profile = profile;
|
|
_profilePictureStream = Assembly.GetCallingAssembly().GetManifestResourceStream("Ryujinx.HLE.RyujinxProfileImage.jpg");
|
|
}
|
|
|
|
[Command(0)]
|
|
// Get() -> (nn::account::profile::ProfileBase, buffer<nn::account::profile::UserData, 0x1a>)
|
|
public ResultCode Get(ServiceCtx context)
|
|
{
|
|
Logger.Stub?.PrintStub(LogClass.ServiceAcc);
|
|
|
|
long position = context.Request.ReceiveBuff[0].Position;
|
|
|
|
MemoryHelper.FillWithZeros(context.Memory, position, 0x80);
|
|
|
|
context.Memory.Write((ulong)position, 0);
|
|
context.Memory.Write((ulong)position + 4, 1);
|
|
context.Memory.Write((ulong)position + 8, 1L);
|
|
|
|
return GetBase(context);
|
|
}
|
|
|
|
[Command(1)]
|
|
// GetBase() -> nn::account::profile::ProfileBase
|
|
public ResultCode GetBase(ServiceCtx context)
|
|
{
|
|
_profile.UserId.Write(context.ResponseData);
|
|
|
|
context.ResponseData.Write(_profile.LastModifiedTimestamp);
|
|
|
|
byte[] username = StringUtils.GetFixedLengthBytes(_profile.Name, 0x20, Encoding.UTF8);
|
|
|
|
context.ResponseData.Write(username);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(10)]
|
|
// GetImageSize() -> u32
|
|
public ResultCode GetImageSize(ServiceCtx context)
|
|
{
|
|
context.ResponseData.Write(_profilePictureStream.Length);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(11)]
|
|
// LoadImage() -> (u32, buffer<bytes, 6>)
|
|
public ResultCode LoadImage(ServiceCtx context)
|
|
{
|
|
long bufferPosition = context.Request.ReceiveBuff[0].Position;
|
|
long bufferLen = context.Request.ReceiveBuff[0].Size;
|
|
|
|
byte[] profilePictureData = new byte[bufferLen];
|
|
|
|
_profilePictureStream.Read(profilePictureData, 0, profilePictureData.Length);
|
|
|
|
context.Memory.Write((ulong)bufferPosition, profilePictureData);
|
|
|
|
context.ResponseData.Write(_profilePictureStream.Length);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
}
|
|
} |