mirror of
				https://git.h3cjp.net/H3cJP/citra.git
				synced 2025-11-04 09:05:08 +00:00 
			
		
		
		
	Merge pull request #2293 from DarkLordZach/system-constants
core: Remove duplicated account JPEG data structure
This commit is contained in:
		
						commit
						357ea15a39
					
				| 
						 | 
				
			
			@ -5,6 +5,8 @@ add_library(core STATIC
 | 
			
		|||
    arm/exclusive_monitor.h
 | 
			
		||||
    arm/unicorn/arm_unicorn.cpp
 | 
			
		||||
    arm/unicorn/arm_unicorn.h
 | 
			
		||||
    constants.cpp
 | 
			
		||||
    constants.h
 | 
			
		||||
    core.cpp
 | 
			
		||||
    core.h
 | 
			
		||||
    core_cpu.cpp
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										17
									
								
								src/core/constants.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/core/constants.cpp
									
									
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,17 @@
 | 
			
		|||
// Copyright 2019 yuzu Emulator Project
 | 
			
		||||
// Licensed under GPLv2 or any later version
 | 
			
		||||
// Refer to the license.txt file included.
 | 
			
		||||
 | 
			
		||||
#include "core/constants.h"
 | 
			
		||||
 | 
			
		||||
namespace Core::Constants {
 | 
			
		||||
const std::array<u8, 107> ACCOUNT_BACKUP_JPEG{{
 | 
			
		||||
    0xff, 0xd8, 0xff, 0xdb, 0x00, 0x43, 0x00, 0x03, 0x02, 0x02, 0x02, 0x02, 0x02, 0x03, 0x02, 0x02,
 | 
			
		||||
    0x02, 0x03, 0x03, 0x03, 0x03, 0x04, 0x06, 0x04, 0x04, 0x04, 0x04, 0x04, 0x08, 0x06, 0x06, 0x05,
 | 
			
		||||
    0x06, 0x09, 0x08, 0x0a, 0x0a, 0x09, 0x08, 0x09, 0x09, 0x0a, 0x0c, 0x0f, 0x0c, 0x0a, 0x0b, 0x0e,
 | 
			
		||||
    0x0b, 0x09, 0x09, 0x0d, 0x11, 0x0d, 0x0e, 0x0f, 0x10, 0x10, 0x11, 0x10, 0x0a, 0x0c, 0x12, 0x13,
 | 
			
		||||
    0x12, 0x10, 0x13, 0x0f, 0x10, 0x10, 0x10, 0xff, 0xc9, 0x00, 0x0b, 0x08, 0x00, 0x01, 0x00, 0x01,
 | 
			
		||||
    0x01, 0x01, 0x11, 0x00, 0xff, 0xcc, 0x00, 0x06, 0x00, 0x10, 0x10, 0x05, 0xff, 0xda, 0x00, 0x08,
 | 
			
		||||
    0x01, 0x01, 0x00, 0x00, 0x3f, 0x00, 0xd2, 0xcf, 0x20, 0xff, 0xd9,
 | 
			
		||||
}};
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										17
									
								
								src/core/constants.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/core/constants.h
									
									
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,17 @@
 | 
			
		|||
// Copyright 2019 yuzu Emulator Project
 | 
			
		||||
// Licensed under GPLv2 or any later version
 | 
			
		||||
// Refer to the license.txt file included.
 | 
			
		||||
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
#include "common/common_types.h"
 | 
			
		||||
 | 
			
		||||
// This is to consolidate system-wide constants that are used by multiple components of yuzu.
 | 
			
		||||
// This is especially to prevent the case of something in frontend duplicating a constexpr array or
 | 
			
		||||
// directly including some service header for the sole purpose of data.
 | 
			
		||||
namespace Core::Constants {
 | 
			
		||||
 | 
			
		||||
// ACC Service - Blank JPEG used as user icon in absentia of real one.
 | 
			
		||||
extern const std::array<u8, 107> ACCOUNT_BACKUP_JPEG;
 | 
			
		||||
 | 
			
		||||
} // namespace Core::Constants
 | 
			
		||||
| 
						 | 
				
			
			@ -10,6 +10,7 @@
 | 
			
		|||
#include "common/logging/log.h"
 | 
			
		||||
#include "common/string_util.h"
 | 
			
		||||
#include "common/swap.h"
 | 
			
		||||
#include "core/constants.h"
 | 
			
		||||
#include "core/core_timing.h"
 | 
			
		||||
#include "core/hle/ipc_helpers.h"
 | 
			
		||||
#include "core/hle/service/acc/acc.h"
 | 
			
		||||
| 
						 | 
				
			
			@ -21,19 +22,6 @@
 | 
			
		|||
 | 
			
		||||
namespace Service::Account {
 | 
			
		||||
 | 
			
		||||
// Smallest JPEG https://github.com/mathiasbynens/small/blob/master/jpeg.jpg
 | 
			
		||||
// used as a backup should the one on disk not exist
 | 
			
		||||
constexpr u32 backup_jpeg_size = 107;
 | 
			
		||||
constexpr std::array<u8, backup_jpeg_size> backup_jpeg{{
 | 
			
		||||
    0xff, 0xd8, 0xff, 0xdb, 0x00, 0x43, 0x00, 0x03, 0x02, 0x02, 0x02, 0x02, 0x02, 0x03, 0x02, 0x02,
 | 
			
		||||
    0x02, 0x03, 0x03, 0x03, 0x03, 0x04, 0x06, 0x04, 0x04, 0x04, 0x04, 0x04, 0x08, 0x06, 0x06, 0x05,
 | 
			
		||||
    0x06, 0x09, 0x08, 0x0a, 0x0a, 0x09, 0x08, 0x09, 0x09, 0x0a, 0x0c, 0x0f, 0x0c, 0x0a, 0x0b, 0x0e,
 | 
			
		||||
    0x0b, 0x09, 0x09, 0x0d, 0x11, 0x0d, 0x0e, 0x0f, 0x10, 0x10, 0x11, 0x10, 0x0a, 0x0c, 0x12, 0x13,
 | 
			
		||||
    0x12, 0x10, 0x13, 0x0f, 0x10, 0x10, 0x10, 0xff, 0xc9, 0x00, 0x0b, 0x08, 0x00, 0x01, 0x00, 0x01,
 | 
			
		||||
    0x01, 0x01, 0x11, 0x00, 0xff, 0xcc, 0x00, 0x06, 0x00, 0x10, 0x10, 0x05, 0xff, 0xda, 0x00, 0x08,
 | 
			
		||||
    0x01, 0x01, 0x00, 0x00, 0x3f, 0x00, 0xd2, 0xcf, 0x20, 0xff, 0xd9,
 | 
			
		||||
}};
 | 
			
		||||
 | 
			
		||||
static std::string GetImagePath(Common::UUID uuid) {
 | 
			
		||||
    return FileUtil::GetUserPath(FileUtil::UserPath::NANDDir) +
 | 
			
		||||
           "/system/save/8000000000000010/su/avators/" + uuid.FormatSwitch() + ".jpg";
 | 
			
		||||
| 
						 | 
				
			
			@ -101,8 +89,8 @@ private:
 | 
			
		|||
        if (!image.IsOpen()) {
 | 
			
		||||
            LOG_WARNING(Service_ACC,
 | 
			
		||||
                        "Failed to load user provided image! Falling back to built-in backup...");
 | 
			
		||||
            ctx.WriteBuffer(backup_jpeg);
 | 
			
		||||
            rb.Push<u32>(backup_jpeg_size);
 | 
			
		||||
            ctx.WriteBuffer(Core::Constants::ACCOUNT_BACKUP_JPEG);
 | 
			
		||||
            rb.Push<u32>(Core::Constants::ACCOUNT_BACKUP_JPEG.size());
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -124,7 +112,7 @@ private:
 | 
			
		|||
        if (!image.IsOpen()) {
 | 
			
		||||
            LOG_WARNING(Service_ACC,
 | 
			
		||||
                        "Failed to load user provided image! Falling back to built-in backup...");
 | 
			
		||||
            rb.Push<u32>(backup_jpeg_size);
 | 
			
		||||
            rb.Push<u32>(Core::Constants::ACCOUNT_BACKUP_JPEG.size());
 | 
			
		||||
        } else {
 | 
			
		||||
            rb.Push<u32>(SanitizeJPEGSize(image.GetSize()));
 | 
			
		||||
        }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -12,21 +12,11 @@
 | 
			
		|||
#include <QVBoxLayout>
 | 
			
		||||
#include "common/file_util.h"
 | 
			
		||||
#include "common/string_util.h"
 | 
			
		||||
#include "core/constants.h"
 | 
			
		||||
#include "core/hle/lock.h"
 | 
			
		||||
#include "yuzu/applets/profile_select.h"
 | 
			
		||||
#include "yuzu/main.h"
 | 
			
		||||
 | 
			
		||||
// Same backup JPEG used by acc IProfile::GetImage if no jpeg found
 | 
			
		||||
constexpr std::array<u8, 107> backup_jpeg{
 | 
			
		||||
    0xff, 0xd8, 0xff, 0xdb, 0x00, 0x43, 0x00, 0x03, 0x02, 0x02, 0x02, 0x02, 0x02, 0x03, 0x02, 0x02,
 | 
			
		||||
    0x02, 0x03, 0x03, 0x03, 0x03, 0x04, 0x06, 0x04, 0x04, 0x04, 0x04, 0x04, 0x08, 0x06, 0x06, 0x05,
 | 
			
		||||
    0x06, 0x09, 0x08, 0x0a, 0x0a, 0x09, 0x08, 0x09, 0x09, 0x0a, 0x0c, 0x0f, 0x0c, 0x0a, 0x0b, 0x0e,
 | 
			
		||||
    0x0b, 0x09, 0x09, 0x0d, 0x11, 0x0d, 0x0e, 0x0f, 0x10, 0x10, 0x11, 0x10, 0x0a, 0x0c, 0x12, 0x13,
 | 
			
		||||
    0x12, 0x10, 0x13, 0x0f, 0x10, 0x10, 0x10, 0xff, 0xc9, 0x00, 0x0b, 0x08, 0x00, 0x01, 0x00, 0x01,
 | 
			
		||||
    0x01, 0x01, 0x11, 0x00, 0xff, 0xcc, 0x00, 0x06, 0x00, 0x10, 0x10, 0x05, 0xff, 0xda, 0x00, 0x08,
 | 
			
		||||
    0x01, 0x01, 0x00, 0x00, 0x3f, 0x00, 0xd2, 0xcf, 0x20, 0xff, 0xd9,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
QString FormatUserEntryText(const QString& username, Common::UUID uuid) {
 | 
			
		||||
    return QtProfileSelectionDialog::tr(
 | 
			
		||||
               "%1\n%2", "%1 is the profile username, %2 is the formatted UUID (e.g. "
 | 
			
		||||
| 
						 | 
				
			
			@ -45,7 +35,8 @@ QPixmap GetIcon(Common::UUID uuid) {
 | 
			
		|||
 | 
			
		||||
    if (!icon) {
 | 
			
		||||
        icon.fill(Qt::black);
 | 
			
		||||
        icon.loadFromData(backup_jpeg.data(), static_cast<u32>(backup_jpeg.size()));
 | 
			
		||||
        icon.loadFromData(Core::Constants::ACCOUNT_BACKUP_JPEG.data(),
 | 
			
		||||
                          static_cast<u32>(Core::Constants::ACCOUNT_BACKUP_JPEG.size()));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return icon.scaled(64, 64, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue