aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2014-06-10 22:38:00 +0200
committerMax Kellermann <max@duempel.org>2014-06-10 23:21:09 +0200
commit37b31907525dd3554924ec4144f4345993579376 (patch)
treec73142153d36066bb9bb537b689b122db4cc51b6
parentd51265d48f1eb8d2ba7640793d5ce6968805d2c0 (diff)
downloadmpd-37b31907525dd3554924ec4144f4345993579376.tar.gz
mpd-37b31907525dd3554924ec4144f4345993579376.tar.xz
mpd-37b31907525dd3554924ec4144f4345993579376.zip
lib/icu: add IcuInit(), IcuFinish()
-rw-r--r--Makefile.am5
-rw-r--r--src/Main.cxx6
-rw-r--r--src/lib/icu/Collate.cxx10
-rw-r--r--src/lib/icu/Init.cxx34
-rw-r--r--src/lib/icu/Init.hxx42
5 files changed, 86 insertions, 11 deletions
diff --git a/Makefile.am b/Makefile.am
index 2df5be262..8dd8372c6 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -434,6 +434,11 @@ libicu_a_SOURCES = \
src/lib/icu/Collate.cxx src/lib/icu/Collate.hxx \
src/lib/icu/Error.cxx src/lib/icu/Error.hxx
+if HAVE_ICU
+libicu_a_SOURCES += \
+ src/lib/icu/Init.cxx src/lib/icu/Init.hxx
+endif
+
ICU_LDADD = libicu.a $(ICU_LIBS)
# PCM library
diff --git a/src/Main.cxx b/src/Main.cxx
index 79fc9d601..5a33e121b 100644
--- a/src/Main.cxx
+++ b/src/Main.cxx
@@ -57,7 +57,7 @@
#include "util/Domain.hxx"
#include "thread/Id.hxx"
#include "thread/Slack.hxx"
-#include "lib/icu/Collate.hxx"
+#include "lib/icu/Init.hxx"
#include "config/ConfigGlobal.hxx"
#include "config/ConfigData.hxx"
#include "config/ConfigDefaults.hxx"
@@ -430,7 +430,7 @@ int mpd_main(int argc, char *argv[])
#endif
#endif
- if (!IcuCollateInit(error)) {
+ if (!IcuInit(error)) {
LogError(error);
return EXIT_FAILURE;
}
@@ -696,7 +696,7 @@ int mpd_main(int argc, char *argv[])
WSACleanup();
#endif
- IcuCollateFinish();
+ IcuFinish();
log_deinit();
return EXIT_SUCCESS;
diff --git a/src/lib/icu/Collate.cxx b/src/lib/icu/Collate.cxx
index 4d1526b28..f6621eb21 100644
--- a/src/lib/icu/Collate.cxx
+++ b/src/lib/icu/Collate.cxx
@@ -43,10 +43,11 @@
static UCollator *collator;
#endif
+#ifdef HAVE_ICU
+
bool
IcuCollateInit(Error &error)
{
-#ifdef HAVE_ICU
assert(collator == nullptr);
assert(!error.IsDefined());
@@ -57,9 +58,6 @@ IcuCollateInit(Error &error)
"ucol_open() failed: %s", u_errorName(code));
return false;
}
-#else
- (void)error;
-#endif
return true;
}
@@ -67,15 +65,11 @@ IcuCollateInit(Error &error)
void
IcuCollateFinish()
{
-#ifdef HAVE_ICU
assert(collator != nullptr);
ucol_close(collator);
-#endif
}
-#ifdef HAVE_ICU
-
static WritableBuffer<UChar>
UCharFromUTF8(const char *src)
{
diff --git a/src/lib/icu/Init.cxx b/src/lib/icu/Init.cxx
new file mode 100644
index 000000000..e6c0814d8
--- /dev/null
+++ b/src/lib/icu/Init.cxx
@@ -0,0 +1,34 @@
+/*
+ * Copyright (C) 2003-2014 The Music Player Daemon Project
+ * http://www.musicpd.org
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#include "config.h"
+#include "Init.hxx"
+#include "Collate.hxx"
+
+bool
+IcuInit(Error &error)
+{
+ return IcuCollateInit(error);
+}
+
+void
+IcuFinish()
+{
+ IcuCollateFinish();
+}
diff --git a/src/lib/icu/Init.hxx b/src/lib/icu/Init.hxx
new file mode 100644
index 000000000..9f585e2bd
--- /dev/null
+++ b/src/lib/icu/Init.hxx
@@ -0,0 +1,42 @@
+/*
+ * Copyright (C) 2003-2014 The Music Player Daemon Project
+ * http://www.musicpd.org
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#ifndef MPD_ICU_INIT_HXX
+#define MPD_ICU_INIT_HXX
+
+#include "check.h"
+
+class Error;
+
+#ifdef HAVE_ICU
+
+bool
+IcuInit(Error &error);
+
+void
+IcuFinish();
+
+#else
+
+static inline bool IcuInit(Error &) { return true; }
+static inline void IcuFinish() {}
+
+#endif
+
+#endif