summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2013-01-24 18:35:30 (GMT)
committerBrad King <brad.king@kitware.com>2013-01-28 20:31:02 (GMT)
commit7bb8344d50fa317580068dedd00b019be8a6cb98 (patch)
tree02cabced4c3299063e0a06e806cf64d0c97a992c
parent00d801fbfe9c5170e3a83019cc2e3f6b1ce64200 (diff)
downloadCMake-7bb8344d50fa317580068dedd00b019be8a6cb98.zip
CMake-7bb8344d50fa317580068dedd00b019be8a6cb98.tar.gz
CMake-7bb8344d50fa317580068dedd00b019be8a6cb98.tar.bz2
ExternalData: Do not match directory names when resolving DATA{}
Our content link and object download infrastructure supports only blobs (files), not trees (directories). Do not allow references to end in a slash.
-rw-r--r--Modules/ExternalData.cmake11
1 files changed, 9 insertions, 2 deletions
diff --git a/Modules/ExternalData.cmake b/Modules/ExternalData.cmake
index 4ab2186..29ddffd 100644
--- a/Modules/ExternalData.cmake
+++ b/Modules/ExternalData.cmake
@@ -304,6 +304,13 @@ function(_ExternalData_arg target arg options var_file)
list(GET options 0 data)
list(REMOVE_AT options 0)
+ # Reject trailing slashes.
+ if("x${data}" MATCHES "[/\\]$")
+ message(FATAL_ERROR "Data file reference in argument\n"
+ " ${arg}\n"
+ "may not end in a slash!")
+ endif()
+
# Convert to full path.
if(IS_ABSOLUTE "${data}")
set(absdata "${data}")
@@ -376,7 +383,7 @@ function(_ExternalData_arg target arg options var_file)
" ${arg}\n"
"corresponds to source tree path\n"
" ${reldata}\n"
- "that does not exist (with or without an extension)!")
+ "that does not exist as a file (with or without an extension)!")
endif()
if(external)
@@ -470,7 +477,7 @@ function(_ExternalData_arg_find_files pattern regex)
foreach(entry IN LISTS globbed)
string(REGEX REPLACE "^(${regex})(\\.md5|)$" "\\1;\\2" tuple "${entry}")
list(LENGTH tuple len)
- if("${len}" EQUAL 2)
+ if("${len}" EQUAL 2 AND NOT IS_DIRECTORY "${top_src}/${entry}")
list(GET tuple 0 relname)
list(GET tuple 1 alg)
set(name "${top_src}/${relname}")