@ -63,20 +63,20 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
( " data " , bpo : : value < Files : : EscapePathContainer > ( ) - > default_value ( Files : : EscapePathContainer ( ) , " data " )
( " data " , bpo : : value < Files : : EscapePathContainer > ( ) - > default_value ( Files : : EscapePathContainer ( ) , " data " )
- > multitoken ( ) - > composing ( ) , " set data directories (later directories have higher priority) " )
- > multitoken ( ) - > composing ( ) , " set data directories (later directories have higher priority) " )
( " data-local " , bpo : : value < Files : : Escape HashString > ( ) - > default_value ( " " ) ,
( " data-local " , bpo : : value < Files : : Escape Path > ( ) - > default_value ( Files : : EscapePath ( ) , " " ) ,
" set local data directory (highest priority) " )
" set local data directory (highest priority) " )
( " fallback-archive " , bpo : : value < Files : : EscapeStringVector > ( ) - > default_value ( Files : : EscapeStringVector ( ) , " fallback-archive " )
( " fallback-archive " , bpo : : value < Files : : EscapeStringVector > ( ) - > default_value ( Files : : EscapeStringVector ( ) , " fallback-archive " )
- > multitoken ( ) , " set fallback BSA archives (later archives have higher priority) " )
- > multitoken ( ) - > composing ( ) , " set fallback BSA archives (later archives have higher priority) " )
( " resources " , bpo : : value < Files : : Escape HashString > ( ) - > default_value ( " resources " ) ,
( " resources " , bpo : : value < Files : : Escape Path > ( ) - > default_value ( Files : : EscapePath ( ) , " resources " ) ,
" set resources directory " )
" set resources directory " )
( " start " , bpo : : value < Files : : EscapeHashString > ( ) - > default_value ( " " ) ,
( " start " , bpo : : value < Files : : EscapeHashString > ( ) - > default_value ( " " ) ,
" set initial cell " )
" set initial cell " )
( " content " , bpo : : value < Files : : EscapeStringVector > ( ) - > default_value ( Files : : EscapeStringVector ( ) , " " )
( " content " , bpo : : value < Files : : EscapeStringVector > ( ) - > default_value ( Files : : EscapeStringVector ( ) , " " )
- > multitoken ( ) , " content file(s): esm/esp, or omwgame/omwaddon " )
- > multitoken ( ) - > composing ( ) , " content file(s): esm/esp, or omwgame/omwaddon " )
( " no-sound " , bpo : : value < bool > ( ) - > implicit_value ( true )
( " no-sound " , bpo : : value < bool > ( ) - > implicit_value ( true )
- > default_value ( false ) , " disable all sounds " )
- > default_value ( false ) , " disable all sounds " )
@ -90,7 +90,7 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
( " script-console " , bpo : : value < bool > ( ) - > implicit_value ( true )
( " script-console " , bpo : : value < bool > ( ) - > implicit_value ( true )
- > default_value ( false ) , " enable console-only script functionality " )
- > default_value ( false ) , " enable console-only script functionality " )
( " script-run " , bpo : : value < Files : : EscapeHashString > ( ) - > default_value ( " " ) ,
( " script-run " , bpo : : value < Files : : EscapeHashString > ( ) - > default_value ( " " ) ,
" select a file containing a list of console commands that is executed on startup " )
" select a file containing a list of console commands that is executed on startup " )
( " script-warn " , bpo : : value < int > ( ) - > implicit_value ( 1 )
( " script-warn " , bpo : : value < int > ( ) - > implicit_value ( 1 )
@ -101,12 +101,12 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
" \t 2 - treat warnings as errors " )
" \t 2 - treat warnings as errors " )
( " script-blacklist " , bpo : : value < Files : : EscapeStringVector > ( ) - > default_value ( Files : : EscapeStringVector ( ) , " " )
( " script-blacklist " , bpo : : value < Files : : EscapeStringVector > ( ) - > default_value ( Files : : EscapeStringVector ( ) , " " )
- > multitoken ( ) , " ignore the specified script (if the use of the blacklist is enabled) " )
- > multitoken ( ) - > composing ( ) , " ignore the specified script (if the use of the blacklist is enabled) " )
( " script-blacklist-use " , bpo : : value < bool > ( ) - > implicit_value ( true )
( " script-blacklist-use " , bpo : : value < bool > ( ) - > implicit_value ( true )
- > default_value ( true ) , " enable script blacklisting " )
- > default_value ( true ) , " enable script blacklisting " )
( " load-savegame " , bpo : : value < Files : : Escape HashString > ( ) - > default_value ( " " ) ,
( " load-savegame " , bpo : : value < Files : : Escape Path > ( ) - > default_value ( Files : : EscapePath ( ) , " " ) ,
" load a save game file on game startup (specify an absolute filename or a filename relative to the current working directory) " )
" load a save game file on game startup (specify an absolute filename or a filename relative to the current working directory) " )
( " skip-menu " , bpo : : value < bool > ( ) - > implicit_value ( true )
( " skip-menu " , bpo : : value < bool > ( ) - > implicit_value ( true )
@ -118,14 +118,14 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
( " fs-strict " , bpo : : value < bool > ( ) - > implicit_value ( true )
( " fs-strict " , bpo : : value < bool > ( ) - > implicit_value ( true )
- > default_value ( false ) , " strict file system handling (no case folding) " )
- > default_value ( false ) , " strict file system handling (no case folding) " )
( " encoding " , bpo : : value < Files : : EscapeHashString > ( ) - >
( " encoding " , bpo : : value < Files : : EscapeHashString > ( ) - >
default_value ( " win1252 " ) ,
default_value ( " win1252 " ) ,
" Character encoding used in OpenMW game messages: \n "
" Character encoding used in OpenMW game messages: \n "
" \n \t win1250 - Central and Eastern European such as Polish, Czech, Slovak, Hungarian, Slovene, Bosnian, Croatian, Serbian (Latin script), Romanian and Albanian languages \n "
" \n \t win1250 - Central and Eastern European such as Polish, Czech, Slovak, Hungarian, Slovene, Bosnian, Croatian, Serbian (Latin script), Romanian and Albanian languages \n "
" \n \t win1251 - Cyrillic alphabet such as Russian, Bulgarian, Serbian Cyrillic and other languages \n "
" \n \t win1251 - Cyrillic alphabet such as Russian, Bulgarian, Serbian Cyrillic and other languages \n "
" \n \t win1252 - Western European (Latin) alphabet, used by default " )
" \n \t win1252 - Western European (Latin) alphabet, used by default " )
( " fallback " , bpo : : value < FallbackMap > ( ) - > default_value ( FallbackMap ( ) , " " )
( " fallback " , bpo : : value < FallbackMap > ( ) - > default_value ( FallbackMap ( ) , " " )
- > multitoken ( ) - > composing ( ) , " fallback values " )
- > multitoken ( ) - > composing ( ) , " fallback values " )
( " no-grab " , bpo : : value < bool > ( ) - > implicit_value ( true ) - > default_value ( false ) , " Don't grab mouse cursor " )
( " no-grab " , bpo : : value < bool > ( ) - > implicit_value ( true ) - > default_value ( false ) , " Don't grab mouse cursor " )
@ -159,14 +159,16 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
{
{
cfgMgr . readConfiguration ( variables , desc , true ) ;
cfgMgr . readConfiguration ( variables , desc , true ) ;
Version : : Version v = Version : : getOpenmwVersion ( variables [ " resources " ] . as < Files : : Escape HashString> ( ) . toStdS tring( ) ) ;
Version : : Version v = Version : : getOpenmwVersion ( variables [ " resources " ] . as < Files : : Escape Path> ( ) . mPath . s tring( ) ) ;
std : : cout < < v . describe ( ) < < std : : endl ;
std : : cout < < v . describe ( ) < < std : : endl ;
return false ;
return false ;
}
}
bpo : : variables_map composingVariables = cfgMgr . separateComposingVariables ( variables , desc ) ;
cfgMgr . readConfiguration ( variables , desc ) ;
cfgMgr . readConfiguration ( variables , desc ) ;
cfgMgr . mergeComposingVariables ( variables , composingVariables , desc ) ;
Version : : Version v = Version : : getOpenmwVersion ( variables [ " resources " ] . as < Files : : Escape HashString> ( ) . toStdS tring( ) ) ;
Version : : Version v = Version : : getOpenmwVersion ( variables [ " resources " ] . as < Files : : Escape Path> ( ) . mPath . s tring( ) ) ;
std : : cout < < v . describe ( ) < < std : : endl ;
std : : cout < < v . describe ( ) < < std : : endl ;
engine . setGrabMouse ( ! variables [ " no-grab " ] . as < bool > ( ) ) ;
engine . setGrabMouse ( ! variables [ " no-grab " ] . as < bool > ( ) ) ;
@ -181,18 +183,13 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
Files : : PathContainer dataDirs ( Files : : EscapePath : : toPathContainer ( variables [ " data " ] . as < Files : : EscapePathContainer > ( ) ) ) ;
Files : : PathContainer dataDirs ( Files : : EscapePath : : toPathContainer ( variables [ " data " ] . as < Files : : EscapePathContainer > ( ) ) ) ;
std: : string local ( variables [ " data-local " ] . as < Files : : Escape HashString> ( ) . toStdString ( ) ) ;
Files: : PathContainer : : value_type local ( variables [ " data-local " ] . as < Files : : Escape Path> ( ) . mPath ) ;
if ( ! local . empty ( ) )
if ( ! local . empty ( ) )
{
dataDirs . push_back ( local ) ;
if ( local . front ( ) = = ' \" ' )
local = local . substr ( 1 , local . length ( ) - 2 ) ;
dataDirs . push_back ( Files : : PathContainer : : value_type ( local ) ) ;
}
cfgMgr . processPaths ( dataDirs ) ;
cfgMgr . processPaths ( dataDirs ) ;
engine . setResourceDir ( variables [ " resources " ] . as < Files : : Escape HashString> ( ) . toStdString ( ) ) ;
engine . setResourceDir ( variables [ " resources " ] . as < Files : : EscapePath > ( ) . mPath ) ;
engine . setDataDirs ( dataDirs ) ;
engine . setDataDirs ( dataDirs ) ;
// fallback archives
// fallback archives
@ -230,7 +227,7 @@ bool parseOptions (int argc, char** argv, OMW::Engine& engine, Files::Configurat
engine . setWarningsMode ( variables [ " script-warn " ] . as < int > ( ) ) ;
engine . setWarningsMode ( variables [ " script-warn " ] . as < int > ( ) ) ;
engine . setScriptBlacklist ( variables [ " script-blacklist " ] . as < Files : : EscapeStringVector > ( ) . toStdStringVector ( ) ) ;
engine . setScriptBlacklist ( variables [ " script-blacklist " ] . as < Files : : EscapeStringVector > ( ) . toStdStringVector ( ) ) ;
engine . setScriptBlacklistUse ( variables [ " script-blacklist-use " ] . as < bool > ( ) ) ;
engine . setScriptBlacklistUse ( variables [ " script-blacklist-use " ] . as < bool > ( ) ) ;
engine . setSaveGameFile ( variables [ " load-savegame " ] . as < Files : : Escape HashString> ( ) . toStdS tring( ) ) ;
engine . setSaveGameFile ( variables [ " load-savegame " ] . as < Files : : Escape Path> ( ) . mPath . s tring( ) ) ;
// other settings
// other settings
Fallback : : Map : : init ( variables [ " fallback " ] . as < FallbackMap > ( ) . mMap ) ;
Fallback : : Map : : init ( variables [ " fallback " ] . as < FallbackMap > ( ) . mMap ) ;