Skip to content

Commit

Permalink
Updated cgns to 4.3.0, plus some recipe fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
paulharris committed May 26, 2022
1 parent b4b92c3 commit 62b7461
Show file tree
Hide file tree
Showing 15 changed files with 227 additions and 5 deletions.
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import os
from conans import ConanFile, CMake, tools
from conan.tools.files import rename


required_conan_version = ">=1.29.1"
Expand All @@ -9,7 +10,7 @@ class CgnsConan(ConanFile):
name = "cgns"
description = "Standard for data associated with the numerical solution " \
"of fluid dynamics equations."
topics = ("conan", "cgns", "data", "cfd", "fluids")
topics = ("cgns", "data", "cfd", "fluids")
homepage = "http://cgns.org/"
license = "Zlib"
url = "https://github.com/conan-io/conan-center-index"
Expand Down Expand Up @@ -49,11 +50,11 @@ def configure(self):

def requirements(self):
if self.options.with_hdf5:
self.requires("hdf5/1.12.0")
self.requires("hdf5/1.12.1")

def source(self):
tools.get(**self.conan_data["sources"][self.version])
os.rename("CGNS-" + self.version, self._source_subfolder)
rename(self, "CGNS-" + self.version, self._source_subfolder)

def _configure_cmake(self):
if self._cmake:
Expand Down Expand Up @@ -87,6 +88,7 @@ def package(self):
os.remove(os.path.join(self.package_folder, "include", "cgnsBuild.defs"))

def package_info(self):
self.cpp_info.builddirs = [os.path.join("lib","cmake","cgns")]
self.cpp_info.libs = ["cgnsdll" if self.settings.os == "Windows" and self.options.shared else "cgns"]
if self.settings.os == "Windows" and self.options.shared:
self.cpp_info.defines = ["CGNSDLL=__declspec(dllimport)"] # we could instead define USE_DLL but it's too generic
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,6 @@ def build(self):
cmake.build()

def test(self):
if not tools.cross_building(self.settings):
if not tools.cross_building(self):
bin_path = os.path.join("bin", "test_package")
self.run(bin_path, run_environment=True)
8 changes: 8 additions & 0 deletions recipes/cgns/4.x.x/conandata.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
sources:
"4.3.0":
url: "https://github.com/CGNS/CGNS/archive/v4.3.0.tar.gz"
sha256: "7709eb7d99731dea0dd1eff183f109eaef8d9556624e3fbc34dc5177afc0a032"
patches:
"4.3.0":
- patch_file: "patches/4.3.0-fixes.patch"
base_path: "source_subfolder"
141 changes: 141 additions & 0 deletions recipes/cgns/4.x.x/conanfile.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,141 @@
import os
from conan import ConanFile
from conan.tools.cmake import CMakeToolchain, CMake, cmake_layout
from conan.tools.files import apply_conandata_patches

# TODO upgrade to new conan.* imports
# not using the new get() yet: it seems to ignore the download cache (1.48.0)
from conans.tools import get, remove_files_by_mask, rmdir, dos2unix


required_conan_version = ">=1.47.0"


class CgnsConan(ConanFile):
name = "cgns"
description = "Standard for data associated with the numerical solution " \
"of fluid dynamics equations."
topics = ("cgns", "data", "cfd", "fluids")
homepage = "http://cgns.org/"
license = "Zlib"
url = "https://github.com/conan-io/conan-center-index"
settings = "os", "compiler", "build_type", "arch"
generators = "CMakeDeps"
options = {
"shared": [True, False],
"fPIC": [True, False],
"with_hdf5": [True, False],
"parallel": [True, False]
}
default_options = {
"shared": False,
"fPIC": True,
"with_hdf5": True,
"parallel": False,
}

@property
def _source_subfolder(self):
return "source_subfolder"

def config_options(self):
if self.settings.os == "Windows":
del self.options.fPIC

def configure(self):
if self.options.shared:
del self.options.fPIC
del self.settings.compiler.libcxx
del self.settings.compiler.cppstd

if self.options.parallel:
self.options["hdf5"].parallel = True
self.options["hdf5"].enable_cxx = False # can't enable this with parallel

def requirements(self):
if self.options.with_hdf5:
self.requires("hdf5/1.12.1")

def validate(self):
if self.options.parallel and not self.options.with_hdf5:
raise ConanInvalidConfiguration("Parallel requires HDF5 with parallel enabled")

def source(self):
get(**self.conan_data["sources"][self.version],
strip_root=True,
destination=self._source_subfolder)

def export_sources(self):
for patch in self.conan_data.get("patches", {}).get(self.version, []):
self.copy(patch["patch_file"])

def layout(self):
cmake_layout(self)

def generate(self):
tc = CMakeToolchain(self)

