# - Find the LEF/DEF includes and libraries. # The following variables are set if LEF/DEF is found. If LEF/DEF is not # found, LEFDEF_FOUND is set to false. # LEFDEF_FOUND - True when LEF/DEF is found. # LEFDEF_INCLUDE_DIR - the path to where the LEF/DEF include files are. # LEFDEF_LIBRARIES - The path to where the LEF/DEF library files are. # # The DEF C API library: LEFDEF_CDEF_LIBRARY # LEFDEF_CDEF_LIBRARY_RELEASE # # The DEF C API library (zlib) : LEFDEF_ZCDEF_LIBRARY # LEFDEF_ZCDEF_LIBRARY_RELEASE # # The DEF C++ API library: LEFDEF_DEF_LIBRARY # LEFDEF_DEF_LIBRARY_RELEASE # # The DEF C++ API library (zlib) : LEFDEF_ZDEF_LIBRARY # LEFDEF_ZDEF_LIBRARY_RELEASE # # The LEF C API library: LEFDEF_CLEF_LIBRARY # LEFDEF_CLEF_LIBRARY_RELEASE # # The LEF C API library (zlib) : LEFDEF_ZCLEF_LIBRARY # LEFDEF_ZCLEF_LIBRARY_RELEASE # # The LEF C++ API library: LEFDEF_LEF_LIBRARY # LEFDEF_LEF_LIBRARY_RELEASE # # The LEF C++ API library (zlib) : LEFDEF_ZLEF_LIBRARY # LEFDEF_ZLEF_LIBRARY_RELEASE # Try to find a reasonable CORIOLIS_TOP value. if( NOT("$ENV{CORIOLIS_USER_TOP}" STREQUAL "") ) set ( CORIOLIS_USER_TOP "$ENV{CORIOLIS_USER_TOP}" ) else( NOT("$ENV{CORIOLIS_USER_TOP}" STREQUAL "") ) if( NOT("$ENV{CORIOLIS_TOP}" STREQUAL "") ) set ( CORIOLIS_TOP "$ENV{CORIOLIS_TOP}" ) endif( NOT("$ENV{CORIOLIS_TOP}" STREQUAL "") ) endif( NOT("$ENV{CORIOLIS_USER_TOP}" STREQUAL "") ) macro( _find_lefdef_lib varname libname ) find_library( LEFDEF_${varname}_LIBRARY_RELEASE NAMES ${libname} PATHS ${LEFDEF_LIBRARY_DIR} ) if( LEFDEF_${varname}_LIBRARY_RELEASE ) set( LEFDEF_${varname}_LIBRARY_DEBUG ${LEFDEF_${varname}_LIBRARY_RELEASE} CACHE STRING "Path to a library" FORCE ) endif() if( LEFDEF_${varname}_LIBRARY_RELEASE ) list( APPEND LEFDEF_LIBRARIES "optimized" ${LEFDEF_${varname}_LIBRARY_RELEASE} "debug" ${LEFDEF_${varname}_LIBRARY_DEBUG} ) set( LEFDEF_${varname}_LIBRARY_FOUND 1 ) mark_as_advanced( LEFDEF_${varname}_LIBRARY_RELEASE LEFDEF_${varname}_LIBRARY_DEBUG ) else() set ( LEFDEF_FOUND "NO" ) endif() endmacro() set( LEFDEF_INCLUDE_DIR_DESCRIPTION "directory containing the LEF/DEF include files. E.g /opt/lefdef-5.6/include" ) set( LEFDEF_LIBRARY_DIR_DESCRIPTION "directory containing the LEF/DEF library files. E.g /opt/lefdef-5.6/lib" ) set( LEFDEF_DIR_MESSAGE "Set the LEFDEF_INCLUDE_DIR cmake cache entry to the ${LEFDEF_INCLUDE_DIR_DESCRIPTION}" ) # Don't even bother under Win32 if( UNIX ) set( LEFDEF_FOUND "YES" ) set( LEFDEF_SEARCH_PATH "$ENV{CORIOLIS_TOP}" "$ENV{LEFDEF_TOP}" "/usr" "/opt/lefdef-5.8" "/opt/lefdef-5.7" "/opt/lefdef-5.6" "/opt/lefdef" "$ENV{HOME}/oa/lefdef/5.7-s038" "/soc/oa" ) message( "-- Components of LEFDEF_DIR_SEARCH:" ) foreach( PATH ${LEFDEF_SEARCH_PATH} ) message( "-- ${PATH}" ) endforeach() set( LEFDEF_LIBRARIES "" ) set( LEFDEF_LIBRARY_SEARCH_PATH "" ) find_path( LEFDEF_INCLUDE_DIR NAMES "defiDefs.hpp" PATHS ${LEFDEF_SEARCH_PATH} PATH_SUFFIXES "include/lefdef" "include" DOC "The ${LEFDEF_INCLUDE_DIR_DESCRIPTION}" ) message( STATUS "LEFDEF_INCLUDE_DIR: ${LEFDEF_INCLUDE_DIR}" ) find_path( LEFDEF_LIBRARY_DIR NAMES "libdef.so" PATHS ${LEFDEF_SEARCH_PATH} PATH_SUFFIXES "lib64" "lib" DOC "The ${LEFDEF_LIBRARY_DIR_DESCRIPTION}" ) message( STATUS "LEFDEF_LIBRARY_DIR: ${LEFDEF_LIBRARY_DIR}" ) if( LEFDEF_INCLUDE_DIR AND LEFDEF_LIBRARY_DIR ) #_find_lefdef_lib( "CDEF" "cdef" ) #_find_lefdef_lib( "ZCDEF" "cdefzlib" ) _find_lefdef_lib( "DEF" "def" ) _find_lefdef_lib( "ZDEF" "defzlib" ) #_find_lefdef_lib( "CLEF" "clef" ) #_find_lefdef_lib( "ZCLEF" "clefzlib" ) _find_lefdef_lib( "LEF" "lef" ) _find_lefdef_lib( "ZLEF" "lefzlib" ) else() set( LEFDEF_FOUND "NO" ) endif() if( LEFDEF_FOUND ) add_definitions( -DHAVE_LEFDEF ) if( NOT LEFDEF_FIND_QUIETLY ) message( STATUS "Found LEF/DEF" ) endif() else( LEFDEF_FOUND ) set( LEFDEF_LIBRARIES "" ) set( LEFDEF_INCLUDE_DIR "" ) set( LEFDEF_LIBRARY_DIR "" ) if( LEFDEF_FIND_REQUIRED ) message( STATUS "LEF/DEF libraries and/or includes NOT found!" ) endif() endif( LEFDEF_FOUND ) mark_as_advanced( LEFDEF_INCLUDE_DIR LEFDEF_LIBRARY_DIR LEFDEF_LIBRARIES ) endif( UNIX )