summaryrefslogtreecommitdiffstats
path: root/cmake/Modules/CMakeMacroLibtoolFile.cmake
diff options
context:
space:
mode:
Diffstat (limited to 'cmake/Modules/CMakeMacroLibtoolFile.cmake')
-rw-r--r--cmake/Modules/CMakeMacroLibtoolFile.cmake60
1 files changed, 32 insertions, 28 deletions
diff --git a/cmake/Modules/CMakeMacroLibtoolFile.cmake b/cmake/Modules/CMakeMacroLibtoolFile.cmake
index fb27df12..4a7c0c0b 100644
--- a/cmake/Modules/CMakeMacroLibtoolFile.cmake
+++ b/cmake/Modules/CMakeMacroLibtoolFile.cmake
@@ -1,75 +1,79 @@
macro(libtool_create_control_file _target)
- # Get target properties to fill into control file
get_target_property(_target_location ${_target} LOCATION)
get_target_property(_target_type ${_target} TYPE)
message("-- Creating static libtool control file for target ${_target}")
- # No support for shared libraries as tigervnc only needs libtool config files
- # for static libraries
+ # No support for shared libraries, as TigerVNC only needs libtool config
+ # files for static libraries.
if("${_target_type}" MATCHES "^[^STATIC_LIBRARY]$")
- message(ERROR " - trying to use libtool_create_control_file on non static library target.")
+ message(ERROR " - trying to use libtool_create_control_file for non-static library target.")
endif()
#
- # Parse the target_LIB_DEPENDS of libraries to put into libtool control file
- # as library dependencies and handle a few corners...
+ # Parse the target_LIB_DEPENDS variable to determine which libraries to put
+ # into libtool control file as library dependencies, and handle a few corner
+ # cases.
#
foreach(library ${${_target}_LIB_DEPENDS})
- # Assume all entries as shared if not platform specific static library
- # extension is matched
+ # Assume all entries are shared libs if platform-specific static library
+ # extension is not matched.
if("${library}" MATCHES "[^.+\\${CMAKE_STATIC_LIBRARY_SUFFIX}]$")
- # Check if we have shared extenstion or not
if("${library}" MATCHES ".+\\${CMAKE_SHARED_LIBRARY_SUFFIX}$")
- # We got an shared library lets cut it down to path and library name then
- # add to libtool dependency libs, we always assume this is a absoult path
- # because this is how cmake does..
+ # Shared library extension matched, so extract the path and library
+ # name, then add the result to the libtool dependency libs. This
+ # will always be an absolute path, because that's what CMake uses
+ # internally.
get_filename_component(_shared_lib ${library} NAME_WE)
get_filename_component(_shared_lib_path ${library} PATH)
string(REPLACE "lib" "" _shared_lib ${_shared_lib})
set(_target_dependency_libs "${_target_dependency_libs} -L${_shared_lib_path} -l${_shared_lib}")
else()
- # No shared library suffix found, might also be a cmake target.
- # Dont continue if we have a target name as lib due to we
- # assume static linkage against out targets
+ # No shared library extension matched. Check whether target is a CMake
+ # target.
get_target_property(_ltp ${library} TYPE)
if(${_ltp})
- # No cmake target soo let's use find_library to see if we found any useful to use
+ # Not a CMake target, so use find_library() to attempt to locate the
+ # library in a system directory.
find_library(FL ${library})
if(FL)
- # Found library, lets cut it down to make libtool happy
+ # Found library, so extract the path and library name, then add the
+ # result to the libtool dependency libs.
get_filename_component(_shared_lib ${FL} NAME_WE)
get_filename_component(_shared_lib_path ${FL} PATH)
string(REPLACE "lib" "" _shared_lib ${_shared_lib})
set(_target_dependency_libs "${_target_dependency_libs} -L${_share_lib_path} -l${_shared_lib}")
else()
- # Nothing found, lets ignore it
+ # No shared library found, so ignore target.
endif()
else()
- # taget detected lets ignore it
+ # Target is a CMake target, so ignore if (CMake targets are static
+ # libs in TigerVNC.)
endif()
endif()
else()
- # Detected a static library, we want the absolute path so lets check if we have that
- # if not try use find_library to get one
+ # Detected a static library. Check whether the library pathname is
+ # absolute and, if not, use find_library() to get the abolute path.
get_filename_component(_name ${library} NAME)
string(REPLACE "${_name}" "" _path ${library})
if(NOT "${_path}" MATCHES "")
- # We got a full path to static library lets add as is to libtool library dependencies
+ # Pathname is absolute, so add it to the libtool library dependencies
+ # as-is.
set(_target_dependency_libs "${_target_dependency_libs} ${library}")
else()
- # there no path for the static library lets use find_library to find one
+ # Pathname is not absolute, so use find_library() to get the absolute
+ # path.
find_library(FL ${library})
if(FL)
- # got the library lets add it..
+ # Absolute pathname found. Add it.
set(_target_dependency_libs "${_target_dependency_libs} ${FL}")
else()
- # Nothing found, let's ignore it
+ # No absolute pathname found. Ignore it.
endif()
endif()
endif()
endforeach()
- # Write the libtool control file for static library
+ # Write the libtool control file for the static library
get_filename_component(_lname ${_target_location} NAME_WE)
set(_laname ${CMAKE_CURRENT_BINARY_DIR}/${_lname}.la)
@@ -90,8 +94,8 @@ macro(libtool_create_control_file _target)
file(APPEND ${_laname} "libdir=''\n\n")
- # Add custom command to symlink the static library so that autotools finds the library in .libs
- # these are executed after the specified target build.
+ # Add custom command to symlink the static library so that autotools finds
+ # the library in .libs. These are executed after the specified target build.
add_custom_command(TARGET ${_target} POST_BUILD COMMAND
cmake -E make_directory "${CMAKE_CURRENT_BINARY_DIR}/.libs")
add_custom_command(TARGET ${_target} POST_BUILD COMMAND