/* This file is part of
- * ======================================================
- *
+ * ======================================================
+ *
* LyX, The Document Processor
- *
+ *
* Copyright 1995 Matthias Ettrich
- * Copyright 1995-2000 The LyX Team.
+ * Copyright 1995-2001 The LyX Team.
*
* ====================================================== */
#include <config.h>
-#ifdef __GNUG__
-#pragma implementation
-#endif
-
#include "language.h"
#include "gettext.h"
#include "encoding.h"
#include "lyxrc.h"
-#include "lyx_gui_misc.h"
#include "lyxlex.h"
#include "debug.h"
Language const * default_language;
Language ignore_lang("ignore", "ignore", "Ignore", false, 0, "ignore", "");
Language const * ignore_language = &ignore_lang;
+Language latex_lang("latex", "latex", "Latex", false, 0, "latex", "");
+Language const * latex_language = &latex_lang;
void Languages::setDefaults()
{
+ // We need to set the encoding of latex_lang
+ latex_lang = Language("latex", "latex", "Latex", false,
+ encodings.getEncoding("iso8859-1"),
+ "latex", "");
+
languagelist["english"] = Language("english", "english", N_("English"),
- false,
+ false,
encodings.getEncoding("iso8859-1"),
"en", "");
english_language = default_language = &languagelist["english"];
void Languages::read(string const & filename)
{
+ // We need to set the encoding of latex_lang
+ latex_lang = Language("latex", "latex", "Latex", false,
+ encodings.getEncoding("iso8859-1"),
+ "latex", "");
+
LyXLex lex(0, 0);
lex.setFile(filename);
- while (lex.IsOK()) {
- string lang, babel, display, encoding_str, code, latex_options;
+ while (lex.isOK()) {
+ string lang;
+ string babel;
+ string display;
+ string encoding_str;
+ string code;
+ string latex_options;
bool rtl = false;
if (lex.next())
- lang = lex.GetString();
+ lang = lex.getString();
else
break;
lyxerr[Debug::INIT] << "Reading language " << lang << endl;
if (lex.next())
- babel = lex.GetString();
+ babel = lex.getString();
if (lex.next())
- display = lex.GetString();
+ display = lex.getString();
if (lex.next())
- rtl = lex.GetBool();
+ rtl = lex.getBool();
if (lex.next())
- encoding_str = lex.GetString();
+ encoding_str = lex.getString();
if (lex.next())
- code = lex.GetString();
+ code = lex.getString();
if (lex.next())
- latex_options = lex.GetString();
+ latex_options = lex.getString();
Encoding const * encoding = encodings.getEncoding(encoding_str);
if (!encoding) {
encoding = encodings.getEncoding("iso8859-1");
- lyxerr << "Unknown encoding " << encoding_str << endl;
+ lyxerr << "Unknown encoding " << encoding_str << endl;
}
- languagelist[lang] = Language(lang, babel, display, rtl,
+ languagelist[lang] = Language(lang, babel, display, rtl,
encoding, code, latex_options);
}
-#ifdef DO_USE_DEFAULT_LANGUAGE
- languagelist["default"] = Language("default", "default",
- N_("Document wide language"),
- false, &iso8859_1, "");
-#endif
default_language = getLanguage(lyxrc.default_language);
if (!default_language) {
lyxerr << "Default language \"" << lyxrc.default_language
Language const * Languages::getLanguage(string const & language) const
{
- const_iterator it = languagelist.find(language);
+ const_iterator it = languagelist.find(language);
if (it != languagelist.end())
- return &(*it).second;
+ return &it->second;
else
return 0;
}