Skip to content

Commit

Permalink
Make more consistent usage of cpm_uri_scheme_from_string to simplify …
Browse files Browse the repository at this point in the history
…some logic; Make updated cpm_parse_add_package_single_arg have behaviour more consistent with the pre-user-definable-uri-schemes version (cpm-cmake#564)
  • Loading branch information
k-channon-PA committed Jun 10, 2024
1 parent b32e88b commit 2433179
Show file tree
Hide file tree
Showing 2 changed files with 81 additions and 71 deletions.
124 changes: 67 additions & 57 deletions cmake/CPM.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -151,24 +151,30 @@ set(CPM_DRY_RUN
CACHE INTERNAL "Don't download or configure dependencies (for testing)"
)
set(CPM_URI_SCHEMES
"gh!GITHUB_REPOSITORY!GIT_REPOSITORY!https://github.com!.git"
"gl!GITLAB_REPOSITORY!GIT_REPOSITORY!https://gitlab.com!.git"
"bb!BITBUCKET_REPOSITORY!GIT_REPOSITORY!https://bitbucket.org!.git"
"gh|GITHUB_REPOSITORY|GIT_REPOSITORY|https://github.com|.git"
"gl|GITLAB_REPOSITORY|GIT_REPOSITORY|https://gitlab.com|.git"
"bb|BITBUCKET_REPOSITORY|GIT_REPOSITORY|https://bitbucket.org|.git"
CACHE INTERNAL ""
)
set(CPM_URI_SCHEME_PATTERN
"^([a-z][a-z0-9]*)\\|([A-Z_][A-Z0-9_]*)\\|(GIT_REPOSITORY|URL)\\|(.+)\\|(.*)$"
CACHE INTERNAL ""
)

function(
cpm_uri_scheme_from_string

# INPUTS
schemeStr

# OUTPUTS
alias
longName
uriType
uriRoot
uriSuffix
)
if("${schemeStr}" MATCHES
"^([a-zA-Z][a-zA-Z0-9]*)!([a-zA-Z_][a-zA-Z0-9_]*)!([a-zA-Z_][a-zA-Z0-9_]*)!(.+)!(.*)$"
)
if("${schemeStr}" MATCHES "${CPM_URI_SCHEME_PATTERN}")
string(TOLOWER "${CMAKE_MATCH_1}" thisScheme)
set(${alias}
"${thisScheme}"
Expand All @@ -190,6 +196,8 @@ function(
"${CMAKE_MATCH_5}"
PARENT_SCOPE
)
else()
message(STATUS "Not a URI scheme: ${schemeStr}")
endif()
endfunction()

Expand Down Expand Up @@ -376,17 +384,31 @@ function(cpm_check_if_package_already_added CPM_ARGS_NAME CPM_ARGS_VERSION)
endif()
endfunction()

function(cpm_infer_packageType uri packageType)
if("${uri}" MATCHES ".git([@#$]?)")
function(cpm_infer_package_type uri uriType uriSuffix packageType)
if("${uriType}" STREQUAL "GIT_REPOSITORY")
set(${packageType}
"git"
PARENT_SCOPE
"git"
PARENT_SCOPE
)
else()
set(${packageType}
"archive"
PARENT_SCOPE
)
if("${uri}" MATCHES ".git([@#$]?)")
set(${packageType}
"git"
PARENT_SCOPE
)
else()
if("${uriSuffix}" MATCHES ".git([@#$]?)")
set(${packageType}
"git"
PARENT_SCOPE
)
else()
set(${packageType}
"archive"
PARENT_SCOPE
)
endif()
endif()
endif()
endfunction()

Expand All @@ -397,7 +419,6 @@ function(
cpm_expand_via_scheme
scheme
uriFragment
applySuffix
expanded
repoType
pkgType
Expand All @@ -409,51 +430,40 @@ function(
)

foreach(mapping ${CPM_URI_SCHEMES})
if("${mapping}" MATCHES
"^([a-zA-Z][a-zA-Z0-9]*)!([a-zA-Z_][a-zA-Z0-9_]*)!([a-zA-Z_][a-zA-Z0-9_]*)!(.+)!(.*)$"
)
string(TOLOWER "${CMAKE_MATCH_1}" thisScheme)
if(scheme STREQUAL ${thisScheme})
set(longName "${CMAKE_MATCH_2}")
set(uriRoot "${CMAKE_MATCH_4}")
set(suffix "${CMAKE_MATCH_5}")
if(applySuffix)
string(REGEX REPLACE "^([^#@]+)" "\\1${suffix}" uriFragment "${uriFragment}")
endif()

set(expandedValue "${longName};${uriRoot}/${uriFragment}")
set(${expanded}
${expandedValue}
PARENT_SCOPE
)
cpm_uri_scheme_from_string(${mapping} alias longName uriType uriRoot uriSuffix)
if(scheme STREQUAL ${alias})
set(expandedValue "${longName};${uriFragment}")
set(${expanded}
${expandedValue}
PARENT_SCOPE
)

set(${repoType}
${CMAKE_MATCH_3}
PARENT_SCOPE
)
cpm_infer_packagetype(${uriFragment} inferredPackageType)
set(${pkgType}
${inferredPackageType}
PARENT_SCOPE
)
set(${success}
"TRUE"
PARENT_SCOPE
)
break()
endif()
set(${repoType}
${CMAKE_MATCH_3}
PARENT_SCOPE
)
cpm_infer_package_type("${uriFragment}" "${uriType}" "${uriSuffix}" inferredPackageType)
set(${pkgType}
${inferredPackageType}
PARENT_SCOPE
)
set(${success}
"TRUE"
PARENT_SCOPE
)
break()
endif()
endforeach()
endfunction()

function(cpm_is_valid_scheme scheme result)
set(${success}
set(${result}
FALSE
PARENT_SCOPE
)

foreach(mapping ${CPM_URI_SCHEMES})
if("${mapping}" MATCHES "^([a-zA-Z][a-zA-Z0-9]*)!(.+)!(.*)$")
if("${mapping}" MATCHES "${CPM_URI_SCHEME_PATTERN}")
string(TOLOWER "${CMAKE_MATCH_1}" testScheme)
if(scheme STREQUAL ${testScheme})
set(${result}
Expand All @@ -462,6 +472,8 @@ function(cpm_is_valid_scheme scheme result)
)
break()
endif()
else()
cpm_message(STATUS "${CPM_INDENT} ${mapping} is not a valid mapping")
endif()
endforeach()
endfunction()
Expand Down Expand Up @@ -505,7 +517,6 @@ function(cpm_parse_add_package_single_arg arg outArgs)
cpm_expand_via_scheme(
${scheme}
${uriFragment}
TRUE
outputVar
repoType
packageType
Expand All @@ -517,7 +528,7 @@ function(cpm_parse_add_package_single_arg arg outArgs)
message(FATAL_ERROR "${CPM_INDENT} Failed to expand scheme from '${arg}'")
endif()
else()
cpm_infer_packagetype(${arg} packageType)
cpm_infer_package_type("${arg}" "" "" packageType)
if("${packageType}" STREQUAL "git")
set(out "GIT_REPOSITORY;${arg}")
else()
Expand Down Expand Up @@ -683,12 +694,11 @@ function(CPMAddPackage)
)

foreach(scheme ${CPM_URI_SCHEMES})
cpm_uri_scheme_from_string(${scheme} alias longName uriType uriRoot uriSuffix)
cpm_uri_scheme_from_string(${scheme} alias longName uriType uriRoot uriSuffix isScheme)
list(APPEND oneValueArgs ${longName})
endforeach()

set(multiValueArgs URL OPTIONS DOWNLOAD_COMMAND)

cmake_parse_arguments(CPM_ARGS "" "${oneValueArgs}" "${multiValueArgs}" "${ARGN}")

# Set default values for arguments
Expand All @@ -712,7 +722,6 @@ function(CPMAddPackage)
cpm_expand_via_scheme(
${alias}
${${cpmRepoType}}
FALSE
completeUri
repoType
pkgType
Expand All @@ -721,9 +730,10 @@ function(CPMAddPackage)
if(NOT successfulExpansion)
message(FATAL_ERROR "${CPM_INDENT} Failed to generate repository URL from '${cpmRepoType}'")
endif()

string(CONCAT uriTypeArg CPM_ARGS_ ${uriType})
string(REPLACE ${longName} "" completeUri ${completeUri})
set(${uriTypeArg} ${completeUri})
set(${uriTypeArg} ${uriRoot}/${completeUri}${uriSuffix})
endif()
endforeach()

Expand Down Expand Up @@ -1347,10 +1357,10 @@ function(CPMDefineUriScheme)
endif()

set(newScheme
"${CPM_SCHEME_ALIAS}!${CPM_SCHEME_LONG_NAME}!${CPM_SCHEME_URI_TYPE}!${CPM_SCHEME_URI_ROOT}!${CPM_SCHEME_URI_SUFFIX}"
"${CPM_SCHEME_ALIAS}|${CPM_SCHEME_LONG_NAME}|${CPM_SCHEME_URI_TYPE}|${CPM_SCHEME_URI_ROOT}|${CPM_SCHEME_URI_SUFFIX}"
)

list(TRANSFORM CPM_URI_SCHEMES REPLACE "^${CPM_SCHEME_ALIAS}!" "${newScheme}")
list(TRANSFORM CPM_URI_SCHEMES REPLACE "^${CPM_SCHEME_ALIAS}" "${newScheme}")
list(FIND CPM_URI_SCHEMES "${newScheme}" index)
if(index EQUAL -1)
list(APPEND CPM_URI_SCHEMES "${newScheme}")
Expand Down
28 changes: 14 additions & 14 deletions test/unit/parse_add_package_single_arg.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -4,42 +4,42 @@ include(${CPM_PATH}/CPM.cmake)
include(${CPM_PATH}/testing.cmake)

cpm_parse_add_package_single_arg("gh:cpm-cmake/CPM.cmake" args)
assert_equal("GITHUB_REPOSITORY;https://github.com/cpm-cmake/CPM.cmake.git" "${args}")
assert_equal("GITHUB_REPOSITORY;cpm-cmake/CPM.cmake" "${args}")

cpm_parse_add_package_single_arg("gh:cpm-cmake/[email protected]" args)
assert_equal("GITHUB_REPOSITORY;https://github.com/cpm-cmake/CPM.cmake.git;VERSION;1.2.3" "${args}")
assert_equal("GITHUB_REPOSITORY;cpm-cmake/CPM.cmake;VERSION;1.2.3" "${args}")

cpm_parse_add_package_single_arg("gh:cpm-cmake/CPM.cmake#master" args)
assert_equal(
"GITHUB_REPOSITORY;https://github.com/cpm-cmake/CPM.cmake.git;GIT_TAG;master" "${args}"
"GITHUB_REPOSITORY;cpm-cmake/CPM.cmake;GIT_TAG;master" "${args}"
)

cpm_parse_add_package_single_arg("gh:cpm-cmake/[email protected]#asdf" args)
assert_equal(
"GITHUB_REPOSITORY;https://github.com/cpm-cmake/CPM.cmake.git;VERSION;0.20.3;GIT_TAG;asdf"
"GITHUB_REPOSITORY;cpm-cmake/CPM.cmake;VERSION;0.20.3;GIT_TAG;asdf"
"${args}"
)

cpm_parse_add_package_single_arg("gh:a/b#c@d" args)
assert_equal("GITHUB_REPOSITORY;https://github.com/a/b.git;GIT_TAG;c;VERSION;d" "${args}")
assert_equal("GITHUB_REPOSITORY;a/b;GIT_TAG;c;VERSION;d" "${args}")

cpm_parse_add_package_single_arg("gh:foo#c@d" args)
assert_equal("GITHUB_REPOSITORY;https://github.com/foo.git;GIT_TAG;c;VERSION;d" "${args}")
assert_equal("GITHUB_REPOSITORY;foo;GIT_TAG;c;VERSION;d" "${args}")

cpm_parse_add_package_single_arg("gh:Foo@5" args)
assert_equal("GITHUB_REPOSITORY;https://github.com/Foo.git;VERSION;5" "${args}")
assert_equal("GITHUB_REPOSITORY;Foo;VERSION;5" "${args}")

cpm_parse_add_package_single_arg("gl:foo/bar" args)
assert_equal("GITLAB_REPOSITORY;https://gitlab.com/foo/bar.git" "${args}")
assert_equal("GITLAB_REPOSITORY;foo/bar" "${args}")

cpm_parse_add_package_single_arg("gl:foo/Bar" args)
assert_equal("GITLAB_REPOSITORY;https://gitlab.com/foo/Bar.git" "${args}")
assert_equal("GITLAB_REPOSITORY;foo/Bar" "${args}")

cpm_parse_add_package_single_arg("bb:foo/bar" args)
assert_equal("BITBUCKET_REPOSITORY;https://bitbucket.org/foo/bar.git" "${args}")
assert_equal("BITBUCKET_REPOSITORY;foo/bar" "${args}")

cpm_parse_add_package_single_arg("bb:foo/Bar" args)
assert_equal("BITBUCKET_REPOSITORY;https://bitbucket.org/foo/Bar.git" "${args}")
assert_equal("BITBUCKET_REPOSITORY;foo/Bar" "${args}")

cpm_parse_add_package_single_arg("https://github.com/cpm-cmake/[email protected]" args)
assert_equal("GIT_REPOSITORY;https://github.com/cpm-cmake/CPM.cmake.git;VERSION;0.30.5" "${args}")
Expand Down Expand Up @@ -87,18 +87,18 @@ cpmdefineurischeme(

cpm_parse_add_package_single_arg("ir:somegroup/[email protected]#asdf" args)
assert_equal(
"INTERNAL_REPOS;[email protected]/somegroup/somerepo.git;VERSION;0.20.3;GIT_TAG;asdf"
"INTERNAL_REPOS;somegroup/somerepo;VERSION;0.20.3;GIT_TAG;asdf"
"${args}"
)

cpm_parse_add_package_single_arg("ir2:somegroup/[email protected]#asdf" args)
assert_equal(
"INTERNAL_REPOS2;https://company.internal.oldGitserver/somegroup/somerepo.gitz;VERSION;0.20.3;GIT_TAG;asdf"
"INTERNAL_REPOS2;somegroup/somerepo;VERSION;0.20.3;GIT_TAG;asdf"
"${args}"
)

cpm_parse_add_package_single_arg("af:somegroup/someitem.zip" args)
assert_equal("ARTIFACTORY_PKG;https://my.company.artifatory/pkgs/somegroup/someitem.zip" "${args}")
assert_equal("ARTIFACTORY_PKG;somegroup/someitem.zip" "${args}")

cpm_parse_add_package_single_arg(
"ssh://[email protected]:123/path/to/pkg.git#[email protected]#branch" args
Expand Down

0 comments on commit 2433179

Please sign in to comment.