summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmFindFileCommand.cxx79
-rw-r--r--Source/cmFindFileCommand.h2
-rw-r--r--Source/cmFindPathCommand.cxx82
-rw-r--r--Source/cmFindPathCommand.h4
4 files changed, 84 insertions, 83 deletions
diff --git a/Source/cmFindFileCommand.cxx b/Source/cmFindFileCommand.cxx
index 465d554..30c481b 100644
--- a/Source/cmFindFileCommand.cxx
+++ b/Source/cmFindFileCommand.cxx
@@ -89,17 +89,6 @@ bool cmFindFileCommand::InitialPass(std::vector<std::string> const& argsIn)
return true;
}
}
-#if defined (__APPLE__)
- cmStdString fpath = this->FindHeaderInFrameworks(path, args[0].c_str(), args[1].c_str());
- if(fpath.size())
- {
- m_Makefile->AddCacheDefinition(args[0].c_str(),
- fpath.c_str(),
- helpString.c_str(),
- cmCacheManager::FILEPATH);
- return true;
- }
-#endif
std::string s = args[0] + "-NOTFOUND";
m_Makefile->AddCacheDefinition(args[0].c_str(),
s.c_str(),
@@ -108,71 +97,3 @@ bool cmFindFileCommand::InitialPass(std::vector<std::string> const& argsIn)
return true;
}
-cmStdString cmFindFileCommand::FindHeaderInFrameworks(
- std::vector<std::string> path,
- const char* defineVar,
- const char* file)
-{
- (void)defineVar;
-
-#ifndef __APPLE__
- (void)path;
- (void)file;
- return cmStdString("");
-#else
- cmStdString fileName = file;
- cmStdString frameWorkName;
- cmStdString::size_type pos = fileName.find("/");
- std::cerr << "ff " << fileName << " " << pos << "\n";
- if(pos != fileName.npos)
- {
- // remove the name from the slash;
- fileName = fileName.substr(pos+1);
- frameWorkName = file;
- frameWorkName = frameWorkName.substr(0, frameWorkName.size()-fileName.size()-1);
- // if the framework has a path in it then just use the filename
- std::cerr << fileName << " " << frameWorkName << "\n";
- if(frameWorkName.find("/") != frameWorkName.npos)
- {
- fileName = file;
- frameWorkName = "";
- }
- }
- path.push_back("~/Library/Frameworks");
- path.push_back("/Library/Frameworks");
- path.push_back("/System/Library/Frameworks");
- path.push_back("/Network/Library/Frameworks");
- for( std::vector<std::string>::iterator i = path.begin();
- i != path.end(); ++i)
- {
- if(frameWorkName.size())
- {
- std::string fpath = *i;
- fpath += "/";
- fpath += frameWorkName;
- fpath += ".framework";
- std::string intPath = fpath;
- intPath += "/Headers/";
- intPath += fileName;
- std::cerr << "try " << intPath << "\n";
- if(cmSystemTools::FileExists(intPath.c_str()))
- {
- return fpath;
- }
- }
- cmStdString glob = *i;
- glob += "/*/Headers/";
- glob += file;
- cmGlob globIt;
- globIt.FindFiles(glob);
- std::vector<std::string> files = globIt.GetFiles();
- if(files.size())
- {
- cmStdString fheader = cmSystemTools::CollapseFullPath(files[0].c_str());
- fheader = cmSystemTools::GetFilenamePath(fheader);
- return fheader;
- }
- }
- return cmStdString("");
-#endif
-}
diff --git a/Source/cmFindFileCommand.h b/Source/cmFindFileCommand.h
index e5fb661..1d4a600 100644
--- a/Source/cmFindFileCommand.h
+++ b/Source/cmFindFileCommand.h
@@ -79,8 +79,6 @@ public:
"different extensions on different platforms, FIND_PROGRAM "
"should be used instead of FIND_FILE when looking for them.";
}
- cmStdString FindHeaderInFrameworks( std::vector<std::string> path,
- const char* var, const char* file);
cmTypeMacro(cmFindFileCommand, cmCommand);
};
diff --git a/Source/cmFindPathCommand.cxx b/Source/cmFindPathCommand.cxx
index d454715..68da096 100644
--- a/Source/cmFindPathCommand.cxx
+++ b/Source/cmFindPathCommand.cxx
@@ -98,7 +98,18 @@ bool cmFindPathCommand::InitialPass(std::vector<std::string> const& argsIn)
return true;
}
}
-
+#if defined (__APPLE__)
+ cmStdString fpath = this->FindHeaderInFrameworks(path, args[0].c_str(), args[1].c_str());
+ if(fpath.size())
+ {
+ m_Makefile->AddCacheDefinition(args[0].c_str(),
+ fpath.c_str(),
+ helpString.c_str(),
+ cmCacheManager::FILEPATH);
+ return true;
+ }
+#endif
+
m_Makefile->AddCacheDefinition(args[0].c_str(),
(args[0] + "-NOTFOUND").c_str(),
helpString.c_str(),
@@ -106,3 +117,72 @@ bool cmFindPathCommand::InitialPass(std::vector<std::string> const& argsIn)
return true;
}
+cmStdString cmFindPathCommand::FindHeaderInFrameworks(
+ std::vector<std::string> path,
+ const char* defineVar,
+ const char* file)
+{
+ (void)defineVar;
+
+#ifndef __APPLE__
+ (void)path;
+ (void)file;
+ return cmStdString("");
+#else
+ cmStdString fileName = file;
+ cmStdString frameWorkName;
+ cmStdString::size_type pos = fileName.find("/");
+ std::cerr << "ff " << fileName << " " << pos << "\n";
+ if(pos != fileName.npos)
+ {
+ // remove the name from the slash;
+ fileName = fileName.substr(pos+1);
+ frameWorkName = file;
+ frameWorkName = frameWorkName.substr(0, frameWorkName.size()-fileName.size()-1);
+ // if the framework has a path in it then just use the filename
+ std::cerr << fileName << " " << frameWorkName << "\n";
+ if(frameWorkName.find("/") != frameWorkName.npos)
+ {
+ fileName = file;
+ frameWorkName = "";
+ }
+ }
+ path.push_back("~/Library/Frameworks");
+ path.push_back("/Library/Frameworks");
+ path.push_back("/System/Library/Frameworks");
+ path.push_back("/Network/Library/Frameworks");
+ for( std::vector<std::string>::iterator i = path.begin();
+ i != path.end(); ++i)
+ {
+ if(frameWorkName.size())
+ {
+ std::string fpath = *i;
+ fpath += "/";
+ fpath += frameWorkName;
+ fpath += ".framework";
+ std::string intPath = fpath;
+ intPath += "/Headers/";
+ intPath += fileName;
+ std::cerr << "try " << intPath << "\n";
+ if(cmSystemTools::FileExists(intPath.c_str()))
+ {
+ return fpath;
+ }
+ }
+ cmStdString glob = *i;
+ glob += "/*/Headers/";
+ glob += file;
+ cmGlob globIt;
+ globIt.FindFiles(glob);
+ std::vector<std::string> files = globIt.GetFiles();
+ if(files.size())
+ {
+ cmStdString fheader = cmSystemTools::CollapseFullPath(files[0].c_str());
+ fheader = cmSystemTools::GetFilenamePath(fheader);
+ return fheader;
+ }
+ }
+ return cmStdString("");
+#endif
+
+}
diff --git a/Source/cmFindPathCommand.h b/Source/cmFindPathCommand.h
index 6553ca0..17e431b 100644
--- a/Source/cmFindPathCommand.h
+++ b/Source/cmFindPathCommand.h
@@ -78,7 +78,9 @@ public:
"the cache entry <VAR>. The environment variable CMAKE_INCLUDE_PATH "
"is searched as well as the PATH variable.\n";
}
-
+ cmStdString FindHeaderInFrameworks( std::vector<std::string> path,
+ const char* var, const char* file);
+
cmTypeMacro(cmFindPathCommand, cmCommand);
};