-# Copyright (C) 2011 Google Inc.
+# Copyright (C) 2011 The Libphonenumber Authors
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
cmake_minimum_required (VERSION 2.8)
project (libphonenumber)
+set (libphonenumber_VERSION_MAJOR 7)
+set (libphonenumber_VERSION_MINOR 0)
+
+include ( GNUInstallDirs )
# Helper functions dealing with finding libraries and programs this library
# depends on.
+include (../tools/cpp/gtest.cmake)
+
function (print_error DESCRIPTION FILE)
message (FATAL_ERROR
"Can't find ${DESCRIPTION}: can't locate ${FILE}. Please read the README.")
find_package (PkgConfig)
function (check_library_version VARNAME LIBRARY_WITH_VERSION)
if (PKG_CONFIG_FOUND)
- pkg_check_modules (${VARNAME} REQUIRED ${LIBRARY_WITH_VERSION})
+ pkg_check_modules (${VARNAME} ${LIBRARY_WITH_VERSION})
endif ()
endfunction ()
endfunction (find_required_program)
# Options that can be passed to CMake using 'cmake -DKEY=VALUE'.
+option ("BUILD_GEOCODER" "Build the offline phone number geocoder" "ON")
+option ("USE_ALTERNATE_FORMATS" "Use alternate formats" "ON")
+option ("USE_BOOST" "Use Boost" "ON")
+option ("USE_ICU_REGEXP" "Use ICU regexp engine" "ON")
option ("USE_LITE_METADATA" "Use lite metadata" "OFF")
-option ("USE_RE2" "Use RE2 instead of ICU" "OFF")
+option ("USE_RE2" "Use RE2" "OFF")
+option ("USE_STD_MAP" "Force the use of std::map" "OFF")
+
+if (${USE_ALTERNATE_FORMATS} STREQUAL "ON")
+ add_definitions ("-DI18N_PHONENUMBERS_USE_ALTERNATE_FORMATS")
+endif ()
# Find all the required libraries and programs.
-find_required_library (GTEST gtest/gtest.h gtest "Google Test framework")
+if (${USE_BOOST} STREQUAL "ON")
+ add_definitions ("-DI18N_PHONENUMBERS_USE_BOOST")
+ if (WIN32)
+ set (Boost_USE_STATIC_LIBS ON)
+ endif ()
+ find_package (Boost 1.40.0 COMPONENTS date_time system thread)
+ if (NOT Boost_FOUND)
+ print_error ("Boost Date_Time/System/Thread" "Boost")
+ endif ()
+ include_directories (${Boost_INCLUDE_DIRS})
+endif ()
+
+find_or_build_gtest ()
if (${USE_RE2} STREQUAL "ON")
find_required_library (RE2 re2/re2.h re2 "Google RE2")
set (ICU_INCLUDE_DIR ${ICU_UC_INCLUDE_DIR})
set (ICU_LIB ${ICU_UC_LIB})
-# If ICU regexp engine is used, use icui18n as well.
-if (${USE_RE2} STREQUAL "OFF")
+# If ICU regexp engine is used or if the geocoder is built, use icui18n as well.
+if (${USE_ICU_REGEXP} STREQUAL "ON" OR ${BUILD_GEOCODER} STREQUAL "ON")
find_required_library (ICU_I18N unicode/regex.h icui18n "ICU")
check_library_version (PC_ICU_I18N icu-i18n>=4.4)
list (APPEND ICU_INCLUDE_DIR ${ICU_I18N_INCLUDE_DIR})
FIND_LIBRARY (FOUNDATION_LIB Foundation)
endif ()
-INCLUDE (CheckIncludeFileCXX)
-CHECK_INCLUDE_FILE_CXX ("tr1/unordered_map" HAVE_CXX_TR1_UNORDERED_MAP)
-
-if (HAVE_CXX_TR1_UNORDERED_MAP)
- add_definitions ("-DUSE_TR1_UNORDERED_MAP")
-else ()
- CHECK_INCLUDE_FILE_CXX (hash_map HAVE_CXX_HASH_MAP)
- if (HAVE_CXX_HASH_MAP)
- add_definitions ("-DUSE_HASH_MAP")
- else ()
- print_error ("C++ map class" "tr1/unordered_map or hash_map")
+if (${USE_STD_MAP} STREQUAL "OFF")
+ INCLUDE (CheckIncludeFileCXX)
+ CHECK_INCLUDE_FILE_CXX ("tr1/unordered_map" HAVE_CXX_TR1_UNORDERED_MAP)
+ if (HAVE_CXX_TR1_UNORDERED_MAP)
+ add_definitions ("-DI18N_PHONENUMBERS_USE_TR1_UNORDERED_MAP")
endif ()
endif ()
)
set (
- PROTOBUF_OUTPUT "${CMAKE_SOURCE_DIR}/src/phonemetadata.pb.cc"
- "${CMAKE_SOURCE_DIR}/src/phonemetadata.pb.h"
- "${CMAKE_SOURCE_DIR}/src/phonenumber.pb.cc"
- "${CMAKE_SOURCE_DIR}/src/phonenumber.pb.h"
+ PROTOBUF_OUTPUT "${CMAKE_SOURCE_DIR}/src/phonenumbers/phonemetadata.pb.cc"
+ "${CMAKE_SOURCE_DIR}/src/phonenumbers/phonemetadata.pb.h"
+ "${CMAKE_SOURCE_DIR}/src/phonenumbers/phonenumber.pb.cc"
+ "${CMAKE_SOURCE_DIR}/src/phonenumbers/phonenumber.pb.h"
)
add_custom_command (
- COMMAND ${PROTOC_BIN} --cpp_out=${CMAKE_SOURCE_DIR}/src
+ COMMAND ${PROTOC_BIN} --cpp_out=${CMAKE_SOURCE_DIR}/src/phonenumbers/
--proto_path=${RESOURCES_DIR} ${PROTOBUF_SOURCES}
OUTPUT ${PROTOBUF_OUTPUT}
DEPENDS ${PROTOBUF_SOURCES}
)
-add_custom_target (
- generate-sources
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ # Geocoding data cpp file generation
+ set (TOOLS_DIR "${CMAKE_CURRENT_BINARY_DIR}/tools")
+ add_subdirectory("${CMAKE_SOURCE_DIR}/../tools/cpp" "${TOOLS_DIR}")
- DEPENDS ${PROTOBUF_OUTPUT}
- COMMENT "Generating Protocol Buffers code"
-)
+ set (GEOCODING_DIR "${RESOURCES_DIR}/geocoding")
+ file (GLOB_RECURSE GEOCODING_SOURCES "${GEOCODING_DIR}/*.txt")
+
+ set (GEOCODING_DATA_OUTPUT
+ "${CMAKE_SOURCE_DIR}/src/phonenumbers/geocoding/geocoding_data.cc"
+ )
+
+ add_custom_command (
+ COMMAND generate_geocoding_data "${GEOCODING_DIR}"
+ "${GEOCODING_DATA_OUTPUT}"
+
+ OUTPUT ${GEOCODING_DATA_OUTPUT}
+ DEPENDS ${GEOCODING_SOURCES}
+ generate_geocoding_data
+ COMMENT "Generating geocoding data code"
+ )
+endif ()
-# Platform independent sources.
set (
SOURCES
- "src/base/at_exit.cc"
- "src/base/lazy_instance.cc"
- "src/base/string_piece.cc"
- "src/base/synchronization/lock.cc"
- "src/base/threading/thread_restrictions.cc"
- "src/default_logger.cc"
- "src/logger_adapter.cc"
- "src/metadata.h" # Generated by build tools.
- "src/phonemetadata.pb.cc" # Generated by Protocol Buffers.
- "src/phonenumber.cc"
- "src/phonenumber.pb.cc" # Generated by Protocol Buffers.
- "src/phonenumberutil.cc"
- "src/regexp_cache.cc"
- "src/stringutil.cc"
- "src/utf/rune.c"
- "src/utf/unicodetext.cc"
- "src/utf/unilib.cc"
+ "src/phonenumbers/asyoutypeformatter.cc"
+ "src/phonenumbers/base/strings/string_piece.cc"
+ "src/phonenumbers/default_logger.cc"
+ "src/phonenumbers/logger.cc"
+ "src/phonenumbers/phonemetadata.pb.cc" # Generated by Protocol Buffers.
+ "src/phonenumbers/phonenumber.cc"
+ "src/phonenumbers/phonenumber.pb.cc" # Generated by Protocol Buffers.
+ "src/phonenumbers/phonenumberutil.cc"
+ "src/phonenumbers/regex_based_matcher.cc"
+ "src/phonenumbers/regexp_cache.cc"
+ "src/phonenumbers/shortnumberinfo.cc"
+ "src/phonenumbers/string_byte_sink.cc"
+ "src/phonenumbers/stringutil.cc"
+ "src/phonenumbers/unicodestring.cc"
+ "src/phonenumbers/utf/rune.c"
+ "src/phonenumbers/utf/unicodetext.cc"
+ "src/phonenumbers/utf/unilib.cc"
)
-# Add regexp engine sources. ICU is used by default.
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ set (
+ GEOCODING_SOURCES
+ "src/phonenumbers/geocoding/area_code_map.cc"
+ "src/phonenumbers/geocoding/default_map_storage.cc"
+ "src/phonenumbers/geocoding/geocoding_data.cc"
+ "src/phonenumbers/geocoding/mapping_file_provider.cc"
+ "src/phonenumbers/geocoding/phonenumber_offline_geocoder.cc"
+ "src/phonenumbers/phonenumber.pb.h" # Forces proto buffer generation.
+ )
+endif ()
+
+# Add regexp engine-dependent sources. ICU is used by default.
if (${USE_RE2} STREQUAL "ON")
- list (APPEND SOURCES "src/regexp_adapter_re2.cc")
-else ()
- list (APPEND SOURCES "src/regexp_adapter_icu.cc")
+ # Add a flag to select the right regexp factory implementation used by
+ # regexp_factory.h and regexp_adapter_test.cc.
+ # When both ICU regexp and RE2 are defined, the regexp engine adapter defaults
+ # to RE2 unless the ICU implementation is instantiated explictly obviously.
+ add_definitions ("-DI18N_PHONENUMBERS_USE_RE2")
+ list (APPEND SOURCES "src/phonenumbers/regexp_adapter_re2.cc")
+endif ()
+
+if (${USE_ICU_REGEXP} STREQUAL "ON")
+ add_definitions ("-DI18N_PHONENUMBERS_USE_ICU_REGEXP")
+ list (APPEND SOURCES "src/phonenumbers/regexp_adapter_icu.cc")
+ # The phone number matcher needs ICU.
+ list (APPEND SOURCES "src/phonenumbers/phonenumbermatch.cc")
+ list (APPEND SOURCES "src/phonenumbers/phonenumbermatcher.cc")
+ if (${USE_ALTERNATE_FORMATS} STREQUAL "ON")
+ list (APPEND SOURCES "src/phonenumbers/alternate_format.cc")
+ endif ()
endif ()
# Library sources excluding the metadata files, since special metadata is used
-# for unit-testing.
+# for unit-testing. Note that a single testing library is built for both
+# libphonenumber and geocoding.
set (TESTING_LIBRARY_SOURCES ${SOURCES})
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ list (APPEND TESTING_LIBRARY_SOURCES ${GEOCODING_SOURCES})
+endif ()
# Add metadata code generation targets.
# code generation targets.
function (add_metadata_gen_target TARGET_NAME
XML_FILE
- METADATA_TYPE)
- set (METADATA_SOURCE_DIR "${CMAKE_SOURCE_DIR}/src")
+ METADATA_TYPE
+ METADATA_HEADER)
+ set (METADATA_SOURCE_DIR "${CMAKE_SOURCE_DIR}/src/phonenumbers")
set (GEN_OUTPUT "${METADATA_SOURCE_DIR}/${METADATA_TYPE}.cc"
- "${METADATA_SOURCE_DIR}/metadata.h")
+ "${METADATA_SOURCE_DIR}/${METADATA_HEADER}.h")
set (JAR_PATH "${CMAKE_SOURCE_DIR}/../tools/java/cpp-build/target")
set (JAR_PATH "${JAR_PATH}/cpp-build-1.0-SNAPSHOT-jar-with-dependencies.jar")
add_custom_command (
COMMAND ${JAVA_BIN} -jar
- ${JAR_PATH} BuildMetadataCppFromXml ${XML_FILE} ${CMAKE_SOURCE_DIR}/src
- ${METADATA_TYPE}
+ ${JAR_PATH} BuildMetadataCppFromXml ${XML_FILE}
+ ${CMAKE_SOURCE_DIR}/src/phonenumbers ${METADATA_TYPE}
OUTPUT ${GEN_OUTPUT}
DEPENDS ${XML_FILE}
set (METADATA_TARGET "generate-lite-metadata")
add_metadata_gen_target (
${METADATA_TARGET}
- "${RESOURCES_DIR}/PhoneNumberMetaData.xml"
+ "${RESOURCES_DIR}/PhoneNumberMetadata.xml"
"lite_metadata"
+ "metadata"
)
- list (APPEND SOURCES "src/lite_metadata.cc")
+ list (APPEND SOURCES "src/phonenumbers/lite_metadata.cc")
else ()
# Add the metadata generation target.
set (METADATA_TARGET "generate-metadata")
add_metadata_gen_target (
${METADATA_TARGET}
- "${RESOURCES_DIR}/PhoneNumberMetaData.xml"
+ "${RESOURCES_DIR}/PhoneNumberMetadata.xml"
+ "metadata"
"metadata"
)
- list (APPEND SOURCES "src/metadata.cc")
+ list (APPEND SOURCES "src/phonenumbers/metadata.cc")
endif ()
# Add the test metadata generation target.
set (TEST_METADATA_TARGET "generate-test-metadata")
add_metadata_gen_target (
${TEST_METADATA_TARGET}
- "${RESOURCES_DIR}/PhoneNumberMetaDataForTesting.xml"
+ "${RESOURCES_DIR}/PhoneNumberMetadataForTesting.xml"
"test_metadata"
+ "metadata"
)
-list (APPEND TESTING_LIBRARY_SOURCES "src/test_metadata.cc")
+list (APPEND TESTING_LIBRARY_SOURCES "src/phonenumbers/test_metadata.cc")
-# Platform-specific sources.
-set (PLATFORM_SPECIFIC_SOURCES "")
-
-if (UNIX)
- if (CMAKE_COMPILER_IS_GNUCXX)
- add_definitions ("-Wall -Werror")
+# Add the short metadata generation target.
+set (SHORT_METADATA_TARGET "generate-short-number-metadata")
+add_metadata_gen_target (
+ ${SHORT_METADATA_TARGET}
+ "${RESOURCES_DIR}/ShortNumberMetadata.xml"
+ "short_metadata"
+ "short_metadata"
+)
+# This is used both for the real library and for testing.
+list (APPEND SOURCES "src/phonenumbers/short_metadata.cc")
+list (APPEND TESTING_LIBRARY_SOURCES "src/phonenumbers/short_metadata.cc")
+
+if (${USE_ICU_REGEXP} STREQUAL "ON")
+ if (${USE_ALTERNATE_FORMATS} STREQUAL "ON")
+ # Add alternate format metadata generation for the phone number matcher.
+ set (ALT_FORMAT_METADATA_TARGET "generate-alt-format-metadata")
+ add_metadata_gen_target (
+ ${ALT_FORMAT_METADATA_TARGET}
+ "${RESOURCES_DIR}/PhoneNumberAlternateFormats.xml"
+ "alternate_format"
+ "alternate_format"
+ )
+ endif ()
+endif ()
- # The next flags are needed by base/ source files to compile low level code
- # needed by Singleton.
- add_definitions ("-DCOMPILER_GCC -DOS_POSIX")
+if (NOT WIN32)
+ add_definitions ("-Wall -Werror")
+endif ()
- if (APPLE)
- add_definitions ("-DOS_MACOSX")
- else ()
- add_definitions ("-DOS_LINUX")
- endif ()
+include_directories ("src")
- if (${CMAKE_SYSTEM_PROCESSOR} MATCHES "x86.*" OR
- ${CMAKE_SYSTEM_PROCESSOR} MATCHES "i386")
- add_definitions ("-DARCH_CPU_X86_FAMILY")
- # Add GCC specific sources.
- set (GCC_SOURCES "src/base/atomicops_internals_x86_gcc.cc")
- list (APPEND PLATFORM_SPECIFIC_SOURCES ${GCC_SOURCES})
- elseif (${CMAKE_SYSTEM_PROCESSOR} MATCHES ".*arm.*")
- add_definitions ("-DARCH_CPU_ARM_FAMILY")
- endif ()
+# Build a static library (without -fPIC).
+add_library (phonenumber STATIC ${SOURCES})
+if (${USE_ICU_REGEXP} STREQUAL "ON")
+ if (${USE_ALTERNATE_FORMATS} STREQUAL "ON")
+ add_dependencies (phonenumber ${ALT_FORMAT_METADATA_TARGET})
endif ()
+endif ()
- # Add POSIX specific sources.
- set (
- POSIX_SOURCES
- "src/base/synchronization/lock_impl_posix.cc"
- "src/base/threading/platform_thread_posix.cc"
- "src/base/threading/thread_local_posix.cc"
- )
- list (APPEND PLATFORM_SPECIFIC_SOURCES ${POSIX_SOURCES})
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ add_library (geocoding STATIC ${GEOCODING_SOURCES})
+ # The geocoder doesn't use RE2 so there is no reason not to build a shared
+ # library for it.
+ add_library (geocoding-shared SHARED ${GEOCODING_SOURCES})
+ set_target_properties (geocoding-shared
+ PROPERTIES
+ OUTPUT_NAME "geocoding"
+ PREFIX "lib"
+ SOVERSION ${libphonenumber_VERSION_MAJOR}
+ VERSION ${libphonenumber_VERSION_MAJOR}.${libphonenumber_VERSION_MINOR})
+endif ()
- if (APPLE)
- set (APPLE_SOURCES "src/base/threading/platform_thread_mac.mm")
- list (APPEND PLATFORM_SPECIFIC_SOURCES ${APPLE_SOURCES})
+# Build a shared library (with -fPIC).
+set (BUILD_SHARED_LIB true)
+
+if (${USE_RE2} STREQUAL "ON")
+ # RE2 is not always available as a shared library (e.g: package provided by
+ # Ubuntu) therefore disable the shared library build in this case.
+ if (${RE2_LIB} MATCHES ".*\\.a")
+ message (WARNING
+ "RE2 not available as a shared library, shared library build disabled")
+ set (BUILD_SHARED_LIB false)
endif ()
-else (WIN32)
- # TODO: add Windows support (define COMPILER_MSVC, OS_WIN).
- set (
- WIN32_SOURCES
- "src/base/synchronization/lock_impl_win.cc"
- "src/base/threading/platform_thread_win.cc"
- "src/base/threading/thread_local_win.cc"
- )
- list (APPEND PLATFORM_SPECIFIC_SOURCES ${WIN32_SOURCES})
- # TODO: Windows specific flags.
endif ()
-# Add platform-specific sources to both versions of phonenumber library (the one
-# used by the client and the one used for testing).
-list (APPEND SOURCES ${PLATFORM_SPECIFIC_SOURCES})
-list (APPEND TESTING_LIBRARY_SOURCES ${PLATFORM_SPECIFIC_SOURCES})
-
-include_directories ("src")
-include_directories (".")
+if (BUILD_SHARED_LIB)
+ add_library (phonenumber-shared SHARED ${SOURCES})
+ if (${USE_ICU_REGEXP} STREQUAL "ON")
+ if (${USE_ALTERNATE_FORMATS} STREQUAL "ON")
+ add_dependencies (phonenumber ${ALT_FORMAT_METADATA_TARGET})
+ endif ()
+ endif ()
+ set_target_properties (phonenumber-shared
+ PROPERTIES
+ OUTPUT_NAME "phonenumber"
+ PREFIX "lib"
+ SOVERSION ${libphonenumber_VERSION_MAJOR}
+ VERSION ${libphonenumber_VERSION_MAJOR}.${libphonenumber_VERSION_MINOR})
+endif ()
-# Build a static library (without -fPIC).
-add_library (phonenumber STATIC ${SOURCES})
-add_dependencies (phonenumber generate-sources ${METADATA_TARGET})
+# Libraries used by both libphonenumber and libgeocoding.
+set (COMMON_DEPS ${ICU_LIB})
-# Build a shared library (with -fPIC).
-add_library (phonenumber-shared SHARED ${SOURCES})
-add_dependencies (phonenumber-shared generate-sources ${METADATA_TARGET})
-set_target_properties (phonenumber-shared PROPERTIES OUTPUT_NAME "phonenumber")
-set_target_properties (phonenumber-shared PROPERTIES PREFIX "lib")
+set (LIBRARY_DEPS ${PROTOBUF_LIB})
-set (LIBRARY_DEPS ${PROTOBUF_LIB} ${ICU_LIB})
+if (${USE_BOOST} STREQUAL "ON")
+ list (APPEND LIBRARY_DEPS ${Boost_LIBRARIES})
+endif ()
if (${USE_RE2} STREQUAL "ON")
list (APPEND LIBRARY_DEPS ${RE2_LIB})
endif ()
if (APPLE)
- list (APPEND LIBRARY_DEPS ${COREFOUNDATION_LIB} ${FOUNDATION_LIB})
+ list (APPEND COMMON_DEPS ${COREFOUNDATION_LIB} ${FOUNDATION_LIB})
endif ()
+list (APPEND LIBRARY_DEPS ${COMMON_DEPS})
+
target_link_libraries (phonenumber ${LIBRARY_DEPS})
-target_link_libraries (phonenumber-shared ${LIBRARY_DEPS})
+
+if (BUILD_SHARED_LIB)
+ target_link_libraries (phonenumber-shared ${LIBRARY_DEPS})
+endif ()
+
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ list (APPEND GEOCODER_DEPS ${COMMON_DEPS})
+ # Note that the subset of base/ on which the geocoder relies is implemented
+ # on top of Boost header-only libraries (e.g. scoped_ptr.hpp).
+ target_link_libraries (geocoding ${LIBRARY_DEPS})
+ target_link_libraries (geocoding-shared ${LIBRARY_DEPS})
+endif ()
# Build a specific library for testing purposes.
add_library (phonenumber_testing STATIC ${TESTING_LIBRARY_SOURCES})
target_link_libraries (phonenumber_testing ${LIBRARY_DEPS})
-add_dependencies (phonenumber_testing generate-sources ${TEST_METADATA_TARGET})
+
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ # Test geocoding data cpp files generation.
+ set (GEOCODING_TEST_DIR "${RESOURCES_DIR}/test/geocoding")
+ file (GLOB_RECURSE GEOCODING_TEST_SOURCES "${GEOCODING_TEST_DIR}/*.txt")
+
+ set (GEOCODING_TEST_DATA_OUTPUT
+ "${CMAKE_SOURCE_DIR}/test/phonenumbers/geocoding/geocoding_test_data.cc"
+ )
+
+ add_custom_command (
+ COMMAND generate_geocoding_data "${GEOCODING_TEST_DIR}"
+ "${GEOCODING_TEST_DATA_OUTPUT}" "_test"
+
+ OUTPUT ${GEOCODING_TEST_DATA_OUTPUT}
+ DEPENDS ${GEOCODING_TEST_SOURCES} generate_geocoding_data
+ COMMENT "Generating geocoding test data code"
+ )
+endif ()
+
set (TEST_SOURCES
- "src/phonenumberutil_test.cc"
- "src/regexp_adapter_test.cc"
- "src/regexp_cache_test.cc"
- "src/run_tests.cc"
- "src/stringutil_test.cc"
- "src/utf/unicodetext_test.cc"
+ "test/phonenumbers/asyoutypeformatter_test.cc"
+ "test/phonenumbers/logger_test.cc"
+ "test/phonenumbers/phonenumberutil_test.cc"
+ "test/phonenumbers/regexp_adapter_test.cc"
+ "test/phonenumbers/regexp_cache_test.cc"
+ "test/phonenumbers/run_tests.cc"
+ "test/phonenumbers/shortnumberinfo_test.cc"
+ "test/phonenumbers/stringutil_test.cc"
+ "test/phonenumbers/test_util.cc"
+ "test/phonenumbers/unicodestring_test.cc"
+ "test/phonenumbers/utf/unicodetext_test.cc"
)
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ set (GEOCODING_TEST_SOURCES
+ "test/phonenumbers/geocoding/area_code_map_test.cc"
+ "test/phonenumbers/geocoding/geocoding_data_test.cc"
+ "test/phonenumbers/geocoding/geocoding_test_data.cc"
+ "test/phonenumbers/geocoding/mapping_file_provider_test.cc"
+ "test/phonenumbers/geocoding/phonenumber_offline_geocoder_test.cc"
+ )
+ list (APPEND TEST_SOURCES ${GEOCODING_TEST_SOURCES})
+endif ()
+
+if (${USE_ICU_REGEXP} STREQUAL "ON")
+ # Add the phone number matcher tests.
+ list (APPEND TEST_SOURCES "test/phonenumbers/phonenumbermatch_test.cc")
+ list (APPEND TEST_SOURCES "test/phonenumbers/phonenumbermatcher_test.cc")
+endif ()
+
# Build the testing binary.
+include_directories ("test")
add_executable (libphonenumber_test ${TEST_SOURCES})
-target_link_libraries (
- libphonenumber_test
- phonenumber_testing ${GTEST_LIB} pthread
+set (TEST_LIBS phonenumber_testing ${GTEST_LIB})
+
+if (NOT WIN32)
+ list (APPEND TEST_LIBS pthread)
+endif ()
+
+target_link_libraries (libphonenumber_test ${TEST_LIBS})
+
+# Unfortunately add_custom_target() can't accept a single command provided as a
+# list of commands.
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ add_custom_target (test
+ COMMAND generate_geocoding_data_test
+ COMMAND libphonenumber_test
+ DEPENDS generate_geocoding_data_test libphonenumber_test
+ )
+else ()
+ add_custom_target (test
+ COMMAND libphonenumber_test
+ DEPENDS libphonenumber_test
+ )
+endif ()
+
+# Install rules.
+install (FILES
+ "src/phonenumbers/asyoutypeformatter.h"
+ "src/phonenumbers/callback.h"
+ "src/phonenumbers/logger.h"
+ "src/phonenumbers/matcher_api.h"
+ "src/phonenumbers/phonenumber.pb.h"
+ "src/phonenumbers/phonemetadata.pb.h"
+ "src/phonenumbers/phonenumberutil.h"
+ "src/phonenumbers/regexp_adapter.h"
+ "src/phonenumbers/regexp_cache.h"
+ "src/phonenumbers/shortnumberinfo.h"
+ "src/phonenumbers/unicodestring.h"
+ DESTINATION include/phonenumbers/
+)
+
+install (FILES "src/phonenumbers/utf/unicodetext.h"
+ DESTINATION include/phonenumbers/utf/)
+
+if (${USE_ICU_REGEXP} STREQUAL "ON")
+ # Install the phone number matcher headers.
+ install (FILES
+ "src/phonenumbers/phonenumbermatch.h"
+ "src/phonenumbers/phonenumbermatcher.h"
+ "src/phonenumbers/regexp_adapter.h"
+ DESTINATION include/phonenumbers/
+ )
+endif ()
+
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ install (FILES
+ "src/phonenumbers/geocoding/phonenumber_offline_geocoder.h"
+ DESTINATION include/phonenumbers/geocoding
+ )
+endif ()
+
+install (
+ FILES
+ "src/phonenumbers/base/basictypes.h"
+ "src/phonenumbers/base/template_util.h"
+ "src/phonenumbers/base/logging.h"
+ "src/phonenumbers/base/thread_checker.h"
+ DESTINATION include/phonenumbers/base/
+)
+
+install (FILES
+ "src/phonenumbers/base/memory/scoped_ptr.h"
+ "src/phonenumbers/base/memory/singleton.h"
+ "src/phonenumbers/base/memory/singleton_posix.h"
+ DESTINATION include/phonenumbers/base/memory/
)
+
+install (FILES "src/phonenumbers/base/synchronization/lock.h"
+ DESTINATION include/phonenumbers/base/synchronization/)
+
+install (TARGETS phonenumber LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR})
+
+if (BUILD_SHARED_LIB)
+ install (TARGETS phonenumber-shared LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE
+ DESTINATION ${CMAKE_INSTALL_LIBDIR})
+endif ()
+
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ install (TARGETS geocoding LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR})
+ install (TARGETS geocoding-shared LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE
+ DESTINATION ${CMAKE_INSTALL_LIBDIR})
+endif ()
+
+# Build an example program using geocoding, mainly to make sure that both
+# libraries are built properly.
+if (${BUILD_GEOCODER} STREQUAL "ON")
+ add_executable (
+ geocoding_test_program
+ "test/phonenumbers/geocoding/geocoding_test_program.cc"
+ )
+ target_link_libraries (geocoding_test_program geocoding phonenumber)
+endif ()