easyParse(argc, argv);
try {
- init_package(to_utf8(from_local8bit(argv[0])),
+ init_package(os::utf8_argv(0),
cl_system_support, cl_user_support,
top_build_dir_is_one_level_up);
} catch (ExceptionMessage const & message) {
if (argv[argi][0] == '-') {
lyxerr << to_utf8(
bformat(_("Wrong command line option `%1$s'. Exiting."),
- from_utf8(argv[argi]))) << endl;
+ from_utf8(os::utf8_argv(argi)))) << endl;
return EXIT_FAILURE;
}
}
// Remaining arguments are assumed to be files to load.
for (int argi = argc - 1; argi >= 1; --argi)
- pimpl_->files_to_load_.push_back(to_utf8(from_local8bit(argv[argi])));
+ pimpl_->files_to_load_.push_back(os::utf8_argv(argi));
if (first_start) {
pimpl_->files_to_load_.push_back(
continue;
string const arg =
- (i + 1 < argc) ? to_utf8(from_local8bit(argv[i + 1])) : string();
+ (i + 1 < argc) ? os::utf8_argv(i + 1) : string();
string const arg2 =
- (i + 2 < argc) ? to_utf8(from_local8bit(argv[i + 2])) : string();
+ (i + 2 < argc) ? os::utf8_argv(i + 2) : string();
string batch;
int const remove = 1 + it->second(arg, arg2, batch);
/// Do some work just once.
void init(int argc, char * argv[]);
+/// Returns the i-th program argument in utf8 encoding.
+std::string utf8_argv(int i);
+
/// Returns the name of the NULL device (/dev/null, null).
std::string const & nulldev();
#include "support/os.h"
#include "support/FileName.h"
+#include "support/lassert.h"
#include "support/lstrings.h"
#include "support/debug.h"
namespace {
+int argc_ = 0;
+char ** argv_ = 0;
+
bool windows_style_tex_paths_ = false;
// In both is_posix_path() and is_windows_path() it is assumed that
} // namespace anon
-void init(int, char *[])
+void init(int argc, char * argv[])
{
+ argc_ = argc;
+ argv_ = argv;
+
// Make sure that the TEMP variable is set
// and sync the Windows environment.
setenv("TEMP", "/tmp", false);
}
+string utf8_argv(int i)
+{
+ LASSERT(i < argc_, /**/);
+ return to_utf8(from_local8bit(argv_[i]));
+}
+
+
string current_root()
{
return string("/");
#include "support/docstring.h"
#include "support/FileName.h"
#include "support/lstrings.h"
+#include "support/lassert.h"
#include <limits.h>
#include <stdlib.h>
namespace support {
namespace os {
-void init(int, char *[])
-{}
+namespace {
+
+int argc_ = 0;
+char ** argv_ = 0;
+
+} // namespace anon
+
+void init(int argc, char * argv[])
+{
+ argc_ = argc;
+ argv_ = argv;
+}
+
+
+string utf8_argv(int i)
+{
+ LASSERT(i < argc_, /**/);
+ return to_utf8(from_local8bit(argv_[i]));
+}
string current_root()
* \author Ruurd A. Reitsma
* \author Claus Hentschel
* \author Angus Leeming
+ * \author Enrico Forestieri
*
* Full author contact details are available in file CREDITS.
*
#define ASSOCF_INIT_IGNOREUNKNOWN 0
#endif
+extern "C" {
+extern void __wgetmainargs(int * argc, wchar_t *** argv, wchar_t *** envp,
+ int expand_wildcards, int * new_mode);
+}
+
using namespace std;
namespace lyx {
namespace {
+int argc_ = 0;
+wchar_t ** argv_ = 0;
+
bool windows_style_tex_paths_ = true;
string cygdrive = "/cygdrive";
} // namespace anon
-void init(int /* argc */, char * argv[])
+void init(int argc, char * argv[])
{
/* Note from Angus, 17 Jan 2005:
*
* lyx is invoked as a parameter of hidecmd.exe.
*/
+
+ // Get the wide program arguments array
+ wchar_t ** envp = 0;
+ int newmode = 0;
+ __wgetmainargs(&argc_, &argv_, &envp, -1, &newmode);
+ LASSERT(argc == argc_, /**/);
+
// If Cygwin is detected, query the cygdrive prefix.
// The cygdrive prefix is needed for translating windows style paths
// to posix style paths in LaTeX files when the Cygwin teTeX is used.
}
+string utf8_argv(int i)
+{
+ LASSERT(i < argc_, /**/);
+ return fromqstr(QString::fromWCharArray(argv_[i]));
+}
+
+
string current_root()
{
// _getdrive returns the current drive (1=A, 2=B, and so on).
static QString const get_short_path(QString const & long_path, file_access how)
{
- // CreateFileW and GetShortPathNameW needs the path in utf16 encoding.
+ // CreateFileW and GetShortPathNameW need the path in utf16 encoding.
if (how == CREATE) {
HANDLE h = CreateFileW((wchar_t *) long_path.utf16(),
GENERIC_WRITE, 0, NULL, CREATE_NEW,