2006-01-04 14:20:05 +00:00
|
|
|
// -*- C++ -*-
|
2005-06-06 12:59:57 +00:00
|
|
|
/*
|
2005-06-15 11:49:24 +00:00
|
|
|
* \file lyx_configure.C
|
2005-06-06 12:59:57 +00:00
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* http://www.lyx.org/
|
|
|
|
* Licence details can be found in the file COPYING or copy at
|
2006-01-04 14:20:05 +00:00
|
|
|
* http://www.lyx.org/about/license.php
|
|
|
|
*
|
2005-06-06 12:59:57 +00:00
|
|
|
* \author Angus Leeming
|
|
|
|
* Full author contact details are available in file CREDITS or copy at
|
|
|
|
* http://www.lyx.org/about/credits.php
|
|
|
|
*
|
2005-06-18 20:30:37 +00:00
|
|
|
* Define four functions that can be called from the NSIS installer:
|
2005-06-06 12:59:57 +00:00
|
|
|
*
|
2005-06-18 20:30:37 +00:00
|
|
|
* set_path_prefix [ configure_file, path_prefix ]
|
|
|
|
* create_bat_files [ bin_dir, lang ]
|
|
|
|
* run_configure [ configure_file, path_prefix ]
|
|
|
|
* set_env [ var_name, var_value ]
|
|
|
|
*
|
2006-01-04 14:20:05 +00:00
|
|
|
* The quantities in [ ... ] are the variables that the functions expect
|
2005-06-18 20:30:37 +00:00
|
|
|
* to find on the stack. They push "-1" onto the stack on failure and "0"
|
|
|
|
* onto the stack on success.
|
2005-06-06 12:59:57 +00:00
|
|
|
*
|
|
|
|
* Compile the code with
|
|
|
|
*
|
|
|
|
* g++ -I/c/Program\ Files/NSIS/Contrib -Wall -shared \
|
2005-06-15 11:49:24 +00:00
|
|
|
* lyx_configure.C -o lyx_configure.dll
|
2005-06-06 12:59:57 +00:00
|
|
|
*
|
2006-01-06 22:37:25 +00:00
|
|
|
* Compilation requires the exdll.h header file to be installed (here at
|
|
|
|
* C:\Program Files\NSIS\Contrib\ExDLL\exdll.h). The file can be obtained
|
|
|
|
* from http://cvs.sourceforge.net/viewcvs.py/nsis/NSIS/Contrib/ExDLL/
|
|
|
|
*
|
|
|
|
* Move the resulting lyx_configure.dll to /c/Program\ Files/NSIS/Plugins
|
2005-06-06 12:59:57 +00:00
|
|
|
*/
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
#include <cstdio>
|
|
|
|
#include <cstdlib>
|
2005-06-06 12:59:57 +00:00
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
2005-06-08 13:14:50 +00:00
|
|
|
#include <list>
|
|
|
|
#include <sstream>
|
2005-06-06 12:59:57 +00:00
|
|
|
#include <string>
|
2006-01-04 14:20:05 +00:00
|
|
|
#include <vector>
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
#include <windows.h>
|
|
|
|
#include "ExDLL/exdll.h"
|
|
|
|
|
|
|
|
|
2005-06-06 12:59:57 +00:00
|
|
|
namespace {
|
|
|
|
|
|
|
|
std::string const subst(std::string const & a,
|
|
|
|
std::string const & oldstr,
|
|
|
|
std::string const & newstr)
|
|
|
|
{
|
|
|
|
std::string lstr = a;
|
|
|
|
std::string::size_type i = 0;
|
|
|
|
std::string::size_type const olen = oldstr.length();
|
|
|
|
while ((i = lstr.find(oldstr, i)) != std::string::npos) {
|
|
|
|
lstr.replace(i, olen, newstr);
|
2005-06-08 13:14:50 +00:00
|
|
|
i += newstr.length();
|
2005-06-06 12:59:57 +00:00
|
|
|
}
|
|
|
|
return lstr;
|
|
|
|
}
|
|
|
|
|
2005-06-08 13:14:50 +00:00
|
|
|
|
|
|
|
std::string const basename(std::string const & path)
|
|
|
|
{
|
2006-01-04 14:20:05 +00:00
|
|
|
// Windows recognizes both '/' and '\' as directory separators.
|
|
|
|
std::string::size_type const final_slash = path.find_last_of("/\\");
|
2005-06-18 20:30:37 +00:00
|
|
|
return (final_slash == std::string::npos) ?
|
|
|
|
path :
|
|
|
|
path.substr(final_slash+1);
|
2005-06-08 13:14:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string const dirname(std::string const & path)
|
|
|
|
{
|
2006-01-04 14:20:05 +00:00
|
|
|
// Windows recognizes both '/' and '\' as directory separators.
|
|
|
|
std::string::size_type const final_slash = path.find_last_of("/\\");
|
2005-06-18 20:30:37 +00:00
|
|
|
return (final_slash == std::string::npos) ?
|
|
|
|
std::string() :
|
|
|
|
path.substr(0, final_slash);
|
2005-06-08 13:14:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string const pop_from_stack()
|
|
|
|
{
|
|
|
|
char data[10*MAX_PATH];
|
2006-01-04 14:20:05 +00:00
|
|
|
return (popstring(data) == 0) ? data : std::string();
|
2005-06-08 13:14:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
void push_to_stack(int const data)
|
2005-06-18 20:30:37 +00:00
|
|
|
{
|
|
|
|
std::ostringstream os;
|
|
|
|
os << data;
|
|
|
|
pushstring(os.str().c_str());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
std::list<std::string> const tokenize(std::string const & data,
|
2005-06-08 13:14:50 +00:00
|
|
|
char const separator)
|
|
|
|
{
|
|
|
|
std::list<std::string> result;
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string::size_type index = 0;
|
2005-06-08 13:14:50 +00:00
|
|
|
while (true) {
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string::size_type const end = data.find(separator, index);
|
2005-06-08 13:14:50 +00:00
|
|
|
if (end == std::string::npos) {
|
|
|
|
result.push_back(data);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
result.push_back(data.substr(0, end));
|
2006-01-04 14:20:05 +00:00
|
|
|
index = (end+1 == data.size()) ? std::string::npos : end + 1;
|
2005-06-08 13:14:50 +00:00
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void remove_duplicates(std::list<std::string> & data)
|
|
|
|
{
|
|
|
|
typedef std::list<std::string>::iterator iterator;
|
|
|
|
for (iterator it = data.begin(); it != data.end(); ++it) {
|
|
|
|
iterator next = it;
|
|
|
|
++next;
|
|
|
|
if (next == data.end())
|
|
|
|
break;
|
|
|
|
iterator end = std::remove(next, data.end(), *it);
|
|
|
|
data.erase(end, data.end());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string concatenate(std::list<std::string> const & data,
|
|
|
|
char const separator)
|
|
|
|
{
|
|
|
|
typedef std::list<std::string>::const_iterator iterator;
|
|
|
|
iterator it = data.begin();
|
|
|
|
iterator const end = data.end();
|
|
|
|
if (it == end)
|
|
|
|
return std::string();
|
|
|
|
|
|
|
|
std::ostringstream result;
|
|
|
|
result << *it;
|
|
|
|
++it;
|
|
|
|
for (; it != end; ++it) {
|
|
|
|
result << separator << *it;
|
|
|
|
}
|
|
|
|
return result.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string const sanitize_win32_path(std::string const & in)
|
2005-06-08 13:14:50 +00:00
|
|
|
{
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string out = subst(in, "/", "\\");
|
|
|
|
// Replace multiple adjacent directory separators with a single one
|
|
|
|
typedef std::string::size_type size_type;
|
|
|
|
size_type offset = 0;
|
|
|
|
while (offset != std::string::npos) {
|
|
|
|
size_type const slash = out.find_first_of('\\', offset);
|
|
|
|
if (slash == std::string::npos)
|
|
|
|
break;
|
|
|
|
size_type const slash_end = out.find_first_not_of('\\', slash);
|
|
|
|
|
|
|
|
if (slash_end == std::string::npos) {
|
|
|
|
// Remove all trailing '\' characters
|
|
|
|
out = out.substr(0, slash);
|
|
|
|
break;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
size_type const count = slash_end - (slash + 1);
|
|
|
|
if (count > 0)
|
|
|
|
out.erase(slash + 1, count);
|
|
|
|
}
|
|
|
|
offset = slash + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string const sanitize_path_envvar(std::string const & in)
|
|
|
|
{
|
|
|
|
// A Windows PATH environment variable has elements separated
|
|
|
|
// by a ';' character.
|
|
|
|
typedef std::list<std::string> string_list;
|
|
|
|
string_list envvar = tokenize(in, ';');
|
|
|
|
|
|
|
|
// Ensure that each PATH element uses '\' directory separators
|
|
|
|
// and doesn't end in a '\'.
|
|
|
|
string_list::iterator const end = envvar.end();
|
|
|
|
for (string_list::iterator it = envvar.begin(); it != end; ++it)
|
|
|
|
*it = sanitize_win32_path(*it);
|
|
|
|
|
|
|
|
remove_duplicates(envvar);
|
|
|
|
return concatenate(envvar, ';');
|
2005-06-08 13:14:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool replace_path_prefix(std::string & data,
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string::size_type const prefix_pos,
|
2005-06-08 13:14:50 +00:00
|
|
|
std::string const & path_prefix)
|
|
|
|
{
|
|
|
|
std::string::size_type start_prefix =
|
|
|
|
data.find_first_of('"', prefix_pos);
|
|
|
|
if (start_prefix == std::string::npos)
|
|
|
|
return false;
|
|
|
|
start_prefix += 1;
|
|
|
|
|
|
|
|
std::string::size_type end_line =
|
|
|
|
data.find_first_of('\n', prefix_pos);
|
|
|
|
if (end_line == std::string::npos)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
std::string::size_type end_prefix =
|
|
|
|
data.find_last_of('"', end_line);
|
|
|
|
if (end_prefix == std::string::npos || end_prefix == start_prefix)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
std::string::size_type const count = end_prefix - start_prefix;
|
|
|
|
std::string const old_prefix = data.substr(start_prefix, count);
|
2006-01-04 14:20:05 +00:00
|
|
|
// The configure script needs to see '\\' for each '\' directory
|
|
|
|
// separator.
|
2005-06-08 13:14:50 +00:00
|
|
|
std::string const prefix =
|
2006-01-04 14:20:05 +00:00
|
|
|
subst(sanitize_path_envvar(path_prefix + ';' + old_prefix),
|
|
|
|
"\\", "\\\\");
|
2005-06-08 13:14:50 +00:00
|
|
|
|
|
|
|
data.erase(start_prefix, count);
|
|
|
|
data.insert(start_prefix, prefix);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool insert_path_prefix(std::string & data,
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string::size_type const xfonts_pos,
|
2005-06-08 13:14:50 +00:00
|
|
|
std::string const & path_prefix)
|
|
|
|
{
|
|
|
|
std::string::size_type const xfonts_start =
|
|
|
|
data.find_last_of('\n', xfonts_pos);
|
|
|
|
|
|
|
|
if (xfonts_start == std::string::npos)
|
|
|
|
return false;
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
// The configure script needs to see '\\' for each '\' directory
|
|
|
|
// separator.
|
|
|
|
std::string const prefix =
|
|
|
|
subst(sanitize_path_envvar(path_prefix), "\\", "\\\\");
|
|
|
|
|
2005-06-08 13:14:50 +00:00
|
|
|
std::ostringstream ss;
|
|
|
|
ss << data.substr(0, xfonts_start)
|
|
|
|
<< "\n"
|
|
|
|
"cat >>$outfile <<EOF\n"
|
|
|
|
"\n"
|
|
|
|
"\\\\path_prefix \"" << prefix << "\"\n"
|
|
|
|
"EOF\n"
|
|
|
|
<< data.substr(xfonts_start);
|
|
|
|
data = ss.str();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-08 13:14:50 +00:00
|
|
|
// Inserts code into "configure" to output "path_prefix" to lyxrc.defaults.
|
2005-06-18 20:30:37 +00:00
|
|
|
// \returns 0 on success, -1 on failure
|
|
|
|
int set_path_prefix(std::string const & configure_file,
|
|
|
|
std::string const & path_prefix)
|
2005-06-06 12:59:57 +00:00
|
|
|
{
|
2005-06-08 13:14:50 +00:00
|
|
|
std::ifstream ifs(configure_file.c_str());
|
2005-06-18 20:30:37 +00:00
|
|
|
if (!ifs)
|
|
|
|
return -1;
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-08 13:14:50 +00:00
|
|
|
std::istreambuf_iterator<char> const begin_ifs(ifs);
|
|
|
|
std::istreambuf_iterator<char> const end_ifs;
|
|
|
|
std::string configure_data(begin_ifs, end_ifs);
|
|
|
|
ifs.close();
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-08 13:14:50 +00:00
|
|
|
// Does configure already contain a "path_prefix" entry
|
|
|
|
// or should we insert one?
|
|
|
|
std::string::size_type const prefix_pos =
|
|
|
|
configure_data.find("path_prefix");
|
|
|
|
if (prefix_pos != std::string::npos) {
|
2005-06-18 20:30:37 +00:00
|
|
|
if (!replace_path_prefix(configure_data, prefix_pos, path_prefix))
|
|
|
|
return -1;
|
2005-06-08 13:14:50 +00:00
|
|
|
} else {
|
|
|
|
std::string::size_type const xfonts_pos =
|
|
|
|
configure_data.find("X FONTS");
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
if (xfonts_pos == std::string::npos)
|
|
|
|
return -1;
|
2005-06-08 13:14:50 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
if (!insert_path_prefix(configure_data, xfonts_pos, path_prefix))
|
|
|
|
return -1;
|
2005-06-06 12:59:57 +00:00
|
|
|
}
|
|
|
|
|
2005-06-08 13:14:50 +00:00
|
|
|
std::ofstream ofs(configure_file.c_str());
|
2005-06-18 20:30:37 +00:00
|
|
|
if (!ofs)
|
|
|
|
return -1;
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-08 13:14:50 +00:00
|
|
|
ofs << configure_data;
|
2005-06-18 20:30:37 +00:00
|
|
|
return 0;
|
2005-06-08 13:14:50 +00:00
|
|
|
}
|
|
|
|
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
bool write_bat(std::ostream & os, std::string const & quoted_exe)
|
2005-06-15 11:49:24 +00:00
|
|
|
{
|
2005-06-29 23:42:33 +00:00
|
|
|
os << "if \"%~1\" == \"~1\" goto win95\n"
|
|
|
|
<< quoted_exe << " %*\n"
|
2005-06-18 20:30:37 +00:00
|
|
|
<< "goto end\n"
|
|
|
|
<< ":win95\n"
|
|
|
|
<< quoted_exe << " %1 %2 %3 %4 %5 %6 %7 %8 %9\n"
|
|
|
|
<< ":end\n";
|
|
|
|
|
|
|
|
return os;
|
|
|
|
}
|
2005-06-15 11:49:24 +00:00
|
|
|
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
// Creates the files lyx.bat and reLyX.bat in the LyX\bin folder.
|
|
|
|
// \returns 0 on success, -1 on failure
|
|
|
|
int create_bat_files(std::string const & bin_dir, std::string const & lang)
|
|
|
|
{
|
2005-06-15 11:49:24 +00:00
|
|
|
std::string const lyx_bat_file = bin_dir + "\\lyx.bat";
|
|
|
|
std::ofstream lyx_bat(lyx_bat_file.c_str());
|
2005-06-18 20:30:37 +00:00
|
|
|
if (!lyx_bat)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
lyx_bat << "@echo off\n"
|
|
|
|
<< "if \"%LANG%\"==\"\" SET LANG=" << lang << "\n";
|
|
|
|
|
2005-06-15 11:49:24 +00:00
|
|
|
std::string const lyx_exe_file = bin_dir + "\\lyx.exe";
|
2005-06-30 09:33:43 +00:00
|
|
|
if (!write_bat(lyx_bat, "start \"LyX\" \"" + lyx_exe_file + "\""))
|
2005-06-18 20:30:37 +00:00
|
|
|
return -1;
|
2005-06-15 11:49:24 +00:00
|
|
|
|
|
|
|
std::string const relyx_bat_file = bin_dir + "\\reLyX.bat";
|
|
|
|
std::ofstream relyx_bat(relyx_bat_file.c_str());
|
2005-06-18 20:30:37 +00:00
|
|
|
if (!relyx_bat)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
std::string relyx_file = bin_dir + "\\reLyX";
|
|
|
|
std::string relyx = "perl.exe \"" + relyx_file + "\"";
|
|
|
|
if (!write_bat(relyx_bat, "perl.exe \"" + relyx_file + "\""))
|
|
|
|
return -1;
|
|
|
|
return 0;
|
|
|
|
}
|
2005-06-15 11:49:24 +00:00
|
|
|
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
// A wrapper for GetEnvironmentVariable
|
|
|
|
bool get_environment_variable(std::string const & var, std::string & val)
|
|
|
|
{
|
|
|
|
if (var.empty())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
std::vector<char> cval(MAX_PATH, '\0');
|
|
|
|
DWORD size = GetEnvironmentVariable(var.c_str(),
|
|
|
|
&*cval.begin(),
|
|
|
|
cval.size());
|
|
|
|
|
|
|
|
if (size == 0)
|
|
|
|
// The specified variable was not found.
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (size > cval.size()) {
|
|
|
|
// Insufficient size in the buffer to store the var
|
|
|
|
// so resize to the required size.
|
|
|
|
cval.resize(size, '\0');
|
|
|
|
size = GetEnvironmentVariable(var.c_str(),
|
|
|
|
&*cval.begin(),
|
|
|
|
cval.size());
|
|
|
|
if (size == 0 || size > cval.size())
|
|
|
|
// Give up
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
val.assign(cval.begin(), cval.begin() + size);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
// Runs "sh configure" to generate things like lyxrc.defaults.
|
|
|
|
// \returns 0 on success, -1 on failure
|
2006-01-04 14:20:05 +00:00
|
|
|
int run_configure(std::string const & abs_configure_file_in,
|
2005-06-18 20:30:37 +00:00
|
|
|
std::string const & path_prefix)
|
|
|
|
{
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string const abs_configure_file =
|
|
|
|
sanitize_win32_path(abs_configure_file_in);
|
2005-06-18 20:30:37 +00:00
|
|
|
std::string const configure_dir = dirname(abs_configure_file);
|
|
|
|
std::string const configure_file = basename(abs_configure_file);
|
2005-06-15 11:49:24 +00:00
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
if (configure_file.empty() || configure_dir.empty())
|
2005-06-18 20:30:37 +00:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (SetCurrentDirectory(configure_dir.c_str()) == 0)
|
|
|
|
return -1;
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
std::string path;
|
|
|
|
if (!get_environment_variable("PATH", path))
|
2005-06-18 20:30:37 +00:00
|
|
|
return -1;
|
2006-01-04 14:20:05 +00:00
|
|
|
path = sanitize_path_envvar(path_prefix + ';' + path);
|
2005-06-18 20:30:37 +00:00
|
|
|
if (SetEnvironmentVariable("PATH", path.c_str()) == 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
// Even "start /WAIT /B sh.exe configure" returns
|
|
|
|
// before the script is done, so just invoke "sh" directly.
|
2006-01-04 14:20:05 +00:00
|
|
|
|
|
|
|
// Assumes that configure_file does not need quoting.
|
2005-06-18 20:30:37 +00:00
|
|
|
std::string const command = std::string("sh.exe ") + configure_file;
|
|
|
|
if (system(command.c_str()) != 0)
|
|
|
|
return -1;
|
|
|
|
return 0;
|
2005-06-15 11:49:24 +00:00
|
|
|
}
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
} // namespace anon
|
2005-06-15 11:49:24 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
|
|
|
|
//===========================================//
|
|
|
|
// //
|
|
|
|
// Below is the public interface to the .dll //
|
|
|
|
// //
|
|
|
|
//===========================================//
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
BOOL WINAPI DllMain(HANDLE /*hInst*/,
|
|
|
|
ULONG /*ul_reason_for_call*/,
|
|
|
|
LPVOID /*lpReserved*/)
|
2005-06-18 20:30:37 +00:00
|
|
|
{
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Inserts code into "configure" to output "path_prefix" to lyxrc.defaults.
|
2005-06-08 13:14:50 +00:00
|
|
|
extern "C"
|
2006-01-04 14:20:05 +00:00
|
|
|
void __declspec(dllexport) set_path_prefix(HWND const /*hwndParent*/,
|
|
|
|
int const string_size,
|
|
|
|
char * const variables,
|
|
|
|
stack_t ** const stacktop)
|
2005-06-08 13:14:50 +00:00
|
|
|
{
|
|
|
|
EXDLL_INIT();
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
std::string const configure_file = pop_from_stack();
|
2005-06-08 13:14:50 +00:00
|
|
|
std::string const path_prefix = pop_from_stack();
|
2006-01-04 14:20:05 +00:00
|
|
|
if (configure_file.empty() || path_prefix.empty()) {
|
|
|
|
push_to_stack(-1);
|
|
|
|
return;
|
|
|
|
}
|
2005-06-08 13:14:50 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
int const result = set_path_prefix(configure_file, path_prefix);
|
|
|
|
push_to_stack(result);
|
|
|
|
}
|
2005-06-08 13:14:50 +00:00
|
|
|
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
// Creates the files lyx.bat and reLyX.bat in the LyX\bin folder.
|
|
|
|
extern "C"
|
2006-01-04 14:20:05 +00:00
|
|
|
void __declspec(dllexport) create_bat_files(HWND const /*hwndParent*/,
|
|
|
|
int const string_size,
|
|
|
|
char * const variables,
|
|
|
|
stack_t ** const stacktop)
|
2005-06-18 20:30:37 +00:00
|
|
|
{
|
|
|
|
EXDLL_INIT();
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
std::string const bin_dir = pop_from_stack();
|
|
|
|
std::string const lang = pop_from_stack();
|
2006-01-04 14:20:05 +00:00
|
|
|
if (bin_dir.empty() || lang.empty()) {
|
|
|
|
push_to_stack(-1);
|
|
|
|
return;
|
|
|
|
}
|
2005-06-06 12:59:57 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
int const result = create_bat_files(bin_dir, lang);
|
|
|
|
push_to_stack(result);
|
|
|
|
}
|
2005-06-06 12:59:57 +00:00
|
|
|
|
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
// Runs "sh configure" to generate things like lyxrc.defaults.
|
|
|
|
extern "C"
|
2006-01-04 14:20:05 +00:00
|
|
|
void __declspec(dllexport) run_configure(HWND const /*hwndParent*/,
|
|
|
|
int const string_size,
|
|
|
|
char * const variables,
|
|
|
|
stack_t ** const stacktop)
|
2005-06-18 20:30:37 +00:00
|
|
|
{
|
|
|
|
EXDLL_INIT();
|
|
|
|
|
|
|
|
std::string const configure_file = pop_from_stack();
|
|
|
|
std::string const path_prefix = pop_from_stack();
|
2006-01-04 14:20:05 +00:00
|
|
|
if (configure_file.empty() || path_prefix.empty()) {
|
|
|
|
push_to_stack(-1);
|
|
|
|
return;
|
|
|
|
}
|
2005-06-18 20:30:37 +00:00
|
|
|
|
|
|
|
int const result = run_configure(configure_file, path_prefix);
|
|
|
|
push_to_stack(result);
|
2005-06-06 12:59:57 +00:00
|
|
|
}
|
2005-06-15 11:49:24 +00:00
|
|
|
|
|
|
|
|
2006-01-04 14:20:05 +00:00
|
|
|
// Set an environment variable.
|
2005-06-15 11:49:24 +00:00
|
|
|
extern "C"
|
2006-01-04 14:20:05 +00:00
|
|
|
void __declspec(dllexport) set_env(HWND const /*hwndParent*/,
|
|
|
|
int const string_size,
|
|
|
|
char * const variables,
|
|
|
|
stack_t ** const stacktop)
|
2005-06-15 11:49:24 +00:00
|
|
|
{
|
|
|
|
EXDLL_INIT();
|
|
|
|
|
|
|
|
std::string const var_name = pop_from_stack();
|
|
|
|
std::string const var_value = pop_from_stack();
|
2006-01-04 14:20:05 +00:00
|
|
|
if (var_name.empty() || var_value.empty()) {
|
|
|
|
push_to_stack(-1);
|
|
|
|
return;
|
|
|
|
}
|
2005-06-15 11:49:24 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
// Function returns a nonzero value on success.
|
|
|
|
int const result =
|
|
|
|
SetEnvironmentVariableA(var_name.c_str(), var_value.c_str()) ?
|
|
|
|
0 : -1;
|
2005-06-15 11:49:24 +00:00
|
|
|
|
2005-06-18 20:30:37 +00:00
|
|
|
push_to_stack(result);
|
2005-06-15 11:49:24 +00:00
|
|
|
}
|