Skip to content

Commit eee91f0

Browse files
authored
Merge branch 'main' into space-help-cmd-test
2 parents 180d8d6 + 6e43cdb commit eee91f0

36 files changed

+1305
-105
lines changed

app/main.f90

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,10 +8,11 @@ program main
88
fpm_test_settings, &
99
fpm_install_settings, &
1010
fpm_update_settings, &
11+
fpm_clean_settings, &
1112
get_command_line_settings
1213
use fpm_error, only: error_t
1314
use fpm_filesystem, only: exists, parent_dir, join_path
14-
use fpm, only: cmd_build, cmd_run
15+
use fpm, only: cmd_build, cmd_run, cmd_clean
1516
use fpm_cmd_install, only: cmd_install
1617
use fpm_cmd_new, only: cmd_new
1718
use fpm_cmd_update, only : cmd_update
@@ -73,6 +74,8 @@ program main
7374
call cmd_install(settings)
7475
type is (fpm_update_settings)
7576
call cmd_update(settings)
77+
type is (fpm_clean_settings)
78+
call cmd_clean(settings)
7679
end select
7780

7881
if (allocated(project_root)) then

ci/run_tests.sh

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -62,6 +62,22 @@ test ! -x ./build/gfortran_*/app/unused
6262
test ! -x ./build/gfortran_*/test/unused_test
6363
popd
6464

65+
pushd tree_shake
66+
"$fpm" build
67+
"$fpm" run
68+
"$fpm" test
69+
test ! -e ./build/gfortran_*/tree_shake/src_farewell_m.f90.o
70+
test ! -e ./build/gfortran_*/tree_shake/src_farewell_m.f90.o.log
71+
popd
72+
73+
pushd submodule_tree_shake
74+
"$fpm" run
75+
test ! -e ./build/gfortran_*/submodule_tree_shake/src_parent_unused.f90.o
76+
test ! -e ./build/gfortran_*/submodule_tree_shake/src_parent_unused.f90.o.log
77+
test ! -e ./build/gfortran_*/submodule_tree_shake/src_child_unused.f90.o
78+
test ! -e ./build/gfortran_*/submodule_tree_shake/src_child_unused.f90.o.log
79+
popd
80+
6581
pushd version_file
6682
"$fpm" build
6783
"$fpm" run

example_packages/README.md

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,8 @@ the features demonstrated in each package and which versions of fpm are supporte
2020
| makefile_complex | External build command (makefile); local path dependency | Y | N |
2121
| program_with_module | App-only; module+program in single source file | Y | Y |
2222
| submodules | Lib-only; submodules (3 levels) | N | Y |
23+
| tree_shake | Test tree-shaking/pruning of unused module dependencies | N | Y |
24+
| submodule_tree_shake| Test tree-shaking/pruning with submodules dependencies | N | Y |
2325
| link_external | Link external library | N | Y |
2426
| link_executable | Link external library to a single executable | N | Y |
2527
| version_file | Read version number from a file in the project root | N | Y |
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
build/*
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
program test
2+
use parent
3+
4+
integer :: a, b
5+
6+
call my_sub1(a)
7+
call my_sub2(b)
8+
9+
end program test
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
name = "submodule_tree_shake"
Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
submodule(parent) child1
2+
implicit none
3+
4+
interface
5+
module function my_fun() result (b)
6+
integer :: b
7+
end function my_fun
8+
end interface
9+
10+
contains
11+
12+
module procedure my_sub1
13+
a = my_fun()
14+
end procedure my_sub1
15+
16+
end submodule child1
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
submodule(parent) child2
2+
implicit none
3+
4+
contains
5+
6+
module procedure my_sub2
7+
a = 2
8+
end procedure my_sub2
9+
10+
end submodule child2
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
submodule(parent_unused) child_unused
2+
implicit none
3+
4+
contains
5+
6+
module procedure unused_sub
7+
a = 1
8+
end procedure unused_sub
9+
10+
end submodule child_unused
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
submodule(parent:child1) grandchild
2+
implicit none
3+
4+
contains
5+
6+
module procedure my_fun
7+
b = 2
8+
end procedure my_fun
9+
10+
end submodule grandchild

0 commit comments

Comments
 (0)