libnx/nx/include/switch/services/set.h
2018-06-03 21:04:29 -05:00

124 lines
4.3 KiB
C

/**
* @file set.h
* @brief Settings services IPC wrapper.
* @author plutoo
* @author yellows8
* @copyright libnx Authors
*/
#include "../result.h"
typedef enum {
ColorSetId_Light=0,
ColorSetId_Dark=1
} ColorSetId;
/// IDs for Language.
typedef enum
{
SetLanguage_JA = 0, ///< Japanese
SetLanguage_ENUS = 1, ///< US English ("AmericanEnglish")
SetLanguage_FR = 2, ///< French
SetLanguage_DE = 3, ///< German
SetLanguage_IT = 4, ///< Italian
SetLanguage_ES = 5, ///< Spanish
SetLanguage_ZHCN = 6, ///< Simplified Chinese ("Chinese")
SetLanguage_KO = 7, ///< Korean
SetLanguage_NL = 8, ///< Dutch
SetLanguage_PT = 9, ///< Portuguese
SetLanguage_RU = 10, ///< Russian
SetLanguage_ZHTW = 11, ///< Traditional Chinese ("Taiwanese")
SetLanguage_ENGB = 12, ///< GB English ("BritishEnglish")
SetLanguage_FRCA = 13, ///< CA French ("CanadianFrench")
SetLanguage_ES419 = 14, ///< "LatinAmericanSpanish"
SetLanguage_Total, ///< Total languages supported by this enum.
} SetLanguage;
/// Command IDS for setsysGetFlag/setsysSetFlag.
typedef enum {
setsysGetLockScreenFlag = 7,
setsysSetLockScreenFlag = 8,
setsysGetConsoleInformationUploadFlag = 25,
setsysSetConsoleInformationUploadFlag = 26,
setsysGetAutomaticApplicationDownloadFlag = 27,
setsysSetAutomaticApplicationDownloadFlag = 28,
setsysGetQuestFlag = 47,
setsysSetQuestFlag = 48,
setsysGetUsb30EnableFlag = 65,
setsysSetUsb30EnableFlag = 66,
setsysGetNfcEnableFlag = 69,
setsysSetNfcEnableFlag = 70,
setsysGetWirelessLanEnableFlag = 73,
setsysSetWirelessLanEnableFlag = 74,
setsysGetBluetoothEnableFlag = 88,
setsysSetBluetoothEnableFlag = 89,
setsysGetAutoUpdateEnableFlag = 95,
setsysSetAutoUpdateEnableFlag = 96,
setsysGetBatteryPercentageFlag = 99,
setsysSetBatteryPercentageFlag = 100,
setsysGetExternalRtcResetFlag = 101,
setsysSetExternalRtcResetFlag = 102,
setsysGetUsbFullKeyEnableFlag = 103,
setsysSetUsbFullKeyEnableFlag = 104,
setsysGetBluetoothAfhEnableFlag = 111,
setsysSetBluetoothAfhEnableFlag = 112,
setsysGetBluetoothBoostEnableFlag = 113,
setsysSetBluetoothBoostEnableFlag = 114,
setsysGetInRepairProcessEnableFlag = 115,
setsysSetInRepairProcessEnableFlag = 116,
setsysGetHeadphoneVolumeUpdateFlag = 117,
setsysSetHeadphoneVolumeUpdateFlag = 118,
} SetSysFlag;
Result setInitialize(void);
void setExit(void);
/// Converts LanguageCode to Language.
Result setMakeLanguage(u64 LanguageCode, s32 *Language);
/// Converts Language to LanguageCode.
Result setMakeLanguageCode(s32 Language, u64 *LanguageCode);
/// Gets the current system LanguageCode.
/// Normally this should be used instead of \ref setGetLanguageCode.
/// LanguageCode is a string, see here: http://switchbrew.org/index.php?title=Settings_services#LanguageCode
Result setGetSystemLanguage(u64 *LanguageCode);
/// Gets the current LanguageCode, \ref setGetSystemLanguage should be used instead normally.
Result setGetLanguageCode(u64 *LanguageCode);
/// Gets available LanguageCodes.
/// On system-version <4.0.0, max_entries is set to the output from \ref setGetAvailableLanguageCodeCount if max_entries is larger than that.
Result setGetAvailableLanguageCodes(s32 *total_entries, u64 *LanguageCodes, size_t max_entries);
/// Gets total available LanguageCodes.
/// Output total is overridden with value 0 if the total is <0.
Result setGetAvailableLanguageCodeCount(s32 *total);
/// Gets the RegionCode.
Result setGetRegionCode(s32 *RegionCode);
Result setsysInitialize(void);
void setsysExit(void);
/// Gets the current system theme.
Result setsysGetColorSetId(ColorSetId* out);
/**
* @brief Gets the system's serial number.
* @param serial Pointer to output the serial to. (The buffer size needs to be at least 0x19 bytes)
*/
Result setsysGetSerialNumber(char *serial);
/**
* @brief Gets the status of the specified settings flag
* @param flag The specified settings flag.
* @param out Pointer To get the status from.
*/
Result setsysGetFlag(SetSysFlag flag, bool *out);
/**
* @brief Enables/disables the specified settings flag.
* @param flag The specified settings flag.
* @param enable To enable/disable the flag.
*/
Result setsysSetFlag(SetSysFlag flag, bool enable);