Skip to content

Commit

Permalink
dokan_fuse: Add libfuse-compatible pkg-config
Browse files Browse the repository at this point in the history
Generate a pkg-config-file that can be used as a drop-in "replacement"
for libfuse, i.e.
$ pkg-config --libs --cflags fuse
will return the dokanfuse-flags.

Closes #338.
  • Loading branch information
Rondom committed Oct 26, 2016
1 parent bbf256e commit 140066d
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 0 deletions.
31 changes: 31 additions & 0 deletions dokan_fuse/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,41 @@ if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE "Release" CACHE STRING "Choose the type of build, options are: Debug Release RelWithDebInfo MinSizeRel." FORCE)
endif(NOT CMAKE_BUILD_TYPE)

option(FUSE_PKG_CONFIG "Install a libfuse-compatible pkg-config file (fuse.pc)" ON)

set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -mwin32 -Wall")
add_definitions(-D_FILE_OFFSET_BITS=64)
include_directories(
${CMAKE_CURRENT_SOURCE_DIR}/include
${CMAKE_CURRENT_SOURCE_DIR}/../sys
)

if(FUSE_PKG_CONFIG)
# Defining helper-function to deal with setups that manually set an
# absolute path for CMAKE_INSTALL_(LIB|INCLUDE)DIR...
# We could also just make all paths absolute, but this way the
# pkg-config-file is more human-readable and pkg-config may be able to deal
# with varying prefixes.
# CMake does not have a ternary operator for generator expressions, so this
# looks more complicated than it is.
function ( make_pkg_config_absolute out_path in_path )
if(IS_ABSOLUTE "${${in_path}}")
set(${out_path} "${${in_path}}" PARENT_SCOPE)
else()
set(${out_path} "\${prefix}/${${in_path}}" PARENT_SCOPE)
endif()
endfunction()

set(pkg_config_file "${CMAKE_CURRENT_BINARY_DIR}/fuse.pc")
make_pkg_config_absolute(PKG_CONFIG_LIBDIR CMAKE_INSTALL_LIBDIR)
make_pkg_config_absolute(PKG_CONFIG_INCLUDEDIR CMAKE_INSTALL_INCLUDEDIR)
CONFIGURE_FILE(
"${CMAKE_CURRENT_SOURCE_DIR}/pkg-config.pc.in"
${pkg_config_file}
@ONLY
)
endif()

file(GLOB sources src/*.cpp src/*.c src/*.rc)
set(install_headers
include/fuse.h
Expand All @@ -30,6 +58,9 @@ add_library(dokanfuse1 SHARED ${sources})

INSTALL(FILES ${install_headers} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/fuse/)
INSTALL(FILES ${compat_headers} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
if(FUSE_PKG_CONFIG)
INSTALL(FILES ${pkg_config_file} DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig)
endif()
INSTALL(TARGETS dokanfuse1
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
Expand Down
13 changes: 13 additions & 0 deletions dokan_fuse/pkg-config.pc.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
prefix=@CMAKE_INSTALL_PREFIX@
exec_prefix=${prefix}
libdir=@PKG_CONFIG_LIBDIR@
includedir=@PKG_CONFIG_INCLUDEDIR@

Name: Dokan FUSE
Description: FUSE-API compatibility library for the Dokan user mode filesystem driver for Windows
# Dokan FUSE provides compatibility with libfuse 2.6.x.
# The corresponding libfuse-version is therefore reported instead of the Dokan FUSE-version
Version: 2.6.0
URL: https://dokan-dev.github.io
Libs: -L${libdir} -l@PROJECT_NAME@
Cflags: -I${includedir} -D_FILE_OFFSET_BITS=64

0 comments on commit 140066d

Please sign in to comment.