2016-08-03 20:46:46 +02:00
/****************************************************************************
2017-03-30 17:53:36 +02:00
* Copyright ( C ) 2016 , 2017 Maschell
2016-08-03 20:46:46 +02:00
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2017-05-07 14:44:09 +02:00
# include "./ConfigParser.hpp"
2016-08-03 20:46:46 +02:00
# include <algorithm>
# include <stdio.h>
# include <stdlib.h>
# include <string.h>
2017-03-30 17:53:36 +02:00
ConfigParser : : ConfigParser ( std : : string configData ) {
2016-08-03 20:46:46 +02:00
this - > content = configData ;
2017-03-30 17:53:36 +02:00
this - > contentLines = CPStringTools : : StringSplit ( content , " \n " ) ;
2016-08-03 20:46:46 +02:00
if ( contentLines . empty ( ) )
return ;
//remove the comments and make everything uppercase
for ( u32 i = 0 ; i < contentLines . size ( ) ; i + + ) {
2017-03-30 17:53:36 +02:00
std : : vector < std : : string > comments = CPStringTools : : StringSplit ( contentLines [ i ] , " // " ) ;
2016-08-03 20:46:46 +02:00
if ( ! comments . empty ( ) ) {
contentLines [ i ] = comments [ 0 ] ;
}
//we want everything uppercase
std : : transform ( contentLines [ i ] . begin ( ) , contentLines [ i ] . end ( ) , contentLines [ i ] . begin ( ) , : : toupper ) ;
}
//remove empty lines
std : : vector < std : : string > contentline2 ;
for ( u32 i = 0 ; i < contentLines . size ( ) ; i + + ) {
if ( strlen ( contentLines [ i ] . c_str ( ) ) > 0 ) {
contentline2 . push_back ( contentLines [ i ] ) ;
}
}
contentLines = contentline2 ;
Init ( ) ;
}
2017-03-30 17:53:36 +02:00
ConfigParser : : ~ ConfigParser ( ) {
2016-08-03 20:46:46 +02:00
}
PARSE_TYPE ConfigParser : : getType ( ) {
return type_b ;
}
void ConfigParser : : setType ( PARSE_TYPE newType ) {
this - > type_b = newType ;
}
u16 ConfigParser : : getSlot ( ) {
return this - > slot_b ;
}
void ConfigParser : : setSlot ( u16 newSlot ) {
this - > slot_b = newSlot ;
}
bool ConfigParser : : Init ( ) {
2017-03-30 17:53:36 +02:00
if ( contentLines . size ( ) = = 0 ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::Init(line %d): Files seems to be empty. Make sure to have a proper header \n " , __LINE__ ) ;
2017-03-30 17:53:36 +02:00
return false ;
}
2016-08-03 20:46:46 +02:00
const char * line = contentLines [ 0 ] . c_str ( ) ;
2017-04-10 11:00:55 +02:00
s32 len = strlen ( line ) ;
2016-08-03 20:46:46 +02:00
std : : string identify ;
if ( line [ 0 ] = = ' [ ' & & line [ len - 1 ] = = ' ] ' ) {
identify = contentLines [ 0 ] . substr ( 1 , len - 2 ) ;
} else {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::Init((line %d): Not a proper config file! \n " , __LINE__ ) ;
2016-08-03 20:46:46 +02:00
return false ;
}
if ( identify . compare ( " GAMEPAD " ) = = 0 ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::Init((line %d): Its a gamepad config file! \n " , __LINE__ ) ;
2016-08-03 20:46:46 +02:00
setSlot ( gGamePadSlot ) ;
setType ( PARSE_GAMEPAD ) ;
} else if ( identify . compare ( " MOUSE " ) = = 0 ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::Init((line %d): Its a mouse config file! \n " , __LINE__ ) ;
2016-08-03 20:46:46 +02:00
setSlot ( gMouseSlot ) ;
setType ( PARSE_MOUSE ) ;
2017-03-30 17:53:36 +02:00
this - > vid = HID_MOUSE_VID ;
this - > pid = HID_MOUSE_PID ;
2016-08-03 20:46:46 +02:00
} else if ( identify . compare ( " KEYBOARD " ) = = 0 ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::Init((line %d): Its a keyboard config file! \n " , __LINE__ ) ;
2016-08-03 20:46:46 +02:00
setSlot ( gHID_SLOT_KEYBOARD ) ;
setType ( PARSE_KEYBOARD ) ;
2017-03-30 17:53:36 +02:00
this - > vid = HID_KEYBOARD_VID ;
this - > pid = HID_KEYBOARD_PID ;
2016-08-03 20:46:46 +02:00
} else {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::Init((line %d): Its a controller config file! \n " , __LINE__ ) ;
2017-03-30 17:53:36 +02:00
2016-08-03 20:46:46 +02:00
setSlot ( getSlotController ( identify ) ) ;
setType ( PARSE_CONTROLLER ) ;
}
if ( getSlot ( ) = = HID_INVALID_SLOT ) {
return false ;
}
ConfigReader : : increaseNumberOfLoadedFiles ( ) ;
return true ;
}
void ConfigParser : : parseSingleLine ( std : : string line ) {
2017-03-30 17:53:36 +02:00
std : : vector < std : : string > cur_values = CPStringTools : : StringSplit ( line , " = " ) ;
2016-08-03 20:46:46 +02:00
if ( cur_values . size ( ) ! = 2 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG | | cur_values . size ( ) > 2 ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Not a valid key=pair line %s \n " , __LINE__ , line . c_str ( ) ) ; }
2016-08-03 20:46:46 +02:00
return ;
} else {
u16 hid_slot = getSlot ( ) ;
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): leftpart = \" %s \" \n " , __LINE__ , cur_values [ 0 ] . c_str ( ) ) ; }
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): rightpart = \" %s \" \n " , __LINE__ , cur_values [ 1 ] . c_str ( ) ) ; }
2017-04-10 11:00:55 +02:00
s32 keyslot = - 1 ;
2016-08-03 20:46:46 +02:00
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Checking single value \n " , __LINE__ ) ; }
2017-04-01 17:35:50 +02:00
if ( getType ( ) = = PARSE_GAMEPAD | | getType ( ) = = PARSE_KEYBOARD ) {
2016-08-03 20:46:46 +02:00
keyslot = ConfigValues : : getKeySlotGamePad ( cur_values [ 0 ] ) ;
} else if ( getType ( ) = = PARSE_MOUSE ) {
keyslot = ConfigValues : : getKeySlotMouse ( cur_values [ 0 ] ) ;
} else {
keyslot = ConfigValues : : getKeySlotDefaultSingleValue ( cur_values [ 0 ] ) ;
}
if ( keyslot ! = - 1 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Its a single value \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
long rightValue = - 1 ;
bool valueSet = false ;
if ( cur_values [ 0 ] . compare ( " DPAD_MODE " ) = = 0 ) {
const u8 * values_ = NULL ;
if ( ( values_ = ConfigValues : : getValuesStickPreset ( cur_values [ 1 ] ) ) ! = NULL ) {
if ( values_ [ STICK_CONF_MAGIC_VERSION ] ! = STICK_CONF_MAGIC_VALUE )
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Settings preset DPAD MODE and Mask \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
config_controller [ hid_slot ] [ CONTRPS_DPAD_MODE ] [ 0 ] = CONTROLLER_PATCHER_VALUE_SET ;
config_controller [ hid_slot ] [ CONTRPS_DPAD_MODE ] [ 1 ] = values_ [ CONTRDPAD_MODE ] ;
if ( values_ [ CONTRDPAD_MASK ] ! = 0x00 ) {
config_controller [ hid_slot ] [ CONTRPS_DPAD_MASK ] [ 0 ] = CONTROLLER_PATCHER_VALUE_SET ;
config_controller [ hid_slot ] [ CONTRPS_DPAD_MASK ] [ 1 ] = values_ [ CONTRDPAD_MASK ] ;
}
valueSet = true ;
}
}
if ( ! valueSet ) {
if ( getType ( ) = = PARSE_KEYBOARD ) {
if ( ( rightValue = ConfigValues : : getPresetValuesKeyboard ( cur_values [ 1 ] ) ) ! = - 1 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Used pre-defined Keyboard! \" %s \" is %d \n " , __LINE__ , cur_values [ 1 ] . c_str ( ) , rightValue ) ; }
2016-08-03 20:46:46 +02:00
} else {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): I need to parse %s \n " , __LINE__ , cur_values [ 1 ] . c_str ( ) ) ; }
2016-08-03 20:46:46 +02:00
char * ptr ;
rightValue = strtol ( cur_values [ 1 ] . c_str ( ) , & ptr , 16 ) ;
}
} else {
rightValue = ConfigValues : : getPresetValue ( cur_values [ 1 ] ) ;
if ( getType ( ) = = PARSE_MOUSE ) { //No parsing for the mouse
if ( rightValue = = - 1 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Invalid mouse value, lets skip it %s \n " , __LINE__ , cur_values [ 1 ] . c_str ( ) ) ; }
2016-08-03 20:46:46 +02:00
return ;
}
} else {
if ( rightValue = = - 1 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): I need to parse %s \n " , __LINE__ , cur_values [ 1 ] . c_str ( ) ) ; }
2016-08-03 20:46:46 +02:00
char * ptr ;
rightValue = strtol ( cur_values [ 1 ] . c_str ( ) , & ptr , 16 ) ;
}
}
}
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Setting value to %d \n " , __LINE__ , rightValue ) ; }
2016-08-03 20:46:46 +02:00
config_controller [ hid_slot ] [ keyslot ] [ 0 ] = CONTROLLER_PATCHER_VALUE_SET ;
config_controller [ hid_slot ] [ keyslot ] [ 1 ] = rightValue ;
}
} else {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Check pair value \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
keyslot = ConfigValues : : getKeySlotDefaultPairedValue ( cur_values [ 0 ] ) ;
if ( keyslot ! = - 1 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Its a pair value \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
if ( ! ConfigValues : : getInstance ( ) - > setIfValueIsAControllerPreset ( cur_values [ 1 ] , getSlot ( ) , keyslot ) ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): And its no preset \n " , __LINE__ ) ; }
2017-03-30 17:53:36 +02:00
std : : vector < std : : string > rightvalues = CPStringTools : : StringSplit ( cur_values [ 1 ] , " , " ) ;
2016-08-03 20:46:46 +02:00
if ( rightvalues . size ( ) ! = 2 ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::parseSingleLine(line %d): %d instead of 2 key=values pairs in line \n " , __LINE__ , rightvalues . size ( ) ) ;
2016-08-03 20:46:46 +02:00
return ;
}
char * ptr ;
long firstValue = strtol ( rightvalues [ 0 ] . c_str ( ) , & ptr , 16 ) ;
long secondValue = strtol ( rightvalues [ 1 ] . c_str ( ) , & ptr , 16 ) ;
config_controller [ hid_slot ] [ keyslot ] [ 0 ] = firstValue ;
config_controller [ hid_slot ] [ keyslot ] [ 1 ] = secondValue ;
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Set %02X,%02X \n " , __LINE__ , firstValue , secondValue ) ; }
2016-08-03 20:46:46 +02:00
} else {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseSingleLine(line %d): Found preset value!! \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
}
} else {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::parseSingleLine(line %d): The setting \" %s \" is unknown! \n " , __LINE__ , cur_values [ 0 ] . c_str ( ) ) ;
2016-08-03 20:46:46 +02:00
}
}
}
}
bool ConfigParser : : resetConfig ( ) {
2017-04-10 11:00:55 +02:00
s32 slot = getSlot ( ) ;
2016-08-03 20:46:46 +02:00
if ( slot > = gHIDMaxDevices ) return false ;
2017-04-10 11:00:55 +02:00
for ( s32 j = ( CONTRPS_PID + 1 ) ; j < CONTRPS_MAX_VALUE ; j + + ) {
2016-08-03 20:46:46 +02:00
config_controller [ slot ] [ j ] [ 0 ] = CONTROLLER_PATCHER_INVALIDVALUE ;
config_controller [ slot ] [ j ] [ 1 ] = CONTROLLER_PATCHER_INVALIDVALUE ;
}
return true ;
}
2017-04-10 11:00:55 +02:00
s32 ConfigParser : : getSlotController ( std : : string identify ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::getSlotController(line %d): Getting Controller Slot \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
2017-03-30 17:53:36 +02:00
std : : vector < std : : string > values = CPStringTools : : StringSplit ( identify , " , " ) ;
2016-08-03 20:46:46 +02:00
if ( values . size ( ) ! = 2 ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::getSlotController(line %d): You need to provide a VID and PID. e.g. \" [vid=0x451,pid=0x152] \" . (%s) \n " , __LINE__ , identify . c_str ( ) ) ;
2016-08-03 20:46:46 +02:00
return HID_INVALID_SLOT ;
}
2017-04-10 11:00:55 +02:00
s32 vid = getValueFromKeyValue ( values [ 0 ] , " VID " , " = " ) ;
2016-08-03 20:46:46 +02:00
if ( vid < 0 ) {
return HID_INVALID_SLOT ;
}
2017-04-10 11:00:55 +02:00
s32 pid = getValueFromKeyValue ( values [ 1 ] , " PID " , " = " ) ;
2016-08-03 20:46:46 +02:00
if ( pid < 0 ) {
return HID_INVALID_SLOT ;
}
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::getSlotController(line %d): VID: %04x PID: %04x \n " , __LINE__ , vid , pid ) ;
2017-03-30 17:53:36 +02:00
this - > vid = vid ;
this - > pid = pid ;
DeviceInfo deviceinfo ;
memset ( & deviceinfo , 0 , sizeof ( deviceinfo ) ) ;
2017-03-31 16:48:12 +02:00
deviceinfo . vidpid . vid = vid ;
deviceinfo . vidpid . pid = pid ;
2017-04-10 11:00:55 +02:00
s32 result = ControllerPatcherUtils : : getDeviceInfoFromVidPid ( & deviceinfo ) ;
s32 slot = deviceinfo . slotdata . deviceslot ;
s32 hid = 0 ;
2017-03-30 17:53:36 +02:00
if ( result < 0 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::getSlotController(line %d): Its a new controller, lets save it \n " , __LINE__ ) ; }
2017-03-30 17:53:36 +02:00
HIDSlotData slotdata ;
ControllerPatcherUtils : : getNextSlotData ( & slotdata ) ;
slot = slotdata . deviceslot ;
hid = slotdata . hidmask ;
2016-08-03 20:46:46 +02:00
if ( slot > = gHIDMaxDevices ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::getSlotController(line %d): ConfigParser::getSlotController: We don't a space for a new controller, please delete .inis \n " , __LINE__ ) ;
2016-08-03 20:46:46 +02:00
return HID_INVALID_SLOT ;
}
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::getSlotController(line %d): Got new slot! slot: %d hid %s .. Lets registrate it! \n " , __LINE__ , slot , CPStringTools : : byte_to_binary ( hid ) ) ; }
2016-08-03 20:46:46 +02:00
config_controller [ slot ] [ CONTRPS_VID ] [ 0 ] = ( vid & 0xFF00 ) > > 8 ;
config_controller [ slot ] [ CONTRPS_VID ] [ 1 ] = ( vid & 0x00FF ) ;
config_controller [ slot ] [ CONTRPS_PID ] [ 0 ] = ( pid & 0xFF00 ) > > 8 ;
config_controller [ slot ] [ CONTRPS_PID ] [ 1 ] = ( pid & 0x00FF ) ;
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) {
log_printf ( " ConfigParser::getSlotController(line %d): Saved vid: %04X pid: %04X \n " , __LINE__ ,
config_controller [ slot ] [ CONTRPS_VID ] [ 0 ] * 0x100 + config_controller [ slot ] [ CONTRPS_VID ] [ 1 ] ,
config_controller [ slot ] [ CONTRPS_PID ] [ 0 ] * 0x100 + config_controller [ slot ] [ CONTRPS_PID ] [ 1 ] ) ; }
2016-08-03 20:46:46 +02:00
2017-03-30 17:53:36 +02:00
config_controller_hidmask [ slot ] = hid ;
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::getSlotController(line %d): Saved the hid \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
} else {
if ( slot < gHIDMaxDevices ) {
2017-03-30 17:53:36 +02:00
hid = config_controller_hidmask [ slot ] ;
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::getSlotController(line %d): >>>>>> found slot %d (hid:%s). Modifing existing data <<<<<<<< \n " , __LINE__ , slot , CPStringTools : : byte_to_binary ( hid ) ) ; }
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::getSlotController(line %d): We already have data of this controller, lets modify it \n " , __LINE__ ) ;
2016-08-03 20:46:46 +02:00
} else {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::getSlotController(line %d): Something really odd happend to the slots. %d is bigger then max (%d) \n " , __LINE__ , slot , gHIDMaxDevices ) ;
2016-08-03 20:46:46 +02:00
return HID_INVALID_SLOT ;
}
}
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::getSlotController(line %d): using slot: %d hid %08X \n " , __LINE__ , slot , hid ) ;
2016-08-03 20:46:46 +02:00
return slot ;
}
bool ConfigParser : : parseIni ( ) {
if ( getSlot ( ) = = HID_INVALID_SLOT ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::parseIni(line %d): Couldn't parse file. Not a valid slot. Probably broken config. Or you tried to have more than %d devices \n " , __LINE__ , getType ( ) , gHIDMaxDevices ) ;
2016-08-03 20:46:46 +02:00
}
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseIni(line %d): Parsing content, type %d \n " , __LINE__ , getType ( ) ) ; }
2016-08-03 20:46:46 +02:00
2017-04-10 11:00:55 +02:00
s32 start = 1 ;
2016-08-03 20:46:46 +02:00
if ( contentLines [ 1 ] . compare ( " [IGNOREDEFAULT] " ) = = 0 ) {
resetConfig ( ) ;
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::parseIni(line %d): Ignoring existing settings of this device \n " , __LINE__ ) ;
2016-08-03 20:46:46 +02:00
start + + ;
}
for ( u32 i = start ; i < contentLines . size ( ) ; i + + ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseIni(line %d): line %d: \" %s \" \n " , __LINE__ , ( i + 1 ) , contentLines [ i ] . c_str ( ) ) ; }
2016-08-03 20:46:46 +02:00
parseSingleLine ( contentLines [ i ] ) ;
}
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG ) { log_printf ( " ConfigParser::parseIni(line %d): Parsing of the file is done. \n " , __LINE__ ) ; }
2016-08-03 20:46:46 +02:00
return true ;
}
2017-04-10 11:00:55 +02:00
s32 ConfigParser : : getValueFromKeyValue ( std : : string value_pair , std : : string expectedKey , std : : string delimiter ) {
2017-03-30 17:53:36 +02:00
std : : vector < std : : string > string_value = CPStringTools : : StringSplit ( value_pair , delimiter ) ;
2016-08-03 20:46:46 +02:00
if ( string_value . size ( ) ! = 2 ) {
2017-05-06 19:46:05 +02:00
if ( HID_DEBUG | | string_value . size ( ) > 2 ) { log_printf ( " ConfigParser::getValueFromKeyValue(line %d): Not a valid key=pair line %s \n " , __LINE__ , value_pair . c_str ( ) ) ; }
2016-08-03 20:46:46 +02:00
return - 1 ;
}
if ( string_value [ 0 ] . compare ( expectedKey ) ! = 0 ) {
2017-04-10 11:00:55 +02:00
log_printf ( " ConfigParser::getValueFromKeyValue(line %d): Key part not %s, its %s " , __LINE__ , expectedKey . c_str ( ) , string_value [ 0 ] . c_str ( ) ) ;
2016-08-03 20:46:46 +02:00
return - 1 ;
}
char * ptr ;
2017-04-10 11:00:55 +02:00
s32 value = strtol ( string_value [ 1 ] . c_str ( ) , & ptr , 16 ) ;
2016-08-03 20:46:46 +02:00
return value ;
}