]> git.lyx.org Git - lyx.git/blobdiff - src/gettext.C
GTK graphics dialog: Default to scaling 100% when no scaling or size is given
[lyx.git] / src / gettext.C
index debe17e487772d13230fc635c15728b9d84ac5c3..aae9bc7f5c12b91b6e989775e99fda66c2b7484b 100644 (file)
@@ -1,79 +1,64 @@
-// -*- C++ -*-
-/* This file is part of
- * ====================================================== 
- * 
- *           LyX, The Document Processor
- *        
- *           Copyright 1995 Matthias Ettrich
- *           Copyright 1995-2001 The LyX Team.
+/**
+ * \file src/gettext.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
  *
- * ====================================================== */
+ * \author Lars Gullik Bjønnes
+ * \author Jean-Marc Lasgouttes
+ *
+ * Full author contact details are available in file CREDITS.
+ */
 
 #include <config.h>
 
-#include "LString.h"
+#include "gettext.h"
+#include "messages.h"
+#include "support/environment.h"
 
-#ifdef ENABLE_NLS
+#ifdef HAVE_LOCALE_H
+#  include <locale.h>
+#endif
+
+using std::string;
+using lyx::support::setEnv;
 
-#  if HAVE_GETTEXT
-#    include <libintl.h>      // use the header already in the system *EK*
-#    ifdef HAVE_LOCALE_H
-#      include <locale.h>        // for LC_MESSAGES
-#    endif
-#  else
-#    include "../intl/libintl.h"
-#  endif
 
-char const * _(char const * str)
+namespace {
+
+Messages & getLyXMessages()
 {
-       // I'd rather have an Assert on str, we should not allow
-       // null pointers here. Lgb
-       // Assert(str);
-       if (str && str[0])
-               return gettext(str);
-       else
-               return "";
+       static Messages lyx_messages;
+
+       return lyx_messages;
 }
 
+} // anon namespace
+
 
-string const _(string const & str) 
+string const _(string const & str)
 {
-       if (!str.empty()) {
-               int const s = str.length();
-               char * tmp = new char[s + 1];
-               str.copy(tmp, s);
-               tmp[s] = '\0';
-               string ret(gettext(tmp));
-               delete [] tmp;
-               return ret;
-       }
-       else
-               return string();
+       return getLyXMessages().get(str);
 }
 
+
+#ifdef ENABLE_NLS
+
 void locale_init()
 {
+       // Disable, as otherwise it overrides everything else incl. the doc language
+       setEnv("LANGUAGE", "");
 #  ifdef HAVE_LC_MESSAGES
        setlocale(LC_MESSAGES, "");
+#  endif
        setlocale(LC_CTYPE, "");
        setlocale(LC_NUMERIC, "C");
-#  endif
-}
-
-void gettext_init(string const & localedir)
-{
-       bindtextdomain(PACKAGE, localedir.c_str()); 
-       textdomain(PACKAGE);
 }
 
-
 #else // ENABLE_NLS
 
 void locale_init()
 {
+       setlocale(LC_NUMERIC, "C");
 }
 
-void gettext_init(string const &)
-{
-}
 #endif