Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

boost: add boost/1.75.0 #3872

Merged
merged 22 commits into from
Dec 23, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
ceb1278
boost: add boost/1.75.0
madebr Dec 12, 2020
ec8677b
boost: disable json in test_package by default
madebr Dec 12, 2020
07559df
boost: fix layout suffix on MSVC
madebr Dec 12, 2020
31941f5
boost: fix test_package
madebr Dec 12, 2020
4931e6e
boost: fix fix test_package ;)
madebr Dec 12, 2020
f89b444
boost: json requires c++11 compiler. So don't build on too old compil…
madebr Dec 13, 2020
fce828b
boost: remove unsupported options at end of config_options method
madebr Dec 13, 2020
2d6e2c3
boost: set version default c++ standard=11 for MSVC and apple-clang
madebr Dec 13, 2020
1b527a3
boost: update compiler versions having c++11 default or higher
madebr Dec 13, 2020
c6ac4a2
boost: move dlls+pdbs to bin folder + remove pdbs
madebr Dec 14, 2020
c6e96f8
boost: iOS needs BOOST_(AC|SP)_USE_PTHREADS
madebr Dec 14, 2020
78f3298
boost: I don't know what version of compiler supports c++11 of every …
madebr Dec 13, 2020
7d0b80e
boost: test availability of dependency with correct name
madebr Dec 14, 2020
3384f92
boost: add locale test
madebr Dec 14, 2020
3209e04
boost: pass root path of libiconv and icu
madebr Dec 14, 2020
7b491f6
boost: allow static icu dependency (with boost:i18n_backend=icu)
madebr Dec 15, 2020
7bad3f9
boost: add nowide option + check fiber/newide
madebr Dec 15, 2020
6171fa4
boost: fix typos + refactor utility function + uncomment -q
madebr Dec 19, 2020
3ec9036
booost: re-enable -q + layout=b2-default is equivalent to versioned o…
madebr Dec 16, 2020
ca43764
boost: build only MSVC with nowide
madebr Dec 22, 2020
3303863
boost: add include <ios>
madebr Dec 22, 2020
aaa7a89
boost: re-enable all configurations
madebr Dec 23, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions recipes/boost/all/conandata.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,12 @@ sources:
"https://sourceforge.net/projects/boost/files/boost/1.74.0/boost_1_74_0.tar.bz2"
]
sha256: "83bfc1507731a0906e387fc28b7ef5417d591429e51e788417fe9ff025e116b1"
1.75.0:
url: [
"https://dl.bintray.com/boostorg/release/1.75.0/source/boost_1_75_0.tar.bz2",
"https://sourceforge.net/projects/boost/files/boost/1.75.0/boost_1_75_0.tar.bz2"
]
sha256: "953db31e016db7bb207f11432bef7df100516eeb746843fa0486a222e3fd49cb"
patches:
SSE4 marked this conversation as resolved.
Show resolved Hide resolved
1.69.0:
- patch_file: "patches/boost_build_asmflags.patch"
Expand Down
30 changes: 19 additions & 11 deletions recipes/boost/all/conanfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
"graph",
"graph_parallel",
"iostreams",
"json",
"locale",
"log",
"math",
Expand Down Expand Up @@ -140,15 +141,20 @@ def _dependencies(self):
raise ConanException("Cannot find {}".format(dependencies_filepath))
return yaml.load(open(dependencies_filepath))

def _iter_modules(self):
tree = {k: v[:] for k, v in self._dependencies["dependencies"].items()}
while tree:
nodeps = set(k for k, v in tree.items() if not v)
if not nodeps:
raise ConanException("cyclic dependency tree detected")
for nodep in nodeps:
yield nodep
tree = {k: [d for d in v if d not in nodeps] for k, v in tree.items() if k not in nodeps}
def _all_dependent_modules(self, name):
dependencies = {name}
new_dependencies = self._dependencies["dependencies"][name]
while True:
len_before = len(dependencies)
dependencies.update(new_dependencies)
len_after = len(dependencies)
if len_before == len_after:
break
next_new_dependencies = set()
for new_dependency in new_dependencies:
next_new_dependencies.update(set(self._dependencies["dependencies"][new_dependency]))
new_dependencies = next_new_dependencies
return dependencies
madebr marked this conversation as resolved.
Show resolved Hide resolved

@property
def _source_subfolder(self):
Expand Down Expand Up @@ -1131,8 +1137,10 @@ def add_libprefix(n):
modules_seen = set()
detected_libraries = set(tools.collect_libs(self))
used_libraries = set()
for module in self._iter_modules():
if self.options.get_safe("without_{}".format(module), False) or not all(d in modules_seen for d in self._dependencies["dependencies"][module]):

