/*****************************************************************************\ * * * Name : version_stamper * * Author : Chris Koeritz * * * ******************************************************************************* * Copyright (c) 1995-$now By Author. 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 2 of * * the License or (at your option) any later version. This is online at: * * http://www.fsf.org/copyleft/gpl.html * * Please send any updates to: fred@gruntose.com * \*****************************************************************************/ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #undef LOG #define LOG(to_print) CLASS_EMERGENCY_LOG(program_wide_logger(), to_print) using namespace application; using namespace basis; using namespace filesystem; using namespace loggers; using namespace structures; using namespace versions; //! This class creates resource information for applications and libraries to be version stamped. /*! This creates a resource (.rc) file and a C++ header (.h) file when given the directory where a version information file (version.ini) resides. It creates the files in that directory. */ class version_stamper : public application_shell { public: version_stamper(); ~version_stamper(); DEFINE_CLASS_NAME("version_stamper"); int execute(); // performs the main action of creating resource and code files. }; ////////////// version_stamper::version_stamper() : application_shell() { } version_stamper::~version_stamper() {} int version_stamper::execute() { FUNCDEF("execute"); SETUP_CONSOLE_LOGGER; // override the file_logger from app_shell. if (application::_global_argc < 3) { log(astring( "The directory where the 'version.ini' file is located must be specified as the\n" "first parameter of this program. The second parameter must provide the\n" "storage location where the version header will be written. Another version\n" "file may optionally be specified as the third parameter of the program; the\n" "version contained in this file will be used to set the version of the file\n" "specified in the first parameter.\n" "Additionally, if the environment variable 'DEBUG' exists, then the\n" "generated RC file will be marked as a debug build. Otherwise it is\n" "marked as a release build. Note that the CLAM system automatically\n" "sets this for you.\n\n"), ALWAYS_PRINT); return 1; } astring path_name = application::_global_argv[1]; astring storage_name = application::_global_argv[2]; astring source_version_file; // blank by default. if (application::_global_argc > 3) source_version_file = application::_global_argv[3]; bool ret = version_ini::one_stop_version_stamp(path_name, storage_name, source_version_file, true); if (!ret) return 1; // failure. return 0; // success. } HOOPLE_MAIN(version_stamper, ) #ifdef __BUILD_STATIC_APPLICATION__ // static dependencies found by buildor_gen_deps.sh: #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #endif // __BUILD_STATIC_APPLICATION__