summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2018-11-01 09:02:41 -0400
committerBrad King <brad.king@kitware.com>2018-11-01 09:02:41 -0400
commita567f533dbbcb0d41ac38837f2593059a456fe5e (patch)
treeb86c5c48ec4c8b027451f7a42ef70c523b57d43e
parent8f043068d5f5953f4eb8440389fe37f8b044baca (diff)
parenteb52529ff41d375344c2bd45a717bf86669627f8 (diff)
downloadcmake-a567f533dbbcb0d41ac38837f2593059a456fe5e.tar.gz
Merge branch 'server-file-monitor-check' into release-3.13
Merge-request: !2556
-rw-r--r--Source/cmFileMonitor.cxx3
1 files changed, 2 insertions, 1 deletions
diff --git a/Source/cmFileMonitor.cxx b/Source/cmFileMonitor.cxx
index 04a3c0ef71..b36ac7805a 100644
--- a/Source/cmFileMonitor.cxx
+++ b/Source/cmFileMonitor.cxx
@@ -315,6 +315,7 @@ void cmFileMonitor::MonitorPaths(const std::vector<std::string>& paths,
for (std::string const& p : paths) {
std::vector<std::string> pathSegments;
cmsys::SystemTools::SplitPath(p, pathSegments, true);
+ const bool pathIsFile = !cmsys::SystemTools::FileIsDirectory(p);
const size_t segmentCount = pathSegments.size();
if (segmentCount < 2) { // Expect at least rootdir and filename
@@ -324,7 +325,7 @@ void cmFileMonitor::MonitorPaths(const std::vector<std::string>& paths,
for (size_t i = 0; i < segmentCount; ++i) {
assert(currentWatcher);
- const bool fileSegment = (i == segmentCount - 1);
+ const bool fileSegment = (i == segmentCount - 1 && pathIsFile);
const bool rootSegment = (i == 0);
assert(
!(fileSegment &&