-/* This file is part of
- * ======================================================
+/**
+ * \file src/gettext.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- * LyX, The Document Processor
+ * \author Lars Gullik Bjønnes
+ * \author Jean-Marc Lasgouttes
*
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-2001 The LyX Team.
- *
- * ====================================================== */
+ * Full author contact details are available in file CREDITS.
+ */
#include <config.h>
+#include "gettext.h"
+#include "messages.h"
+
+
#ifdef HAVE_LOCALE_H
# include <locale.h>
#endif
-#include "LString.h"
+using std::string;
-#include <boost/smart_ptr.hpp>
-#ifdef ENABLE_NLS
+namespace {
-# if HAVE_GETTEXT
-# include <libintl.h> // use the header already in the system *EK*
-# else
-# include "../intl/libintl.h"
-# endif
-
-char const * _(char const * str)
+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)
{
- if (!str.empty()) {
- int const s = str.length();
- boost::scoped_array<char> tmp(new char[s + 1]);
- str.copy(tmp.get(), s);
- tmp[s] = '\0';
- string const ret(gettext(tmp.get()));
- return ret;
- } else {
- return string();
- }
+ return getLyXMessages().get(str);
}
+#ifdef ENABLE_NLS
+
void locale_init()
{
# ifdef HAVE_LC_MESSAGES
setlocale(LC_NUMERIC, "C");
}
-
-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