+/* This file is part of
+ * ======================================================
+ *
+ * LyX, The Document Processor
+ *
+ * Copyright 1995 Matthias Ettrich
+ * Copyright 1995-2000 The LyX Team.
+ *
+ * ====================================================== */
#include <config.h>
+#ifdef __GNUG__
+#pragma implementation
+#endif
+
#include "language.h"
#include "gettext.h"
+#include "encoding.h"
Languages languages;
Language const * default_language;
-Language ignore_lang("ignore", "Ignore", false);
+Language ignore_lang("ignore", "Ignore", false, 0);
Language const * ignore_language = &ignore_lang;
///
init = true;
}
private:
- ///
- void newLang(char const * l, char const * d, bool rtl) {
- Language lang(l, d, rtl);
- //lang.lang = l;
- //lang.display = d;
- //lang.RightToLeft = rtl;
- languages[l] = lang;
- }
///
void initL();
///
char const * lang;
char const * display;
bool rtl;
+ Encoding const * encoding;
};
{
// Use this style of initialization to lower compilation times.
// Same method is used in LyXAction.C (Lgb)
-
+
lang_item items[] = {
- { "afrikaans", N_("Afrikaans"), false },
- { "american", N_("American"), false },
- { "arabic", N_("Arabic"), true },
- { "austrian", N_("Austrian"), false },
- { "bahasa", N_("Bahasa"), false },
- { "brazil", N_("Brazil"), false },
- { "breton", N_("Breton"), false },
- { "catalan", N_("Catalan"), false },
- { "croatian", N_("Croatian"), false },
- { "czech", N_("Czech"), false },
- { "danish", N_("Danish"), false },
- { "dutch", N_("Dutch"), false },
- { "english", N_("English"), false },
- { "esperanto", N_("Esperanto"), false },
- { "estonian", N_("Estonian"), false },
- { "finnish", N_("Finnish"), false },
- { "francais", N_("Francais"), false },
- { "french", N_("French"), false },
- { "frenchb", N_("Frenchb"), false },
- { "galician", N_("Galician"), false },
- { "german", N_("German"), false },
- { "greek", N_("Greek"), false },
- { "hebrew", N_("Hebrew"), true },
+ { "afrikaans", N_("Afrikaans"), false, &iso8859_1 },
+ { "american", N_("American"), false, &iso8859_1 },
+ { "arabic", N_("Arabic"), true, &iso8859_6 },
+ { "austrian", N_("Austrian"), false, &iso8859_1 },
+ { "bahasa", N_("Bahasa"), false, &iso8859_1 },
+ { "brazil", N_("Brazil"), false, &iso8859_1 },
+ { "breton", N_("Breton"), false, &iso8859_1 },
+ { "catalan", N_("Catalan"), false, &iso8859_1 },
+ { "croatian", N_("Croatian"), false, &iso8859_2 },
+ { "czech", N_("Czech"), false, &iso8859_2 },
+ { "danish", N_("Danish"), false, &iso8859_1 },
+ { "dutch", N_("Dutch"), false, &iso8859_1 },
+ { "english", N_("English"), false, &iso8859_1 },
+ { "esperanto", N_("Esperanto"), false, &iso8859_3 },
+ { "estonian", N_("Estonian"), false, &iso8859_4 },
+ { "finnish", N_("Finnish"), false, &iso8859_1 },
+ { "francais", N_("Francais"), false, &iso8859_1 },
+ { "french", N_("French"), false, &iso8859_1 },
+ { "frenchb", N_("Frenchb"), false, &iso8859_1 },
+ { "galician", N_("Galician"), false, &iso8859_1 },
+ { "german", N_("German"), false, &iso8859_1 },
+ { "greek", N_("Greek"), false, &iso8859_7 },
+ { "hebrew", N_("Hebrew"), true, &cp1255 },
/* According to Zrubecz Laszlo <zrubi@k2.jozsef.kando.hu>,
"magyar" is better. I kept it here in case we want
to provide aliasing of languages. (JMarc)
*/
- //{ "hungarian", N_("Hungarian"), false },
- { "irish", N_("Irish"), false },
- { "italian", N_("Italian"), false },
- { "lsorbian", N_("Lsorbian"), false },
- { "magyar", N_("Magyar"), false },
- { "norsk", N_("Norsk"), false },
- { "polish", N_("Polish"), false },
- { "portuges", N_("Portuges"), false },
- { "romanian", N_("Romanian"), false },
- { "russian", N_("Russian"), false },
- { "scottish", N_("Scottish"), false },
- { "spanish", N_("Spanish"), false },
- { "slovak", N_("Slovak"), false },
- { "slovene", N_("Slovene"), false },
- { "swedish", N_("Swedish"), false },
- { "turkish", N_("Turkish"), false },
- { "usorbian", N_("Usorbian"), false },
- { "welsh", N_("Welsh"), false },
- { 0, 0, false }
+ //{ "hungarian", N_("Hungarian"), false, &iso8859_2 },
+ { "irish", N_("Irish"), false, &iso8859_1 },
+ { "italian", N_("Italian"), false, &iso8859_1 },
+ { "lsorbian", N_("Lsorbian"), false, &iso8859_2 },
+ { "magyar", N_("Magyar"), false, &iso8859_2 },
+ { "norsk", N_("Norsk"), false, &iso8859_1 },
+ { "polish", N_("Polish"), false, &iso8859_2 },
+ { "portuges", N_("Portuges"), false, &iso8859_1 },
+ { "romanian", N_("Romanian"), false, &iso8859_2 },
+ { "russian", N_("Russian"), false, &koi8 },
+ { "scottish", N_("Scottish"), false, &iso8859_1 },
+ { "spanish", N_("Spanish"), false, &iso8859_1 },
+ { "slovak", N_("Slovak"), false, &iso8859_2 },
+ { "slovene", N_("Slovene"), false, &iso8859_2 },
+ { "swedish", N_("Swedish"), false, &iso8859_1 },
+ { "turkish", N_("Turkish"), false, &iso8859_9 },
+ { "usorbian", N_("Usorbian"), false, &iso8859_2 },
+ { "welsh", N_("Welsh"), false, &iso8859_1 },
+ { 0, 0, false, 0 }
};
int i = 0;
while (items[i].lang) {
- newLang(items[i].lang, items[i].display, items[i].rtl);
+ languages[items[i].lang] =
+ Language(items[i].lang, items[i].display,
+ items[i].rtl, items[i].encoding);
++i;
}