tc.variables["CMAKE_DEBUG_FIND_MODE"] = True
tc.variables["CGNS_ENABLE_TESTS"] = False
tc.variables["CGNS_BUILD_TESTING"] = False
tc.variables["CGNS_ENABLE_FORTRAN"] = False
tc.variables["CGNS_ENABLE_HDF5"] = self.options.with_hdf5
tc.variables["CGNS_BUILD_SHARED"] = self.options.shared
tc.variables["CGNS_USE_SHARED"] = self.options.shared
tc.variables["CGNS_ENABLE_PARALLEL"] = self.options.parallel
tc.variables["CGNS_BUILD_CGNSTOOLS"] = False

# Other flags, seen in appveyor.yml in source code, not currently managed.
# CGNS_ENABLE_LFS:BOOL=OFF --- note in code: needed on 32 bit systems
# CGNS_ENABLE_SCOPING:BOOL=OFF --- disabled in VTK's bundle
# HDF5_NEED_ZLIB:BOOL=ON -- should be dealt with by cmake auto dependency management or something?

tc.generate()


def build(self):
cmake = CMake(self)
if self.should_configure:
# conan complains about CRLF in this file, so fix it up
dos2unix(os.path.join(self.source_folder,self._source_subfolder,"src","cgnstools","common", "winhtml.c"))
apply_conandata_patches(self)
cmake.configure(build_script_folder=self._source_subfolder)
if self.should_build:
cmake.build()
# OLD WAY: cmake.build(target="cgns_shared" if self.options.shared else "cgns_static")


def package(self):
cmake = CMake(self)
cmake.install()

self.copy("license.txt", dst="licenses", src=self._source_subfolder)

# TODO do we need to export the variables in the generated cgnsBuild.defs ?
# These would/could be used in consumers of the library...
# Perhaps generate a conan-official-{}-variables.cmake file with these items?
# From the file:
#-----------------------------------------------------------------------
# CGNS library build options. A 1 indicates that the library
# was built with that option, a 0 indicates without
# CGNS_DEBUG = debug
# CGNS_LEGACY = legacy code (prior to 3.0)
# CGNS_SCOPING = scoping of enums
# CGNS_64BIT = 64 bit support
# CGNS_FORTRAN = Fortran interface
# CGNS_PARALLEL = parallel I/O
# CGNS_BASESCOPE = Base scope for family and zone reference-to
#-----------------------------------------------------------------------

# And then delete the .defs file
remove_files_by_mask(os.path.join(self.package_folder, "include"), "cgnsBuild.defs")

# And delete the original cmake files, conan will sort that out
rmdir(os.path.join(self.package_folder, "lib", "cmake"))


def package_info(self):
# self.cpp_info.builddirs = [os.path.join("lib","cmake","cgns")]
self.cpp_info.libs = ["cgnsdll" if self.settings.os == "Windows" and self.options.shared else "cgns"]
if self.settings.os == "Windows" and self.options.shared:
self.cpp_info.defines = ["CGNSDLL=__declspec(dllimport)"] # we could instead define USE_DLL but it's too generic
22 changes: 22 additions & 0 deletions recipes/cgns/4.x.x/patches/4.3.0-fixes.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 103cb1f..aae21a7 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -674,7 +674,9 @@ if(CGNS_BUILD_SHARED)
endif()


+if(NOT CGNS_BUILD_SHARED)
set (install_targets cgns_static)
+endif()
if(CGNS_BUILD_SHARED)
set(install_targets ${install_targets} cgns_shared)
endif ()
@@ -738,7 +740,6 @@ install(EXPORT cgns-targets
# Tools #
#########

-add_subdirectory(tools)

#########
# Tests #
8 changes: 8 additions & 0 deletions recipes/cgns/4.x.x/test_package/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
cmake_minimum_required(VERSION 3.1)
project(test_package CXX)

include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
conan_basic_setup()

add_executable(test_package test_package.cpp)
target_link_libraries(test_package ${CONAN_LIBS})
18 changes: 18 additions & 0 deletions recipes/cgns/4.x.x/test_package/conanfile.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import os

from conans import ConanFile, CMake, tools


class CgnsTestConan(ConanFile):
settings = "os", "compiler", "build_type", "arch"
generators = "cmake"

def build(self):
cmake = CMake(self)
cmake.configure()
cmake.build()

def test(self):
if not tools.cross_building(self):
bin_path = os.path.join("bin", "test_package")
self.run(bin_path, run_environment=True)
21 changes: 21 additions & 0 deletions recipes/cgns/4.x.x/test_package/test_package.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
#include <cgnslib.h>

#include <cstdio>

int main() {
int indexFile;
int indexBase;

cg_open("test.cgns", CG_MODE_WRITE, &indexFile);

cg_base_write(indexFile, "Base2D", 2, 3, &indexBase);

// test a global variable
printf("MassUnits: ");
for (unsigned i = 0; i < NofValidMassUnits; ++i) {
printf("%s ", MassUnitsName[i]);
}
printf("\n");

return 0;
}
4 changes: 3 additions & 1 deletion recipes/cgns/config.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
versions:
"3.4.1":
folder: all
folder: 3.x.x
"4.3.0":
folder: 4.x.x

0 comments on commit 62b7461

Please sign in to comment.