// // Copyright (c) 2009-2011 Artyom Beilis (Tonkikh) // // Distributed under the Boost Software License, Version 1.0. (See // accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // // vim: tabstop=4 expandtab shiftwidth=4 softtabstop=4 filetype=cpp.doxygen /*! \page gettext_for_windows Using Gettext Tools on Windows In order to get the Gettext tools like \c msgfmt, \c msgmerge, \c xgettext for Windows you have basically several options: - Download the package from CppCMS project (where the Boost.Locale was developed originally) - Download the a set of packages from MinGW project - Build it on your own - Use Cygwin's packages \section gettext_for_windows_cppcms Getting gettext utilities from CppCMS project Boost.Locale was developed for needs of CppCMS project and thus CppCMS hosts a convince package for Windows users of pre-build, statically liked \c gettext runtime utilities like \c xgettext, \c msgfmt, etc. So you can download a zip file \c gettext-tools-static-XXX.zip from a CppCMS downloads page under boost_locale/gettext_for_windows. Extract the file and use the executable files inside. \section gettext_for_windows_mingw Getting Gettext via MinGW project MinGW project provides GNU tools for Windows, including GNU compilers and various runtime utilities. Thus you can always install full MinGW distribution including gettext tools. However, if you a want minimalistic runtime version that allows you to extract messages and create catalogs you need to download several packages manually. In order to install Gettext via MinGW distributing you need to download, a GCC's runtime, iconv library and gettext itself. So visit a downloads page of MinGW project and download following files (chose the latest versions of each package): - From: \c MinGW/BaseSystem/GCC/Version4/gcc-xxx/ \n File: \c libgcc-xxx-mingw32-dll-1.tar.lzma - From \c MinGW/Gettext/gettext-yyy/ \n Files: \c gettext-yyy-mingw32-dev.tar.lzma, \c libgettextpo-yyy-mingw32-dll-0.tar.lzma, \c libintl-yyy-mingw32-dll-8.tar.lzma - From \c MinGW/libiconv/libiconv-zzz/ \n Files: \c libiconv-zzz-mingw32-dll-2.tar.lzma, \c libcharset-zzz-mingw32-dll-1.tar.lzma For example, at June 23, 2011 it was: - GNU Runtime: \c libgcc-4.5.2-1-mingw32-dll-1.tar.lzma - \c iconv: \c libiconv-1.13.1-1-mingw32-dll-2.tar.lzma and \c libcharset-1.13.1-1-mingw32-dll-1.tar.lzma - \c gettext: \c libintl-0.17-1-mingw32-dll-8.tar.lzma, \c libgettextpo-0.17-1-mingw32-dll-0.tar.lzma and \c gettext-0.17-1-mingw32-dev.tar.lzma. After you download the packages, extract all the files to the same directory using tools like \c 7zip and you'll get all the executables and \c dll's you need under \c bin subdirectory. \note the version on MinGW site is slightly outdated (0.17.1) while gettext provides currently 0.18.1. \section gettext_for_windows_build Building latest version on your own. You can build your own version of GNU Gettext using MinGW environment, you'll need to have up-to-date gcc compiler and the shell, you'll need to install iconv first and then build a gettext with it. Basic and simplest way would be to open a MinGW shell Build \c iconv: \code cd libiconv-SOMEVERSION ./configure --prefix=c:/mygettext --disable-shared make make install cd .. cd gettext-SOMEVERSION ./configure --prefix=c:/mygettext --disable-shared --with-libiconv-prefix=c:/mygettext make make install \endcode And now you have in c:\\mygettext\\bin all appropriate executable files to use. \section gettext_for_windows_cygwin Using Cygwin If you already have Cygwin - just use gettext tools provided with it. */