¿Cuál es la definición 'principal' multiplataforma preferida usando boost::program_options?
-
21-08-2019 - |
Pregunta
Estoy intentando desarrollar una aplicación multiplataforma usando C++ con impulso.
Normalmente programo en un entorno *nix, donde siempre he definido 'principal' de la siguiente manera:
int main( const int argc, const char* argv[] )
{
...
}
Para esta aplicación, estoy comenzando en el entorno Windows, usando Visual Studio 2003.
Cuando intento usar boost::program_options con esta definición, obtengo errores de compilación de program_options::store:
po::options_description desc("Supported options");
desc.add_options()...;
po::variables_map vm;
po::store(po::parse_command_line(argc, argv, desc), vm);
Error:
main.cpp(46) : error C2665: 'boost::program_options::store' : none of the 2 overloads can convert parameter 1 from type 'boost::program_options::basic_parsed_options<charT>'
with
[
charT=const char
]
c:\boost_1_38_0\boost\program_options\variables_map.hpp(34): could be 'void boost::program_options::store(const boost::program_options::basic_parsed_options<charT> &,boost::program_options::variables_map &,bool)'
with
[
charT=char
]
c:\boost_1_38_0\boost\program_options\variables_map.hpp(43): or 'void boost::program_options::store(const boost::program_options::basic_parsed_options<wchar_t> &,boost::program_options::variables_map &)'
while trying to match the argument list '(boost::program_options::basic_parsed_options<charT>, boost::program_options::variables_map)'
with
[
charT=const char
]
Intenté forzar la función wchar_t definiendo main de la siguiente manera:
int main( const int argc, wchar_t* argv[]){
...
}
Luego se compila, pero obtengo errores de enlace:
main.obj : error LNK2019: unresolved external symbol "void __cdecl boost::program_options::store(class boost::program_options::basic_parsed_options<unsigned short> const &,class boost::program_options::variables_map &)" referenced in function _main
main.obj : error LNK2019: unresolved external symbol "public: __thiscall boost::program_options::basic_parsed_options<unsigned short>::basic_parsed_options<unsigned short>(class boost::program_options::basic_parsed_options<char> const &)" referenced in function "public: class boost::program_options::basic_parsed_options<unsigned short> __thiscall boost::program_options::basic_command_line_parser<unsigned short>::run(void)"
main.obj : error LNK2019: unresolved external symbol "class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > __cdecl boost::program_options::to_internal(class std::basic_string<unsigned short,struct std::char_traits<unsigned short>,class std::allocator<unsigned short> > const &)" referenced in function "class std::vector<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,class std::allocator<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > > > __cdecl boost::program_options::to_internal<class std::basic_string<unsigned short,struct std::char_traits<unsigned short>,class std::allocator<unsigned short> > >(class std::vector<class std::basic_string<unsigned short,struct std::char_traits<unsigned short>,class std::allocator<unsigned short> >,class std::allocator<class std::basic_string<unsigned short,struct std::char_traits<unsigned short>,class std::allocator<unsigned short> > > > const &)"
Finalmente, si recurro a la configuración de definición principal predeterminada de Visual Studio, compila y vincula:
int main( const int argc, _TCHAR* argv[]){
...
}
Entonces, eso es bueno para Windows, pero ¿funcionará cuando intente llevarlo a *nix?¿Esos sistemas suelen definir un tipo _TCHAR?No lo he encontrado personalmente.
¿Cuál es la forma correcta de definir main para que funcione en Windows y *nix, además de trabajar con la biblioteca boost::program_options?
Solución
Parece ser un problema relacionado constness. Proveedores:
int main( int argc, char* argv[] )
{
// ...
}
Otros consejos
int main()
y int main(int argc, char* argv[])
(también conocido como int main(int argc, char** argv)
) son las firmas aprobadas por los estándares C++.
VisualStudio intenta ser útil de muchas maneras locas, incluido intentar determinar si (1) desea un main()
o un WinMain()
y (2) decidir si quieres char
s o wchar_t
s.Si VisualStudio no cree que esté trabajando en una aplicación de consola, es posible que deba llamar a split_winmain().
Si quieres forzar char
s (que recomendaría) es posible que necesites #undef UNICODE
.