Unverified Commit 1d242ec1 authored by Lukas-Heiligenbrunner's avatar Lukas-Heiligenbrunner Committed by GitHub

Merge pull request #1 from madebr/pr181

Pr181
parents 0cce4352 238b6f6d
from conans import ConanFile, CMake, tools
import os
import re
import textwrap
class HelloConan(ConanFile):
name = "LibConfig"
version = "1.7.2"
class LibconfigConan(ConanFile):
name = "libconfig"
license = "GNU LESSER GENERAL PUBLIC LICENSE"
author = """Mark Lindner - Lead developer & maintainer.
Daniel Marjamäki - Enhancements & bugfixes.
......@@ -12,13 +14,19 @@ class HelloConan(ConanFile):
Matt Renaud - Enhancements & bugfixes.
JoseLuis Tallon - Enhancements & bugfixes"""
url = "hyperrealm.github.io/libconfig/"
description = "Libconfig is a simple library for processing structured configuration files, like this one. This file format is more compact and more readable than XML. And unlike XML, it is type-aware, so it is not necessary to do string parsing in application code."
topics = ("config")
description = "Libconfig is a simple library for processing structured configuration files. " \
"This file format is more compact and more readable than XML. And unlike XML, it is type-aware, " \
"so it is not necessary to do string parsing in application code."
topics = ("libconfig", "structured", "configuration", "xml", "type")
settings = "os", "compiler", "build_type", "arch"
options = {"shared": [True, False], "fPIC": [True, False]}
default_options = {"shared": False, "fPIC": False}
generators = "cmake"
exports_sources="*"
exports_sources = "*"
def set_version(self):
configure_ac = tools.load(os.path.join(self.recipe_folder, "configure.ac"))
self.version = next(re.finditer(r"AC_INIT\(libconfig,[ \t]+([0-9.]+),.*", configure_ac)).group(1)
def config_options(self):
if self.settings.os == "Windows":
......@@ -29,12 +37,20 @@ class HelloConan(ConanFile):
del self.options.fPIC
def build(self):
self.cmake = CMake(self)
self.cmake.configure(source_folder=self.build_folder)
self.cmake.build()
tools.save(os.path.join(self.build_folder, "CMakeLists.txt"), textwrap.dedent("""\
cmake_minimum_required(VERSION 2.8.12)
project(cmake_wrapper)
include("{}/conanbuildinfo.cmake")
conan_basic_setup()
add_subdirectory("{}" libconfig)
""").format(self.install_folder.replace("\\","/"), self.source_folder.replace("\\","/")))
cmake = CMake(self)
cmake.configure(source_folder=self.build_folder)
cmake.build()
def package(self):
self.cmake.install()
cmake = CMake(self)
cmake.install()
def package_info(self):
# FIXME: `libconfig` is `libconfig::libconfig` in `libconfigConfig.cmake`
......
......@@ -9,11 +9,6 @@ add_executable(c++_example2 example2.cpp )
add_executable(c++_example3 example3.cpp )
add_executable(c++_example4 example4.cpp )
target_include_directories(c++_example1 PRIVATE ${CMAKE_SOURCE_DIR}/lib)
target_include_directories(c++_example2 PRIVATE ${CMAKE_SOURCE_DIR}/lib)
target_include_directories(c++_example3 PRIVATE ${CMAKE_SOURCE_DIR}/lib)
target_include_directories(c++_example4 PRIVATE ${CMAKE_SOURCE_DIR}/lib)
target_link_libraries(c++_example1 ${libname}++ )
target_link_libraries(c++_example2 ${libname}++ )
target_link_libraries(c++_example3 ${libname}++ )
......
......@@ -8,10 +8,6 @@ add_executable(c_example1 example1.c )
add_executable(c_example2 example2.c )
add_executable(c_example3 example3.c )
target_include_directories(c_example1 PRIVATE ${CMAKE_SOURCE_DIR}/lib)
target_include_directories(c_example2 PRIVATE ${CMAKE_SOURCE_DIR}/lib)
target_include_directories(c_example3 PRIVATE ${CMAKE_SOURCE_DIR}/lib)
target_link_libraries(c_example1 ${libname} )
target_link_libraries(c_example2 ${libname} )
target_link_libraries(c_example3 ${libname} )
......@@ -37,6 +37,14 @@ endif()
add_library(${libname} ${libsrc} ${libinc})
add_library(${libname}++ ${libsrc_cpp} ${libinc_cpp})
target_include_directories(${libname} PUBLIC
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}>
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>)
target_include_directories(${libname}++ PUBLIC
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}>
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>)
set_target_properties(${libname}
PROPERTIES LINKER_LANGUAGE C
PUBLIC_HEADER "${libinc}")
......
......@@ -4,8 +4,6 @@ else()
set(libname "config")
endif()
include_directories(${CMAKE_SOURCE_DIR}/lib)
add_executable(libconfig_tests
tests.c
)
......@@ -18,5 +16,5 @@ target_link_libraries(libconfig_tests
add_test(
NAME libconfig_tests
COMMAND libconfig_tests
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/tests
WORKING_DIRECTORY ${PROJECT_SOURCE_DIR}/tests
)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment