-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Select static from both_libraries in internal dep
Add `.as_static()` method to internal dependencies. Internal dependencies can now choose between static and shared version of a `both_libraries` linked library. This allows to use the same dependency objects for building either a static or a shared library from the same hierarchy of dependencies.
- Loading branch information
Showing
16 changed files
with
153 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
## Allow the use of static version of `both_libraries` in internal dependencies | ||
|
||
Internal dependencies can now choose the static version | ||
of a `both_libraries` linked library. This allows to use the same | ||
dependency objects for building either a static or a shared library from | ||
the same hierarchy of dependencies. | ||
|
||
`dep` object returned by [[declare_dependency]] now has `.as_static()` method, | ||
to convert it to a dependency that prefer the `static` version of the linked | ||
[[both_libraries]] targets. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
int libfunc1(void) | ||
{ | ||
return 1 + NUMBER; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
EXPORTS | ||
|
||
libfunc1 @1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
int libfunc2(void) | ||
{ | ||
return 2 + NUMBER; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
EXPORTS | ||
|
||
libfunc2 @2 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
int libfunc3(void) | ||
{ | ||
return 3; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
EXPORTS | ||
|
||
libfunc3 @3 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
int libfunc4(void) | ||
{ | ||
return 4; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
int libfunc1(void); | ||
int libfunc2(void); | ||
int libfunc3(void); | ||
int libfunc4(void); | ||
|
||
int main(void) | ||
{ | ||
int sum = libfunc1() + libfunc2() + libfunc3() + libfunc4(); | ||
return sum == EXPECTED ? 0 : sum; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
project( | ||
'as_static', | ||
['c'], | ||
meson_version: '>= 1.3.0', | ||
) | ||
|
||
lib1 = library('lib1', 'lib1.c', vs_module_defs: 'lib1.def', c_static_args: ['-DNUMBER=100'], c_shared_args: ['-DNUMBER=1000']) | ||
dep1 = declare_dependency(link_with: lib1) | ||
|
||
lib2 = both_libraries('lib2', 'lib2.c', vs_module_defs: 'lib2.def', c_static_args: ['-DNUMBER=100'], c_shared_args: ['-DNUMBER=1000']) | ||
dep2 = declare_dependency(link_with: lib2) | ||
|
||
lib3 = shared_library('lib3', 'lib3.c', vs_module_defs: 'lib3.def') | ||
dep3 = declare_dependency(link_with: lib3) | ||
|
||
lib4 = static_library('lib4', 'lib4.c') | ||
dep4 = declare_dependency(link_with: lib4) | ||
|
||
|
||
if get_option('default_library') == 'static' | ||
lib1_n = 101 | ||
else | ||
lib1_n = 1001 # shared or both will use shared | ||
endif | ||
lib2_n = 1002 # shared | ||
lib3_n = 3 | ||
lib4_n = 4 | ||
|
||
expected = lib1_n + lib2_n + lib3_n + lib4_n | ||
dep_default = declare_dependency(dependencies: [dep1, dep2, dep3, dep4]) | ||
main_default = executable('main_default', 'main.c', dependencies: [dep_default], c_args: ['-DEXPECTED=@0@'.format(expected)]) | ||
test('default', main_default) | ||
|
||
|
||
if get_option('default_library') == 'shared' | ||
lib1_n = 1001 | ||
else | ||
lib1_n = 101 # static or both will use static | ||
endif | ||
lib2_n = 102 # static | ||
lib3_n = 3 | ||
lib4_n = 4 | ||
|
||
expected = lib1_n + lib2_n + lib3_n + lib4_n | ||
dep_static = declare_dependency(dependencies: [dep1, dep2, dep3, dep4]).as_static(recursive: true) | ||
main_static = executable('main_static', 'main.c', dependencies: [dep_static], c_args: ['-DEXPECTED=@0@'.format(expected)]) | ||
test('static', main_static) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
{ | ||
"matrix": { | ||
"options": { | ||
"default_library": [ | ||
{ "val": "shared" }, | ||
{ "val": "static" }, | ||
{ "val": "both" } | ||
] | ||
} | ||
} | ||
} |