#include "language.h"
#include "session.h"
#include "LColor.h"
+#include "lyx_cb.h"
#include "lyxfunc.h"
#include "lyxlex.h"
#include "lyxrc.h"
#include "support/environment.h"
#include "support/filetools.h"
#include "support/lyxlib.h"
+#include "support/convert.h"
#include "support/os.h"
#include "support/package.h"
#include "support/path.h"
+#include "support/systemcall.h"
#include <boost/bind.hpp>
#include <boost/filesystem/operations.hpp>
using lyx::support::prependEnvPath;
using lyx::support::quoteName;
using lyx::support::rtrim;
+using lyx::support::Systemcall;
namespace os = lyx::support::os;
namespace fs = boost::filesystem;
#endif
-extern void QuitLyX(bool);
-
extern LyXServer * lyxserver;
// This is the global bufferlist object
string cl_user_support;
+void lyx_exit(int status)
+{
+ // FIXME: We should not directly call exit(), since it only
+ // guarantees a return to the system, no application cleanup.
+ // This may cause troubles with not executed destructors.
+ if (lyx_gui::use_gui)
+ // lyx_gui::exit may return and only schedule the exit
+ lyx_gui::exit(status);
+ exit(status);
+}
+
+
void showFileError(string const & error)
{
Alert::warning(_("Could not read configuration file"),
bformat(_("Error while reading the configuration file\n%1$s.\n"
"Please check your installation."), error));
- exit(EXIT_FAILURE);
}
void reconfigureUserLyXDir()
{
- string const configure_script =
- addName(package().system_support(), "configure.py");
- string const configure_command =
- "python " + quoteName(configure_script);
+ string const configure_command = package().configure_command();
lyxerr << _("LyX: reconfiguring user directory") << endl;
Path p(package().user_support());
- ::system(configure_command.c_str());
+ Systemcall one;
+ one.startscript(Systemcall::Wait, configure_command);
lyxerr << "LyX: " << _("Done!") << endl;
}
boost::scoped_ptr<LyX> LyX::singleton_;
-void LyX::exec(int & argc, char * argv[])
+int LyX::exec(int & argc, char * argv[])
{
BOOST_ASSERT(!singleton_.get());
// We must return from this before launching the gui so that
// LyX::ref and LyX::cref.
singleton_.reset(new LyX);
// Start the real execution loop.
- singleton_->priv_exec(argc, argv);
+ return singleton_->priv_exec(argc, argv);
}
LyX::LyX()
- : first_start(false)
+ : first_start(false), geometryOption_(false)
{}
}
-void LyX::addLyXView(boost::shared_ptr<LyXView> const & lyxview)
+void LyX::addLyXView(LyXView * lyxview)
{
views_.push_back(lyxview);
}
}
-void LyX::priv_exec(int & argc, char * argv[])
+int LyX::priv_exec(int & argc, char * argv[])
{
// Here we need to parse the command line. At least
// we need to parse for "-dbg" and "-help"
- bool const want_gui = easyParse(argc, argv);
+ lyx_gui::use_gui = easyParse(argc, argv);
lyx::support::init_package(argv[0], cl_system_support, cl_user_support,
lyx::support::top_build_dir_is_one_level_up);
- if (want_gui)
- lyx_gui::parse_init(argc, argv);
+ // Start the real execution loop.
+ if (lyx_gui::use_gui)
+ return lyx_gui::exec(argc, argv);
+ else
+ return exec2(argc, argv);
+}
+
+int LyX::exec2(int & argc, char * argv[])
+{
// check for any spurious extra arguments
// other than documents
for (int argi = 1; argi < argc ; ++argi) {
if (argv[argi][0] == '-') {
lyxerr << bformat(_("Wrong command line option `%1$s'. Exiting."),
argv[argi]) << endl;
- exit(1);
+ return EXIT_FAILURE;
}
}
// Initialization of LyX (reads lyxrc and more)
lyxerr[Debug::INIT] << "Initializing LyX::init..." << endl;
- init(want_gui);
+ bool const success = init();
lyxerr[Debug::INIT] << "Initializing LyX::init...done" << endl;
+ if (!success)
+ return EXIT_FAILURE;
- if (want_gui)
+ if (lyx_gui::use_gui)
lyx_gui::parse_lyxrc();
vector<string> files;
if (first_start)
files.push_back(i18nLibFileSearch("examples", "splash.lyx"));
- // if a file is specified, I assume that user wants to edit *that* file
- if (files.empty() && lyxrc.load_session) {
- vector<string> const & lastopened = session_->lastOpenedFiles();
- files.insert(files.end(), lastopened.begin(), lastopened.end() );
- // clear this list to save a few bytes of RAM
- session_->clearLastOpenedFiles();
- }
-
// Execute batch commands if available
if (!batch_command.empty()) {
// the filename if necessary
string s = fileSearch(string(), *it, "lyx");
if (s.empty()) {
- last_loaded = newFile(*it, string(), true);
+ Buffer * const b = newFile(*it, string(), true);
+ if (b)
+ last_loaded = b;
} else {
Buffer * buf = bufferlist.newBuffer(s, false);
- buf->error.connect(boost::bind(&LyX::printError, this, _1));
- if (loadLyXFile(buf, s))
+ if (loadLyXFile(buf, s)) {
last_loaded = buf;
+ ErrorList const & el = buf->errorList("Parse");
+ if (!el.empty())
+ for_each(el.begin(), el.end(),
+ boost::bind(&LyX::printError, this, _1));
+ }
else
bufferlist.release(buf);
}
if (last_loaded) {
bool success = false;
if (last_loaded->dispatch(batch_command, &success)) {
- QuitLyX(false);
- exit(!success);
+ quitLyX(false);
+ return !success;
}
}
files.clear(); // the files are already loaded
}
- if (want_gui)
- lyx_gui::start(batch_command, files);
- else {
+ if (lyx_gui::use_gui) {
+ // determine windows size and position, from lyxrc and/or session
+ // initial geometry
+ unsigned int width = 690;
+ unsigned int height = 510;
+ bool maximize = false;
+ // first try lyxrc
+ if (lyxrc.geometry_width != 0 && lyxrc.geometry_height != 0 ) {
+ width = lyxrc.geometry_width;
+ height = lyxrc.geometry_height;
+ }
+ // if lyxrc returns (0,0), then use session info
+ else {
+ string val = session().loadSessionInfo("WindowWidth");
+ if (!val.empty())
+ width = convert<unsigned int>(val);
+ val = session().loadSessionInfo("WindowHeight");
+ if (!val.empty())
+ height = convert<unsigned int>(val);
+ if (session().loadSessionInfo("WindowIsMaximized") == "yes")
+ maximize = true;
+ }
+ // if user wants to restore window position
+ int posx = -1;
+ int posy = -1;
+ if (lyxrc.geometry_xysaved) {
+ string val = session().loadSessionInfo("WindowPosX");
+ if (!val.empty())
+ posx = convert<int>(val);
+ val = session().loadSessionInfo("WindowPosY");
+ if (!val.empty())
+ posy = convert<int>(val);
+ }
+
+ if (geometryOption_) {
+ width = 0;
+ height = 0;
+ }
+ // create the main window
+ LyXView * view = lyx_gui::create_view(width, height, posx, posy, maximize);
+
+ // load files
+ for_each(files.begin(), files.end(),
+ bind(&LyXView::loadLyXFile, view, _1, true));
+
+ // if a file is specified, I assume that user wants to edit *that* file
+ if (files.empty() && lyxrc.load_session) {
+ vector<string> const & lastopened = session_->lastOpenedFiles();
+ // do not add to the lastfile list since these files are restored from
+ // last seesion, and should be already there (regular files), or should
+ // not be added at all (help files).
+ for_each(lastopened.begin(), lastopened.end(),
+ bind(&LyXView::loadLyXFile, view, _1, false));
+ }
+ // clear this list to save a few bytes of RAM
+ session_->clearLastOpenedFiles();
+
+ return lyx_gui::start(view, batch_command);
+ } else {
// Something went wrong above
- QuitLyX(false);
- exit(EXIT_FAILURE);
+ quitLyX(false);
+ return EXIT_FAILURE;
}
}
}
-void LyX::init(bool gui)
+bool LyX::init()
{
#ifdef SIGHUP
signal(SIGHUP, error_handler);
signal(SIGTERM, error_handler);
// SIGPIPE can be safely ignored.
- // Check that user LyX directory is ok. We don't do that if
- // running in batch mode.
- bool reconfigure = false;
- if (gui) {
- reconfigure =
- queryUserLyXDir(package().explicit_user_support());
- } else {
- first_start = false;
- }
-
- // Disable gui when easyparse says so
- lyx_gui::use_gui = gui;
-
lyxrc.tempdir_path = package().temp_dir();
lyxrc.document_path = package().document_dir();
// Read configuration files
//
- readRcFile("lyxrc.defaults");
+ // This one may have been distributed along with LyX.
+ if (!readRcFile("lyxrc.dist"))
+ return false;
+
+ // Set the PATH correctly.
+#if !defined (USE_POSIX_PACKAGING)
+ // Add the directory containing the LyX executable to the path
+ // so that LyX can find things like tex2lyx.
+ if (package().build_support().empty())
+ prependEnvPath("PATH", package().binary_dir());
+#endif
+ if (!lyxrc.path_prefix.empty())
+ prependEnvPath("PATH", lyxrc.path_prefix);
+
+ // Check that user LyX directory is ok.
+ if (queryUserLyXDir(package().explicit_user_support()))
+ reconfigureUserLyXDir();
+
+ // no need for a splash when there is no GUI
+ if (!lyx_gui::use_gui) {
+ first_start = false;
+ }
+
+ // This one is generated in user_support directory by lib/configure.py.
+ if (!readRcFile("lyxrc.defaults"))
+ return false;
+
+ // Query the OS to know what formats are viewed natively
+ formats.setAutoOpen();
+
system_lyxrc = lyxrc;
system_formats = formats;
system_converters = converters;
system_movers = movers;
system_lcolor = lcolor;
- string prefsfile = "preferences";
- // back compatibility to lyxs < 1.1.6
- if (libFileSearch(string(), prefsfile).empty())
- prefsfile = "lyxrc";
- if (!libFileSearch(string(), prefsfile).empty())
- readRcFile(prefsfile);
+ // This one is edited through the preferences dialog.
+ if (!readRcFile("preferences"))
+ return false;
- readEncodingsFile("encodings");
- readLanguagesFile("languages");
+ if (!readEncodingsFile("encodings"))
+ return false;
+ if (!readLanguagesFile("languages"))
+ return false;
// Load the layouts
lyxerr[Debug::INIT] << "Reading layouts..." << endl;
- LyXSetStyle();
+ if (!LyXSetStyle())
+ return false;
- if (gui) {
+ if (lyx_gui::use_gui) {
// Set up bindings
toplevel_keymap.reset(new kb_keymap);
defaultKeyBindings(toplevel_keymap.get());
toplevel_keymap->read(lyxrc.bind_file);
// Read menus
- readUIFile(lyxrc.ui_file);
+ if (!readUIFile(lyxrc.ui_file))
+ return false;
}
if (lyxerr.debugging(Debug::LYXRC))
lyxrc.print();
- os::cygwin_path_fix(lyxrc.cygwin_path_fix);
+ os::windows_style_tex_paths(lyxrc.windows_style_tex_paths);
if (!lyxrc.path_prefix.empty())
prependEnvPath("PATH", lyxrc.path_prefix);
-#if !defined (USE_POSIX_PACKAGING)
- // Add the directory containing the LyX executable to the path
- // so that LyX can find things like tex2lyx.
- if (package().build_support().empty())
- prependEnvPath("PATH", package().binary_dir());
-#endif
-
- // Having reset the PATH we're now in a position to run configure
- // if necessary.
- if (reconfigure)
- reconfigureUserLyXDir();
-
if (fs::exists(lyxrc.document_path) &&
fs::is_directory(lyxrc.document_path))
package().document_dir() = lyxrc.document_path;
// close to zero. We therefore don't try to overcome this
// problem with e.g. asking the user for a new path and
// trying again but simply exit.
- exit(EXIT_FAILURE);
+ return false;
}
if (lyxerr.debugging(Debug::INIT)) {
lyxerr[Debug::INIT] << "Reading session information '.lyx/session'..." << endl;
session_.reset(new lyx::Session(lyxrc.num_lastfiles));
+ return true;
}
void LyX::defaultKeyBindings(kb_keymap * kbmap)
{
- kbmap->bind("Right", FuncRequest(LFUN_RIGHT));
- kbmap->bind("Left", FuncRequest(LFUN_LEFT));
+ kbmap->bind("Right", FuncRequest(LFUN_CHAR_FORWARD));
+ kbmap->bind("Left", FuncRequest(LFUN_CHAR_BACKWARD));
kbmap->bind("Up", FuncRequest(LFUN_UP));
kbmap->bind("Down", FuncRequest(LFUN_DOWN));
kbmap->bind("~S-ISO_Left_Tab", FuncRequest(LFUN_CELL_BACKWARD));
kbmap->bind("~S-BackTab", FuncRequest(LFUN_CELL_BACKWARD));
- kbmap->bind("Home", FuncRequest(LFUN_HOME));
- kbmap->bind("End", FuncRequest(LFUN_END));
- kbmap->bind("Prior", FuncRequest(LFUN_PRIOR));
- kbmap->bind("Next", FuncRequest(LFUN_NEXT));
+ kbmap->bind("Home", FuncRequest(LFUN_LINE_BEGIN));
+ kbmap->bind("End", FuncRequest(LFUN_LINE_END));
+ kbmap->bind("Prior", FuncRequest(LFUN_SCREEN_UP));
+ kbmap->bind("Next", FuncRequest(LFUN_SCREEN_DOWN));
- kbmap->bind("Return", FuncRequest(LFUN_BREAKPARAGRAPH));
+ kbmap->bind("Return", FuncRequest(LFUN_BREAK_PARAGRAPH));
//kbmap->bind("~C-~S-~M-nobreakspace", FuncRequest(LFUN_PROTECTEDSPACE));
- kbmap->bind("Delete", FuncRequest(LFUN_DELETE));
- kbmap->bind("BackSpace", FuncRequest(LFUN_BACKSPACE));
+ kbmap->bind("Delete", FuncRequest(LFUN_CHAR_DELETE_FORWARD));
+ kbmap->bind("BackSpace", FuncRequest(LFUN_CHAR_DELETE_BACKWARD));
// kbmap->bindings to enable the use of the numeric keypad
// e.g. Num Lock set
- //kbmap->bind("KP_0", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_Decimal", FuncRequest(LFUN_SELFINSERT));
- kbmap->bind("KP_Enter", FuncRequest(LFUN_BREAKPARAGRAPH));
- //kbmap->bind("KP_1", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_2", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_3", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_4", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_5", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_6", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_Add", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_7", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_8", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_9", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_Divide", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_Multiply", FuncRequest(LFUN_SELFINSERT));
- //kbmap->bind("KP_Subtract", FuncRequest(LFUN_SELFINSERT));
- kbmap->bind("KP_Right", FuncRequest(LFUN_RIGHT));
- kbmap->bind("KP_Left", FuncRequest(LFUN_LEFT));
+ //kbmap->bind("KP_0", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_Decimal", FuncRequest(LFUN_SELF_INSERT));
+ kbmap->bind("KP_Enter", FuncRequest(LFUN_BREAK_PARAGRAPH));
+ //kbmap->bind("KP_1", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_2", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_3", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_4", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_5", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_6", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_Add", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_7", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_8", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_9", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_Divide", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_Multiply", FuncRequest(LFUN_SELF_INSERT));
+ //kbmap->bind("KP_Subtract", FuncRequest(LFUN_SELF_INSERT));
+ kbmap->bind("KP_Right", FuncRequest(LFUN_CHAR_FORWARD));
+ kbmap->bind("KP_Left", FuncRequest(LFUN_CHAR_BACKWARD));
kbmap->bind("KP_Up", FuncRequest(LFUN_UP));
kbmap->bind("KP_Down", FuncRequest(LFUN_DOWN));
- kbmap->bind("KP_Home", FuncRequest(LFUN_HOME));
- kbmap->bind("KP_End", FuncRequest(LFUN_END));
- kbmap->bind("KP_Prior", FuncRequest(LFUN_PRIOR));
- kbmap->bind("KP_Next", FuncRequest(LFUN_NEXT));
+ kbmap->bind("KP_Home", FuncRequest(LFUN_LINE_BEGIN));
+ kbmap->bind("KP_End", FuncRequest(LFUN_LINE_END));
+ kbmap->bind("KP_Prior", FuncRequest(LFUN_SCREEN_UP));
+ kbmap->bind("KP_Next", FuncRequest(LFUN_SCREEN_DOWN));
}
{
// bindKeyings for transparent handling of deadkeys
// The keysyms are gotten from XFree86 X11R6
- kbmap->bind("~C-~S-~M-dead_acute", FuncRequest(LFUN_ACUTE));
- kbmap->bind("~C-~S-~M-dead_breve", FuncRequest(LFUN_BREVE));
- kbmap->bind("~C-~S-~M-dead_caron", FuncRequest(LFUN_CARON));
- kbmap->bind("~C-~S-~M-dead_cedilla", FuncRequest(LFUN_CEDILLA));
- kbmap->bind("~C-~S-~M-dead_abovering", FuncRequest(LFUN_CIRCLE));
- kbmap->bind("~C-~S-~M-dead_circumflex", FuncRequest(LFUN_CIRCUMFLEX));
- kbmap->bind("~C-~S-~M-dead_abovedot", FuncRequest(LFUN_DOT));
- kbmap->bind("~C-~S-~M-dead_grave", FuncRequest(LFUN_GRAVE));
- kbmap->bind("~C-~S-~M-dead_doubleacute", FuncRequest(LFUN_HUNG_UMLAUT));
- kbmap->bind("~C-~S-~M-dead_macron", FuncRequest(LFUN_MACRON));
+ kbmap->bind("~C-~S-~M-dead_acute", FuncRequest(LFUN_ACCENT_ACUTE));
+ kbmap->bind("~C-~S-~M-dead_breve", FuncRequest(LFUN_ACCENT_BREVE));
+ kbmap->bind("~C-~S-~M-dead_caron", FuncRequest(LFUN_ACCENT_CARON));
+ kbmap->bind("~C-~S-~M-dead_cedilla", FuncRequest(LFUN_ACCENT_CEDILLA));
+ kbmap->bind("~C-~S-~M-dead_abovering", FuncRequest(LFUN_ACCENT_CIRCLE));
+ kbmap->bind("~C-~S-~M-dead_circumflex", FuncRequest(LFUN_ACCENT_CIRCUMFLEX));
+ kbmap->bind("~C-~S-~M-dead_abovedot", FuncRequest(LFUN_ACCENT_DOT));
+ kbmap->bind("~C-~S-~M-dead_grave", FuncRequest(LFUN_ACCENT_GRAVE));
+ kbmap->bind("~C-~S-~M-dead_doubleacute", FuncRequest(LFUN_ACCENT_HUNGARIAN_UMLAUT));
+ kbmap->bind("~C-~S-~M-dead_macron", FuncRequest(LFUN_ACCENT_MACRON));
// nothing with this name
- // kbmap->bind("~C-~S-~M-dead_special_caron", LFUN_SPECIAL_CARON);
- kbmap->bind("~C-~S-~M-dead_tilde", FuncRequest(LFUN_TILDE));
- kbmap->bind("~C-~S-~M-dead_diaeresis", FuncRequest(LFUN_UMLAUT));
+ // kbmap->bind("~C-~S-~M-dead_special_caron", LFUN_ACCENT_SPECIAL_CARON);
+ kbmap->bind("~C-~S-~M-dead_tilde", FuncRequest(LFUN_ACCENT_TILDE));
+ kbmap->bind("~C-~S-~M-dead_diaeresis", FuncRequest(LFUN_ACCENT_UMLAUT));
// nothing with this name either...
- //kbmap->bind("~C-~S-~M-dead_underbar", FuncRequest(LFUN_UNDERBAR));
- kbmap->bind("~C-~S-~M-dead_belowdot", FuncRequest(LFUN_UNDERDOT));
- kbmap->bind("~C-~S-~M-dead_tie", FuncRequest(LFUN_TIE));
- kbmap->bind("~C-~S-~M-dead_ogonek",FuncRequest(LFUN_OGONEK));
+ //kbmap->bind("~C-~S-~M-dead_underbar", FuncRequest(LFUN_ACCENT_UNDERBAR));
+ kbmap->bind("~C-~S-~M-dead_belowdot", FuncRequest(LFUN_ACCENT_UNDERDOT));
+ kbmap->bind("~C-~S-~M-dead_tie", FuncRequest(LFUN_ACCENT_TIE));
+ kbmap->bind("~C-~S-~M-dead_ogonek",FuncRequest(LFUN_ACCENT_OGONEK));
}
-bool LyX::queryUserLyXDir(bool explicit_userdir)
+namespace {
+
+// return true if file does not exist or is older than configure.py.
+bool needsUpdate(string const & file)
{
- bool reconfigure = false;
+ static string const configure_script =
+ addName(package().system_support(), "configure.py");
+ string const absfile =
+ addName(package().user_support(), file);
+
+ return (! fs::exists(absfile))
+ || (fs::last_write_time(configure_script)
+ > fs::last_write_time(absfile));
+}
+
+}
+
+bool LyX::queryUserLyXDir(bool explicit_userdir)
+{
// Does user directory exist?
if (fs::exists(package().user_support()) &&
fs::is_directory(package().user_support())) {
first_start = false;
- string const configure_script =
- addName(package().system_support(), "configure.py");
- string const userDefaults =
- addName(package().user_support(), "lyxrc.defaults");
- if (fs::exists(configure_script) &&
- fs::exists(userDefaults) &&
- fs::last_write_time(configure_script)
- > fs::last_write_time(userDefaults)) {
- reconfigure = true;
- }
- return reconfigure;
+
+ return needsUpdate("lyxrc.defaults")
+ || needsUpdate("textclass.lst")
+ || needsUpdate("packages.lst");
}
first_start = !explicit_userdir;
_("&Create directory"),
_("&Exit LyX"))) {
lyxerr << _("No user LyX directory. Exiting.") << endl;
- exit(1);
+ lyx_exit(EXIT_FAILURE);
}
lyxerr << bformat(_("LyX: Creating directory %1$s"),
package().user_support())
<< endl;
- reconfigure = true;
if (!createDirectory(package().user_support(), 0755)) {
// Failed, so let's exit.
lyxerr << _("Failed to create directory. Exiting.")
<< endl;
- exit(1);
+ lyx_exit(EXIT_FAILURE);
}
- return reconfigure;
+ return true;
}
-void LyX::readRcFile(string const & name)
+bool LyX::readRcFile(string const & name)
{
- lyxerr[Debug::INIT] << "About to read " << name << "..." << endl;
+ lyxerr[Debug::INIT] << "About to read " << name << "... ";
string const lyxrc_path = libFileSearch(string(), name);
if (!lyxrc_path.empty()) {
- lyxerr[Debug::INIT] << "Found " << name
- << " in " << lyxrc_path << endl;
+ lyxerr[Debug::INIT] << "Found in " << lyxrc_path << endl;
- if (lyxrc.read(lyxrc_path) >= 0)
- return;
- }
+ if (lyxrc.read(lyxrc_path) < 0) {
+ showFileError(name);
+ return false;
+ }
+ } else
+ lyxerr[Debug::INIT] << "Not found." << lyxrc_path << endl;
+ return true;
- showFileError(name);
}
// Read the ui file `name'
-void LyX::readUIFile(string const & name)
+bool LyX::readUIFile(string const & name)
{
enum Uitags {
ui_menuset = 1,
<< "' has been read already. "
<< "Is this an include loop?"
<< endl;
- return;
+ return false;
}
lyxerr[Debug::INIT] << "About to read " << name << "..." << endl;
if (ui_path.empty()) {
lyxerr[Debug::INIT] << "Could not find " << name << endl;
showFileError(name);
- return;
+ return false;
}
uifiles.push_back(name);
case ui_include: {
lex.next(true);
string const file = lex.getString();
- readUIFile(file);
+ if (!readUIFile(file))
+ return false;
break;
}
case ui_menuset:
break;
}
}
+ return true;
}
// Read the languages file `name'
-void LyX::readLanguagesFile(string const & name)
+bool LyX::readLanguagesFile(string const & name)
{
lyxerr[Debug::INIT] << "About to read " << name << "..." << endl;
string const lang_path = libFileSearch(string(), name);
if (lang_path.empty()) {
showFileError(name);
- return;
+ return false;
}
languages.read(lang_path);
+ return true;
}
// Read the encodings file `name'
-void LyX::readEncodingsFile(string const & name)
+bool LyX::readEncodingsFile(string const & name)
{
lyxerr[Debug::INIT] << "About to read " << name << "..." << endl;
string const enc_path = libFileSearch(string(), name);
if (enc_path.empty()) {
showFileError(name);
- return;
+ return false;
}
encodings.read(enc_path);
+ return true;
}
int parse_version(string const &, string const &)
{
lyxerr << "LyX " << lyx_version
- << " of " << lyx_release_date << endl;
+ << " (" << lyx_release_date << ")" << endl;
lyxerr << "Built on " << __DATE__ << ", " << __TIME__ << endl;
lyxerr << lyx_version_info << endl;
std::map<string, cmd_helper>::const_iterator it
= cmdmap.find(argv[i]);
+ // check for X11 -geometry option
+ if (lyx::support::compare(argv[i], "-geometry") == 0)
+ geometryOption_ = true;
+
// don't complain if not found - may be parsed later
if (it == cmdmap.end())
continue;