for module in self._dependencies["dependencies"].keys():
missing_depmodules = list(depmodule for depmodule in self._all_dependent_modules(module) if self.options.get_safe("without_{}".format(depmodule), False))
if missing_depmodules:
continue

module_libraries = [add_libprefix(lib.format(**libformatdata)) + libsuffix for lib in self._dependencies["libs"][module]]
Expand Down
279 changes: 279 additions & 0 deletions recipes/boost/all/dependencies/dependencies-1.75.0.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,279 @@
configure_options:
- atomic
- chrono
- container
- context
- contract
- coroutine
- date_time
- exception
- fiber
- filesystem
- graph
- graph_parallel
- iostreams
- json
- locale
- log
- math
- mpi
- program_options
- python
- random
- regex
- serialization
- stacktrace
- system
- test
- thread
- timer
- type_erasure
- wave
dependencies:
atomic: []
chrono:
- system
container: []
context:
- thread
contract:
- exception
- thread
coroutine:
- context
- exception
- system
- thread
date_time: []
exception: []
fiber:
- context
- filesystem
fiber_numa:
- fiber
filesystem:
- system
graph:
- math
- random
- regex
- serialization
graph_parallel:
- filesystem
- graph
- mpi
- random
- serialization
iostreams:
- random
- regex
json:
- container
- exception
- system
locale:
- thread
log:
- atomic
- container
- date_time
- exception
- filesystem
- locale
- random
- regex
- system
- thread
log_setup:
- log
math:
- atomic
math_c99:
- math
math_c99f:
- math
math_c99l:
- math
math_tr1:
- math
math_tr1f:
- math
math_tr1l:
- math
mpi:
- graph
- serialization
mpi_python:
- mpi
- python
nowide:
- filesystem
numpy:
- python
prg_exec_monitor:
- test
program_options: []
python: []
random:
- math
- system
regex: []
serialization: []
stacktrace: []
stacktrace_addr2line:
- stacktrace
stacktrace_backtrace:
- stacktrace
stacktrace_basic:
- stacktrace
stacktrace_noop:
- stacktrace
stacktrace_windbg:
- stacktrace
stacktrace_windbg_cached:
- stacktrace
system: []
test:
- exception
test_exec_monitor:
- test
thread:
- atomic
- chrono
- container
- date_time
- exception
- system
timer:
- chrono
- system
type_erasure:
- thread
unit_test_framework:
- prg_exec_monitor
- test
- test_exec_monitor
wave:
- filesystem
- serialization
wserialization:
- serialization
libs:
atomic:
- boost_atomic
chrono:
- boost_chrono
container:
- boost_container
context:
- boost_context
contract:
- boost_contract
coroutine:
- boost_coroutine
date_time:
- boost_date_time
exception:
- boost_exception
fiber:
- boost_fiber
fiber_numa:
- boost_fiber_numa
filesystem:
- boost_filesystem
graph:
- boost_graph
graph_parallel:
- boost_graph_parallel
iostreams:
- boost_iostreams
json:
- boost_json
locale:
- boost_locale
log:
- boost_log
log_setup:
- boost_log_setup
math: []
math_c99:
- boost_math_c99
math_c99f:
- boost_math_c99f
math_c99l:
- boost_math_c99l
math_tr1:
- boost_math_tr1
math_tr1f:
- boost_math_tr1f
math_tr1l:
- boost_math_tr1l
mpi:
- boost_mpi
mpi_python:
- boost_mpi_python
nowide:
- boost_nowide
numpy:
- boost_numpy{py_major}{py_minor}
prg_exec_monitor:
- boost_prg_exec_monitor
program_options:
- boost_program_options
python:
- boost_python{py_major}{py_minor}
random:
- boost_random
regex:
- boost_regex
serialization:
- boost_serialization
stacktrace: []
stacktrace_addr2line:
- boost_stacktrace_addr2line
stacktrace_backtrace:
- boost_stacktrace_backtrace
stacktrace_basic:
- boost_stacktrace_basic
stacktrace_noop:
- boost_stacktrace_noop
stacktrace_windbg:
- boost_stacktrace_windbg
stacktrace_windbg_cached:
- boost_stacktrace_windbg_cached
system:
- boost_system
test: []
test_exec_monitor:
- boost_test_exec_monitor
thread:
- boost_thread
timer:
- boost_timer
type_erasure:
- boost_type_erasure
unit_test_framework:
- boost_unit_test_framework
wave:
- boost_wave
wserialization:
- boost_wserialization
requirements:
iostreams:
- bzip2
- lzma
- zlib
- zstd
locale:
- iconv
- icu
python:
- python
regex:
- icu
stacktrace:
- backtrace
static_only:
- boost_exception
- boost_test_exec_monitor
version: 1.75.0
Loading