]> icculus.org git repositories - mikachu/openbox.git/blob - src/i18n.cc
fix compiling with --disable-nls
[mikachu/openbox.git] / src / i18n.cc
1 // -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
2 // i18n.cc for Openbox
3 // Copyright (c) 2001 - 2002 Sean 'Shaleh' Perry <shaleh@debian.org>
4 // Copyright (c) 1997 - 2000 Brad Hughes (bhughes@tcac.net)
5 //
6 // Permission is hereby granted, free of charge, to any person obtaining a
7 // copy of this software and associated documentation files (the "Software"),
8 // to deal in the Software without restriction, including without limitation
9 // the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 // and/or sell copies of the Software, and to permit persons to whom the
11 // Software is furnished to do so, subject to the following conditions:
12 //
13 // The above copyright notice and this permission notice shall be included in
14 // all copies or substantial portions of the Software.
15 //
16 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
19 // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 // DEALINGS IN THE SOFTWARE.
23
24 #ifdef    HAVE_CONFIG_H
25 #  include "../config.h"
26 #endif // HAVE_CONFIG_H
27
28 extern "C" {
29 #include <X11/Xlocale.h>
30
31 #ifdef HAVE_STDLIB_H
32 #  include <stdlib.h>
33 #endif // HAVE_STDLIB_H
34
35 #ifdef HAVE_STRING_H
36 #  include <string.h>
37 #endif // HAVE_STRING_H
38
39 #ifdef HAVE_STDIO_H
40 #  include <stdio.h>
41 #endif // HAVE_STDIO_H
42
43 #ifdef    HAVE_LOCALE_H
44 #  include <locale.h>
45 #endif // HAVE_LOCALE_H
46 }
47
48 #include <string>
49 using std::string;
50
51 #include "i18n.h"
52
53 I18n::I18n(const char *catalog) {
54   mb = false;
55 #ifdef    HAVE_SETLOCALE
56   locale = setlocale(LC_ALL, "");
57   if (! locale) {
58     fprintf(stderr, "failed to set locale, reverting to \"C\"\n");
59 #endif // HAVE_SETLOCALE
60     locale = "C";
61 #ifdef    HAVE_SETLOCALE
62   } else {
63     // MB_CUR_MAX returns the size of a char in the current locale
64     if (MB_CUR_MAX > 1)
65       mb = true;
66     // truncate any encoding off the end of the locale
67     char *l = strchr(locale, '@');
68     if (l) *l = '\0';
69     l = strchr(locale, '.');
70     if (l) *l = '\0';
71   }
72
73 #ifdef HAVE_CATOPEN
74   catalog_fd = (nl_catd) -1;
75 #endif
76 #endif // HAVE_SETLOCALE
77   if (catalog)
78     openCatalog(catalog);
79 }
80
81
82 I18n::~I18n() {
83 #if defined(NLS) && defined(HAVE_CATCLOSE)
84   if (catalog_fd != (nl_catd) -1)
85     catclose(catalog_fd);
86 #endif // HAVE_CATCLOSE
87 }
88
89
90 #if defined(NLS) && defined(HAVE_CATOPEN)
91 void I18n::openCatalog(const char *catalog) {
92   int lp = strlen(LOCALEPATH), lc = strlen(locale),
93       ct = strlen(catalog), len = lp + lc + ct + 3;
94   catalog_filename = new char[len];
95
96   strncpy(catalog_filename, LOCALEPATH, lp);
97   *(catalog_filename + lp) = '/';
98   strncpy(catalog_filename + lp + 1, locale, lc);
99   *(catalog_filename + lp + lc + 1) = '/';
100   strncpy(catalog_filename + lp + lc + 2, catalog, ct + 1);
101
102 #  ifdef    MCLoadBySet
103   catalog_fd = catopen(catalog_filename.c_str(), MCLoadBySet);
104 #  else // !MCLoadBySet
105   catalog_fd = catopen(catalog_filename.c_str(), NL_CAT_LOCALE);
106 #  endif // MCLoadBySet
107
108   if (catalog_fd == (nl_catd) -1)
109     fprintf(stderr, "failed to open catalog, using default messages\n");
110 }
111 #else // !HAVE_CATOPEN
112 void I18n::openCatalog(const char *) {
113   catalog_filename = (char *) 0;
114 }
115 #endif // HAVE_CATOPEN
116
117
118 #if   defined(NLS) && defined(HAVE_CATGETS)
119 const char *I18n::getMessage(int set, int msg, const char *msgString) const {
120   if (catalog_fd != (nl_catd) -1)
121     return catgets(catalog_fd, set, msg, msgString);
122   else
123     return msgString;
124 }
125 #else
126 const char *I18n::getMessage(int, int, const char *msgString) const {
127   return msgString;
128 }
129 #endif