|
1 | 1 |
|
2 | 2 |
|
3 | 3 | function(get_guile_env) |
4 | | - set(_GNC_MODULE_PATH ${LIBDIR_BUILD}:${LIBDIR_BUILD}/gnucash) |
| 4 | + set(_gnc_module_path ${LIBDIR_BUILD}:${LIBDIR_BUILD}/gnucash) |
5 | 5 | if (WIN32) |
6 | | - set(_GNC_MODULE_PATH ${CMAKE_BINARY_DIR}/bin) |
7 | | - endif() |
8 | | - set(env "") |
9 | | - list(APPEND env "GNC_UNINSTALLED=yes") |
10 | | - list(APPEND env "GNC_BUILDDIR=${CMAKE_BINARY_DIR}") |
11 | | - if (APPLE) |
12 | | - list(APPEND env "DYLD_LIBRARY_PATH=${_GNC_MODULE_PATH}:$ENV{DYLD_LIBRARY_PATH}") |
13 | | - endif() |
14 | | - if (UNIX) |
15 | | - list(APPEND env "LD_LIBRARY_PATH=${_GNC_MODULE_PATH}:$ENV{LD_LIBRARY_PATH}") |
| 6 | + set(_gnc_module_path ${CMAKE_BINARY_DIR}/bin) |
16 | 7 | endif() |
| 8 | + set(_relative_site_dir "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}") |
| 9 | + set(_relative_cache_dir "${CMAKE_BINARY_DIR}/${GUILE_REL_SITECCACHEDIR}") |
| 10 | + |
17 | 11 | if (MINGW64) |
18 | 12 | set(fpath "") |
19 | 13 | set(path $ENV{PATH}) |
20 | 14 | list(INSERT path 0 ${CMAKE_BINARY_DIR}/bin) |
21 | | - foreach(dir ${path}) |
22 | | - string(REGEX REPLACE "^([A-Za-z]):" "/\\1" dir ${dir}) |
23 | | - string(REGEX REPLACE "\\\\" "/" dir ${dir}) |
24 | | - set(fpath "${fpath}${dir}:") |
25 | | - endforeach(dir) |
26 | | - list(APPEND env "PATH=${fpath}") |
27 | | - set(compiled_path "${CMAKE_BINARY_DIR}/${GUILE_REL_SITECCACHEDIR}") |
28 | | - string(REGEX REPLACE "^([A-Za-z]):" "/\\1" compiled_path ${compiled_path}) |
29 | | - list(APPEND env GUILE_LOAD_COMPILED_PATH=${compiled_path}) |
30 | | - endif() |
31 | | - list(APPEND env "GNC_MODULE_PATH=${_GNC_MODULE_PATH}") |
32 | | - list(APPEND env "GUILE=${GUILE_EXECUTABLE}") |
33 | | - |
34 | | - set(guile_load_paths "") |
35 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}") |
36 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}/gnucash/deprecated") # Path to gnucash' deprecated modules |
| 15 | + if (${GUILE_EFFECTIVE_VERSION} VERSION_LESS 2.2) |
| 16 | + foreach(dir ${path}) |
| 17 | + make_unix_path(dir) |
| 18 | + list(APPEND fpath ${dir}) |
| 19 | + endforeach(dir) |
| 20 | + make_unix_path_list(fpath) |
| 21 | + else() |
| 22 | + set(fpath ${path}) |
| 23 | + make_win32_path_list(fpath) |
| 24 | + endif() |
| 25 | + endif() |
| 26 | + |
| 27 | + set(guile_load_paths "$ENV{GUILE_LOAD_PATH}") |
| 28 | + list(APPEND guile_load_paths |
| 29 | + "${_relative_site_dir}" |
| 30 | + "${_relative_site_dir}/gnucash/deprecated" |
| 31 | + ) |
37 | 32 | if (GUILE_COVERAGE) |
38 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}/gnucash") |
39 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}/gnucash/report") |
40 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}/gnucash/reports") |
41 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}/gnucash/engine") |
42 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}/gnucash/app-utils") |
43 | | - list(APPEND guile_load_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITEDIR}/gnucash/qif-import") |
| 33 | + list(APPEND guile_load_paths |
| 34 | + "${_relative_site_dir}/gnucash" |
| 35 | + "${_relative_site_dir}/gnucash/report" |
| 36 | + "${_relative_site_dir}/gnucash/reports" |
| 37 | + "${_relative_site_dir}/gnucash/engine" |
| 38 | + "${_relative_site_dir}/gnucash/app-utils" |
| 39 | + "${_relative_site_dir}/gnucash/qif-import" |
| 40 | + ) |
44 | 41 |
|
45 | 42 | endif() |
46 | | - set(guile_load_path "${guile_load_paths}") |
| 43 | + set(_guile_load_path "${guile_load_paths}") |
47 | 44 |
|
48 | | - set(guile_load_compiled_paths "") |
49 | | - list(APPEND guile_load_compiled_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITECCACHEDIR}") |
50 | | - list(APPEND guile_load_compiled_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITECCACHEDIR}/gnucash/deprecated") |
51 | | - list(APPEND guile_load_compiled_paths "${CMAKE_BINARY_DIR}/${GUILE_REL_SITECCACHEDIR}/tests") |
52 | | - set(guile_load_compiled_path "${guile_load_compiled_paths}") |
| 45 | + set(guile_load_compiled_paths "$ENV{GUILE_LOAD_COMPILED_PATH}") |
| 46 | + list(APPEND guile_load_compiled_paths |
| 47 | + "${_relative_cache_dir}" |
| 48 | + "${_relative_cache_dir}/gnucash/deprecated" |
| 49 | + "${_relative_cache_dir}/tests" |
| 50 | + ) |
| 51 | + set(_guile_load_compiled_path "${guile_load_compiled_paths}") |
53 | 52 |
|
54 | | - if (MINGW64) |
| 53 | + if (MINGW64 AND ${GUILE_EFFECTIVE_VERSION} VERSION_LESS 2.2) |
55 | 54 | set(new_path "") |
56 | | - foreach(load_item ${guile_load_path}) |
57 | | - string(REGEX REPLACE "^([A-Za-z]):" "/\\1" load_item ${load_item}) |
58 | | - list(APPEND new_path ${load_item}) |
| 55 | + foreach(load_item ${_guile_load_path}) |
| 56 | + make_unix_path(load_item) |
| 57 | + list(APPEND new_path "${load_item}") |
59 | 58 | endforeach(load_item) |
60 | | - set(guile_load_path ${new_path}) |
| 59 | + set(_guile_load_path ${new_path}) |
61 | 60 |
|
62 | 61 | set(new_path "") |
63 | | - foreach(load_item ${guile_load_compiled_path}) |
64 | | - string(REGEX REPLACE "^([A-Za-z]):" "/\\1" load_item ${load_item}) |
| 62 | + foreach(load_item ${_guile_load_compiled_path}) |
| 63 | + make_unix_path(load_item) |
65 | 64 | list(APPEND new_path ${load_item}) |
66 | 65 | endforeach(load_item) |
67 | | - set(guile_load_compiled_path ${new_path}) |
| 66 | + set(_guile_load_compiled_path ${new_path}) |
68 | 67 | endif() |
69 | | - if (WIN32 AND NOT MINGW64) |
70 | | - string(REPLACE ";" "\\\\;" GUILE_LOAD_PATH "${guile_load_path}") |
71 | | - string(REPLACE ";" "\\\\;" GUILE_LOAD_COMPILED_PATH "${guile_load_compiled_path}") |
| 68 | + |
| 69 | + if (NOT MINGW64 OR ${GUILE_EFFECTIVE_VERSION} VERSION_LESS 2.2) |
| 70 | + make_unix_path_list(_guile_load_path) |
| 71 | + make_unix_path_list(_guile_load_compiled_path) |
72 | 72 | else() |
73 | | - string(REPLACE ";" ":" GUILE_LOAD_PATH "${guile_load_path}") |
74 | | - string(REPLACE ";" ":" GUILE_LOAD_COMPILED_PATH "${guile_load_compiled_path}") |
| 73 | + make_win32_path_list(_guile_load_path) |
| 74 | + make_win32_path_list(_guile_load_compiled_path) |
| 75 | + endif() |
| 76 | + |
| 77 | + set(_guile_env |
| 78 | + "GNC_MODULE_PATH=${_gnc_module_path}" |
| 79 | + "GUILE=${GUILE_EXECUTABLE}" |
| 80 | + "GUILE_LOAD_PATH=${_guile_load_path}" |
| 81 | + "GUILE_LOAD_COMPILED_PATH=${_guile_load_compiled_path}" |
| 82 | + "GUILE_WARN_DEPRECATED=detailed" |
| 83 | + ) |
| 84 | + if (MINGW64) |
| 85 | + list(APPEND _guile_env "PATH=${fpath}") |
| 86 | + elseif (APPLE) |
| 87 | + list(APPEND _guile_env "DYLD_LIBRARY_PATH=${_gnc_module_path}:$ENV{DYLD_LIBRARY_PATH}") |
| 88 | + elseif (UNIX) |
| 89 | + list(APPEND _guile_env "LD_LIBRARY_PATH=${_gnc_module_path}:$ENV{LD_LIBRARY_PATH}") |
75 | 90 | endif() |
76 | | - list(APPEND env "GUILE_LOAD_PATH=${GUILE_LOAD_PATH}") |
77 | | - list(APPEND env "GUILE_LOAD_COMPILED_PATH=${GUILE_LOAD_COMPILED_PATH}") |
78 | | - list(APPEND env "GUILE_WARN_DEPRECATED=detailed") |
79 | | - set(GUILE_ENV ${env} PARENT_SCOPE) |
| 91 | + set(GUILE_ENV "${_guile_env}" PARENT_SCOPE) |
80 | 92 | endfunction() |
81 | 93 |
|
82 | 94 |
|
|
0 commit comments