1 C++ version of the libphonenumber project 2 ========================================= 3 4This library is a port of the Java version. 5 6This project uses some third-party code: 7 - src/phonenumbers/utf/ sources come from lib9 which is also used in Go. 8 9 10Installing the library on GNU/Linux 11----------------------------------- 12In recent Debian-based distributions you may be able to simply install the 13libphonenumber library directly. 14 15Installing the binary packages: 16 - Use this if you just need to use or link against the library: 17 $ sudo apt-get install libphonenumber8 libphonenumber-dev 18 19Installing the source package: 20 - Use this if you wish to develop or debug the library: 21 $ sudo apt-get source libphonenumber 22 23The latest packages can be found on the Debian packages site: 24 https://packages.debian.org/search?searchon=names&keywords=libphonenumber 25 26 27Manually installing the library on GNU/Linux 28-------------------------------------------- 29You should only need these instructions if the above instructions do not work. 30 31The example command lines below assume that you have a Debian-based GNU/Linux 32distribution. Other distributions and packaging systems will differ. 33 34Quickstart: 35 - In recent Debian-based distributions, it should be sufficient to run: 36 $ sudo apt-get install \ 37 cmake cmake-curses-gui libprotobuf-dev libgtest-dev libre2-dev \ 38 libicu-dev libboost-dev libboost-thread-dev libboost-system-dev \ 39 protobuf-compiler 40 41If any of these packages fails to install correctly, follow the instructions 42in the appropriate section below. 43 44Requirements: 45 - CMake build system 46 http://www.cmake.org 47 48 Installation: 49 $ sudo apt-get install cmake 50 51 Additionally it is recommended you install the ccmake configuration tool: 52 $ sudo apt-get install cmake-curses-gui 53 54 - Protocol Buffers 55 http://github.com/google/protobuf/ 56 Version 3.6.1 or more recent is required (this is available by default for 57 recent Debian-based GNU/Linux distributions). 58 59 You can check which version is available: 60 $ apt-cache show libprotobuf-dev 61 Package: libprotobuf-dev 62 Source: protobuf 63 Version: 3.6.1-9ubuntu1 <-- This must be >= 3.6.1 64 ... 65 66 Installation: 67 $ sudo apt-get install libprotobuf-dev 68 69 Note: if your GNU/Linux distribution doesn't provide the needed package, 70 please download and install it manually: 71 More details can be found at its official page: 72 https://github.com/protocolbuffers/protobuf 73 74 - Google Test 75 http://github.com/google/googletest 76 77 Installation: 78 $ sudo apt-get install libgtest-dev 79 80 - RE2 81 http://github.com/google/re2 82 83 Installation: 84 $ sudo apt-get install libre2-dev 85 86 Note that some distributions (notably Ubuntu 10.4) may not include this, 87 so you might need to download and install it manually. 88 89 Find and download the Debian packages for your system. For example: 90 http://packages.ubuntu.com/utopic/libre2-1 91 http://packages.ubuntu.com/utopic/libre2-dev 92 93 You need to download both the libre2-dev and libre2-1 packages. 94 Once downloaded, install them with: 95 $ sudo dpkg -i libre2*.deb 96 97 If you want to install it from source, it's available via Mercurial at: 98 https://re2.googlecode.com/hg 99 however precise instructions on building and installing are outside the 100 scope of this document. 101 102 - ICU 103 Installation: 104 $ sudo apt-get install libicu-dev 105 106 Otherwise you need to download the source tarball for the latest version 107 from: 108 http://site.icu-project.org/download 109 And then extract it via: 110 $ tar xzf icu4c-*-src.tgz 111 112 Alternatively you can export the SVN repository to the current directory 113 via: 114 $ svn export http://source.icu-project.org/repos/icu/icu/tags/release-XX-y-z/ 115 116 Having acquired the latest sources, make and install it via: 117 $ cd icu/source 118 $ ./configure && make && sudo make install 119 120 - A thread synchronization solution or more recent is required if you need 121 libphonenumber to be thread-safe. Supported solution are: 122 - Boost Version 1.40 or more recent 123 - Posix Thread. Linux or Apple (ios/mac) detection is automatic. On other 124 Posix environnement, uses -DUSE_POSIX_THREAD = ON 125 - C++ 2011 (and later) std::mutex. Uses -DUSE_STDMUTEX = ON to enable 126 automatic C++ 2011 detection (if you prefer Posix or Win32 solution). 127 - Windows Win32 synchronization API. 128 129 If you access libphonenumber from a single thread, you don't need one of 130 these solution. 131 132 You can install it very easily on a Debian-based GNU/Linux distribution: 133 $ sudo apt-get install libboost-dev libboost-thread-dev libboost-system-dev 134 135 Note: Boost Thread is the only library needed at link time. 136 137 138Building and testing the library 139-------------------------------- 140 $ cd libphonenumber/cpp 141 $ mkdir build 142 $ cd build 143 $ cmake .. 144 $ make 145 $ ./libphonenumber_test 146 147 148Manually installing the library on Mac 149-------------------------------------- 150 151You can easily install dependencies on Mac using a package manager. In these 152instructions we use Homebrew (http://brew.sh). 153 154Install Homebrew package manager and use it to install dependencies: 155 $ /usr/bin/ruby -e "$(curl -fsSL \ 156 https://raw.githubusercontent.com/Homebrew/install/master/install)" 157 $ brew install boost cmake icu4c pkg-config protobuf wget 158 159See https://github.com/Homebrew/homebrew/issues/14099 - homebrew does not have 160gtest. We don't need to install gtest, we only copy sources. For example: 161 $ mkdir ~/googletest_clone 162 $ cd ~/googletest_clone 163 $ git clone https://github.com/google/googletest.git 164 165Get the libphonenumber source. For example: 166 $ mkdir ~/libphonenumber_clone 167 $ cd ~/libphonenumber_clone 168 $ git clone https://github.com/google/libphonenumber.git 169 170Build and test the library: 171 $ cd libphonenumber/cpp 172 $ mkdir build 173 $ cd build 174 Replace XXX in the commands below with the appropriate version number: 175 $ cmake \ 176 -DGTEST_SOURCE_DIR=~/googletest_clone/googletest/googletest/ \ 177 -DGTEST_INCLUDE_DIR=~/googletest_clone/googletest/googletest/include/ \ 178 -DICU_UC_INCLUDE_DIR=/usr/local/Cellar/icu4c/XXX/include/ \ 179 -DICU_UC_LIB=/usr/local/Cellar/icu4c/XXX/lib/libicuuc.dylib \ 180 -DICU_I18N_INCLUDE_DIR=/usr/local/Cellar/icu4c/XXX/include/ \ 181 -DICU_I18N_LIB=/usr/local/Cellar/icu4c/XXX/lib/libicui18n.dylib \ 182 -DUSE_STD_MAP=ON \ 183 .. 184 $ make 185 $ ./libphonenumber_test 186 187Optional: Deleting & uninstalling everything again: 188 $ cd 189 $ rm -rf ~/libphonenumber_clone ~/googletest_clone 190 191 openssl is a dependency of wget and installed with it by Homebrew. If you had 192 openssl before installing wget don't uninstall here. 193 $ brew uninstall boost cmake icu4c openssl pkg-config protobuf wget 194 195 $ /usr/bin/ruby -e "$(curl -fsSL \ 196 https://raw.githubusercontent.com/Homebrew/install/master/uninstall)" 197 198 Homebrew will have changed permissions at installation. See output of previous 199 command for how to change them back, for example: 200 $ sudo chmod 0755 /usr/local 201 $ sudo chgrp wheel /usr/local 202 203 204Troubleshooting CMake via ccmake 205-------------------------------- 206 Follow these instructions if the build steps above don't work for you. 207 208 - Incorrect protocol buffer library issues 209 If the build process complains that the version of protoc being used is too 210 old or that it cannot find the correct libprotobuf library, you may need to 211 change the library path of the project. 212 213 This issue should typically only occur in cases where you have two (or more) 214 versions of the protocol buffer libraries installed on your system. This 215 step assumes that you have already manually downloaded and installed the 216 protocol buffer libraries into /usr/local (as described above). 217 218 To make cmake use the manually installed version of the protocol buffer 219 libraries, install cmake-curses-gui and use ccmake as follows. 220 221 From within libphonenumber/cpp/build: 222 $ ccmake . 223 224 You should set the following values: 225 PROTOBUF_INCLUDE_DIR /usr/local/include 226 PROTOBUF_LIB /usr/local/lib/libprotobuf.dylib 227 PROTOC_BIN /usr/local/bin/protoc 228 229 Now press 'c' then 'g' to configure the new parameters and exit ccmake. 230 Finally regenerate the make files and rebuild via: 231 $ cmake .. 232 $ make 233 234 - Protoc binary not executing properly 235 If you still have issues with the protoc binary tool in /usr/local/bin not 236 running correctly (cannot find libprotobuf.so.x) then you may need to 237 configure the LD_LIBRARY_PATH. To do this, as a superuser, add the following 238 file: 239 /etc/ld.so.conf.d/libprotobuf.conf 240 241 with the contents: 242 # Use the manually installed version of the protocol buffer libraries. 243 /usr/local/lib 244 245 And then run: 246 $ sudo chmod 644 /etc/ld.so.conf.d/libprotobuf.conf 247 $ sudo ldconfig 248 249 - Incorrect ICU library issues 250 Similar to the protocol buffer library issue above, it is possible that your 251 build may fail if you have two conflicting versions of the ICU libraries 252 installed on your system. This step assumes that you have already manually 253 downloaded and installed a recent version of the ICU libraries into 254 /usr/local. 255 256 Install and run the ccmake tool (as described above) and set the following 257 values: 258 ICU_I18N_INCLUDE_DIR /usr/local/include 259 ICU_I18N_LIB /usr/local/lib/libicui18n.so 260 ICU_UC_INCLUDE_DIR /usr/local/include 261 ICU_UC_LIB /usr/local/lib/libicuuc.so 262 263 Now press 'c' then 'g' to configure the new parameters and exit ccmake. 264 Finally regenerate the make files and rebuild via: 265 $ cmake .. 266 $ make 267 268 269Building the library on Windows (Visual Studio) 270----------------------------------------------- 271We recommend that libphonenumber on Windows be built with Visual Studio 2015 272Update 2 (https://www.visualstudio.com/en-us/news/releasenotes/vs2015-update2-vs) 273or later. 274 275This enables support of plain UTF-8 source files, for which you also need to specify 276the /utf-8 option in build files; see "New Options in VS2015 Update 2" at 277https://blogs.msdn.microsoft.com/vcblog/2016/02/22/new-options-for-managing-character-sets-in-the-microsoft-cc-compiler/, 278or a Chrome patch for an example: 279https://codereview.chromium.org/2488853002/diff/80001/build/config/compiler/BUILD.gn 280 281Without this version and the option, your compilation will have warnings when 282setting the codepage for non-Unicode applications on Windows to one of the CJK 283code pages, since libphonenumber has UTF-8 strings in source files. While these 284are only comments (as opposed to string literals) the warnings can be 285suppressed, but we reserve the right to introduce UTF-8 string literals. 286 287The library was tested with Visual Studio 2010. 288 289You will need to manually fetch and install the following dependencies: 290 - CMake (tested with v2.8.6): 291 http://cmake.org/cmake/resources/software.html 292 * Download and install the Win32 installer. 293 294 - Boost (tested with v1.44) from BoostPro: 295 http://www.boostpro.com/download/ 296 * Select all the variants and Boost DateTime and Boost Thread during the 297 installation process. 298 See Linux instructions for information about thread-safety. 299 300 - GTest (tested with v1.6.0): 301 http://code.google.com/p/googletest/downloads/list 302 * Open msvc/gtest-md.sln with Visual Studio and build the whole solution. 303 304 - ICU (MSVC binaries, tested with v4.8.1): 305 http://site.icu-project.org/download/48#ICU4C-Download 306 * Simply extract the archive. 307 308 - Protocol Buffers: 309 http://code.google.com/p/protobuf/downloads/list 310 * Open vsprojects/protobuf.sln with Visual Studio and build the whole 311 solution. 312 313Then run cmake-gui and specify the path to the libphonenumber's cpp directory 314and its build directory which must be created (e.g. cpp/build). 315 316When clicking on "Configure", specify the appropriate Visual Studio version 317(tested with 2010). 318 319Then CMake will need your help to locate the dependencies. You will have to set 320the following variables (this example assumes that you extracted the 321dependencies to C:/). 322 323GTEST_INCLUDE_DIR C:/gtest-1.6.0/include 324GTEST_LIB C:/gtest-1.6.0/msvc/gtest-md/Release/gtest.lib 325 326ICU_I18N_INCLUDE_DIR C:/icu/include 327ICU_I18N_LIB C:/icu/lib/icuin.lib 328 329ICU_UC_INCLUDE_DIR C:/icu/include 330ICU_UC_LIB C:/icu/lib/icuuc.lib 331 332PROTOBUF_INCLUDE_DIR C:/protobuf-3.6.1/src 333PROTOBUF_LIB C:/protobuf-3.6.1/vsprojects/Release/libprotobuf.lib 334PROTOC_BIN C:/protobuf-3.6.1/vsprojects/Release/protoc.exe 335 336Then you can click on "Configure" again. CMake should have located all the 337dependencies. 338Then click on "Generate" to generate the appropriate Visual Studio project. 339Then open cpp/build/libphonenumber.sln with Visual Studio and build the INSTALL 340target. 341 342As a result the library's headers and binaries should have been installed to 343C:/Program Files/libphonenumber/. 344Note that this path can be set by overriding the CMAKE_INSTALL_PREFIX variable 345with cmake-gui. 346 347 348Supported build parameters 349-------------------------- 350 Build parameters can be specified invoking CMake with '-DKEY=VALUE' or using a 351 CMake user interface (ccmake or cmake-gui). 352 353 USE_ALTERNATE_FORMATS = ON | OFF [ON] -- Use alternate formats for the phone 354 number matcher. 355 USE_BOOST = ON | OFF [ON] -- Use Boost. This is only needed in 356 multi-threaded environments that 357 are not Linux and Mac. 358 Libphonenumber relies on Boost for 359 non-POSIX, non-Windows and non-C++ 2011 360 multi-threading. 361 USE_ICU_REGEXP = ON | OFF [ON] -- Use ICU regexp engine. 362 USE_LITE_METADATA = ON | OFF [OFF] -- Generates smaller metadata that 363 doesn't include example numbers. 364 USE_POSIX_THREAD = ON | OFF [OFF] -- Use Posix thread for multi-threading. 365 USE_RE2 = ON | OFF [OFF] -- Use RE2. 366 USE_STD_MAP = ON | OFF [OFF] -- Force the use of std::map. 367 USE_STDMUTEX = ON | OFF [OFF] -- Detect and use C++2011 for multi-threading. 368 REGENERATE_METADATA = ON | OFF [ON] -- When this is set to OFF it will skip 369 regenerating the metadata with 370 BuildMetadataCppFromXml. Since the 371 metadata is included in the source 372 tree anyway, it is beneficial for 373 packagers to turn this OFF: it saves 374 some time, and it also makes it 375 unnecessary to have java in the build 376 environment. 377