Added in version 3.1.
Finds the Internet Communication Engine (Ice) programs, libraries and datafiles. Ice is an open-source remote procedure call (RPC) framework developed by ZeroC and provides SDKs for various languages to develop network applications.
Added in version 3.4: Imported targets for components and many new *_EXECUTABLE variables.
Added in version 3.7: Debug and Release library variants are found separately.
Added in version 3.10: Ice 3.7 support, including new components, programs and the Nuget package.
Ice consists of several libraries and programs (executables). This find module
supports components, which can be specified using the find_package()
command, to select specific Ice libraries for use in a CMake project.
Executables provided by Ice installation are always searched automatically,
regardless of the specified components.
The list of available components depends on the Ice version in use. To successfully find Ice, at least one component must be specified:
find_package(Ice COMPONENTS <components>...)
Supported components include:
|
|
Ice 3.7 and later also include C++11-specific components:
|
|
This module provides the following Imported Targets:
Ice::<component>Added in version 3.4.
Target encapsulating the usage requirements for the specified Ice component
(library), available if that component is found. The <component> should
be written in the same case, as listed above. For example, use
Ice::Glacier2 for the Ice Glacier2 library, or Ice::Ice++11 for the
Ice++11 library, etc.
This module defines the following variables:
Ice_FOUNDBoolean indicating whether the main programs, libraries and all requested components for using Ice were found.
Ice_VERSIONThe version of Ice release found.
Ice_INCLUDE_DIRSThe include directories containing headers needed to use Ice.
Ice_LIBRARIESComponent libraries needed to link against to use Ice.
Ice_SLICE_DIRSThe data directories containing interface definitions (*.ice files) for
Slice (Specification Language for Ice).
Ice component libraries are stored in:
Ice_<COMPONENT>_FOUNDBoolean indicating whether the specified Ice component is found. The
<COMPONENT> should be written in uppercase.
Ice_<COMPONENT>_LIBRARIESLibraries provided by the specified Ice component. The <COMPONENT> should
be written in uppercase.
Slice programs are stored in:
Ice_SLICE2CONFLUENCE_EXECUTABLEAdded in version 3.14.
The path to the slice2confluence executable.
Ice_SLICE2CPP_EXECUTABLEThe path to the slice2cpp executable.
Ice_SLICE2CS_EXECUTABLEThe path to the slice2cs executable.
Ice_SLICE2FREEZEJ_EXECUTABLEThe path to the slice2freezej executable.
Ice_SLICE2FREEZE_EXECUTABLEThe path to the slice2freeze executable.
Ice_SLICE2HTML_EXECUTABLEThe path to the slice2html executable.
Ice_SLICE2JAVA_EXECUTABLEThe path to the slice2java executable.
Ice_SLICE2JS_EXECUTABLEAdded in version 3.4.
The path to the slice2js executable.
Ice_SLICE2MATLAB_EXECUTABLEAdded in version 3.14.
The path to the slice2matlab executable.
Ice_SLICE2OBJC_EXECUTABLEAdded in version 3.10.
The path to the slice2objc executable.
Ice_SLICE2PHP_EXECUTABLEThe path to the slice2php executable.
Ice_SLICE2PY_EXECUTABLEThe path to the slice2py executable.
Ice_SLICE2RB_EXECUTABLEThe path to the slice2rb executable.
Ice programs are stored in:
Ice_GLACIER2ROUTER_EXECUTABLEAdded in version 3.4.
The path to the glacier2router executable.
Ice_ICEBOX_EXECUTABLEAdded in version 3.4.
The path to the icebox executable.
Ice_ICEBOX++11_EXECUTABLEAdded in version 3.10.
The path to the icebox++11 executable.
Ice_ICEBOXADMIN_EXECUTABLEAdded in version 3.4.
The path to the iceboxadmin executable.
Ice_ICEBOXD_EXECUTABLEAdded in version 3.4.
The path to the iceboxd executable.
Ice_ICEBOXNET_EXECUTABLEAdded in version 3.4.
The path to the iceboxnet executable.
Ice_ICEBRIDGE_EXECUTABLEAdded in version 3.10.
The path to the icebridge executable.
Ice_ICEGRIDADMIN_EXECUTABLEAdded in version 3.4.
The path to the icegridadmin executable.
Ice_ICEGRIDDB_EXECUTABLEAdded in version 3.10.
The path to the icegriddb executable.
Ice_ICEGRIDNODE_EXECUTABLEAdded in version 3.4.
The path to the icegridnode executable.
Ice_ICEGRIDNODED_EXECUTABLEAdded in version 3.4.
The path to the icegridnoded executable.
Ice_ICEGRIDREGISTRY_EXECUTABLEAdded in version 3.4.
The path to the icegridregistry executable.
Ice_ICEGRIDREGISTRYD_EXECUTABLEAdded in version 3.4.
The path to the icegridregistryd executable.
Ice_ICEPATCH2CALC_EXECUTABLEThe path to the icepatch2calc executable.
Ice_ICEPATCH2CLIENT_EXECUTABLEAdded in version 3.4.
The path to the icepatch2client executable.
Ice_ICEPATCH2SERVER_EXECUTABLEAdded in version 3.4.
The path to the icepatch2server executable.
Ice_ICESERVICEINSTALL_EXECUTABLEAdded in version 3.4.
The path to the iceserviceinstall executable.
Ice_ICESTORMADMIN_EXECUTABLEAdded in version 3.4.
The path to the icestormadmin executable.
Ice_ICESTORMDB_EXECUTABLEAdded in version 3.10.
The path to the icestormdb executable.
Ice_ICESTORMMIGRATE_EXECUTABLEAdded in version 3.4.
The path to the icestormmigrate executable.
Ice database programs are stored in the following variables (on Windows, they are included with the Ice installation; on other platforms, they are usually available through standard Berkeley DB packages):
Ice_DB_ARCHIVE_EXECUTABLEAdded in version 3.4.
The path to the db_archive executable.
Ice_DB_CHECKPOINT_EXECUTABLEAdded in version 3.4.
The path to the db_checkpoint executable.
Ice_DB_DEADLOCK_EXECUTABLEAdded in version 3.4.
The path to the db_deadlock executable.
Ice_DB_DUMP_EXECUTABLEAdded in version 3.4.
The path to the db_dump executable.
Ice_DB_HOTBACKUP_EXECUTABLEAdded in version 3.4.
The path to the db_hotbackup executable.
Ice_DB_LOAD_EXECUTABLEAdded in version 3.4.
The path to the db_load executable.
Ice_DB_LOG_VERIFY_EXECUTABLEAdded in version 3.4.
The path to the db_log_verify executable.
Ice_DB_PRINTLOG_EXECUTABLEAdded in version 3.4.
The path to the db_printlog executable.
Ice_DB_RECOVER_EXECUTABLEAdded in version 3.4.
The path to the db_recover executable.
Ice_DB_STAT_EXECUTABLEAdded in version 3.4.
The path to the db_stat executable.
Ice_DB_TUNER_EXECUTABLEAdded in version 3.4.
The path to the db_tuner executable.
Ice_DB_UPGRADE_EXECUTABLEAdded in version 3.4.
The path to the db_upgrade executable.
Ice_DB_VERIFY_EXECUTABLEAdded in version 3.4.
The path to the db_verify executable.
Ice_DUMPDB_EXECUTABLEAdded in version 3.4.
The path to the dumpdb executable.
Ice_TRANSFORMDB_EXECUTABLEAdded in version 3.4.
The path to the transformdb executable.
The following cache variables may also be set:
Ice_<PROGRAM>_EXECUTABLEThe path to the specified <PROGRAM> executable; The <PROGRAM> is the
uppercase name of the Ice program as listed in above result variables of
executables.
Ice_INCLUDE_DIRThe directory containing Ice headers.
Ice_SLICE_DIRThe data directory containing interface definitions for Slice.
Ice_<COMPONENT>_LIBRARYThe path to the library for the specified component. The <COMPONENT>
should be written in uppercase.
This module accepts the following variables:
Ice_HOMESet this CMake variable to the root of the Ice installation in order to search for Ice in a custom location.
Note
On Windows, Ice 3.7.0 and later provide libraries via the NuGet
package manager. Appropriate NuGet packages will be searched for
using CMAKE_PREFIX_PATH, or alternatively Ice_HOME may be
set to the location of a specific NuGet package to restrict the search.
ICE_HOMEEnvironment variable (uppercased) may also be set to the root of the Ice
installation; The Ice_HOME CMake variable takes precedence.
Ice_DEBUGSet this variable to boolean true to enable debug output from this module.
Note
In most cases, none of the above variables need to be set unless multiple Ice
versions are installed and a specific one is required. On Windows, the most
recent version is typically found using the registry. On Unix-like systems,
programs, headers, and libraries are usually found in standard locations,
although Ice_SLICE_DIRS might not be detected automatically (commonly
known locations are searched). All other variables default based on the value
of Ice_HOME, if set.
It's also possible to set Ice_HOME while selectively overriding specific
locations for individual components; This might be required, for example, in
newer versions of Visual Studio if the heuristics are not sufficient to
identify the correct programs and libraries for the specific Visual Studio
version.
Finding the Ice core library and linking it to a project target:
find_package(Ice COMPONENTS Ice)
target_link_libraries(project_target PRIVATE Ice::Ice)
Finding Ice core library and IceSSL library, and linking them to a project target:
find_package(Ice COMPONENTS Ice IceSSL)
target_link_libraries(project_target PRIVATE Ice::Ice Ice::IceSSL)
Finding Ice core library as required component and Ice Freeze library as optional:
find_package(Ice COMPONENTS Ice OPTIONAL_COMPONENTS Freeze)