|
|
@@ -31,10 +31,20 @@ cmVisualStudioGeneratorOptions
|
|
|
cmVS7FlagTable const* table,
|
|
|
cmVS7FlagTable const* extraTable,
|
|
|
cmVisualStudio10TargetGenerator* g):
|
|
|
+ cmIDEOptions(),
|
|
|
LocalGenerator(lg), Version(version), CurrentTool(tool),
|
|
|
- DoingDefine(false), FlagTable(table), ExtraFlagTable(extraTable),
|
|
|
TargetGenerator(g)
|
|
|
{
|
|
|
+ // Store the given flag tables.
|
|
|
+ cmIDEFlagTable const** ft = this->FlagTable;
|
|
|
+ if(table) { *ft++ = table; }
|
|
|
+ if(extraTable) { *ft++ = extraTable; }
|
|
|
+
|
|
|
+ // Preprocessor definitions are not allowed for linker tools.
|
|
|
+ this->AllowDefine = (tool != Linker);
|
|
|
+
|
|
|
+ // Slash options are allowed for VS.
|
|
|
+ this->AllowSlash = true;
|
|
|
}
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
@@ -85,30 +95,6 @@ void cmVisualStudioGeneratorOptions::SetVerboseMakefile(bool verbose)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-//----------------------------------------------------------------------------
|
|
|
-void cmVisualStudioGeneratorOptions::AddDefine(const std::string& def)
|
|
|
-{
|
|
|
- this->Defines.push_back(def);
|
|
|
-}
|
|
|
-
|
|
|
-//----------------------------------------------------------------------------
|
|
|
-void cmVisualStudioGeneratorOptions::AddDefines(const char* defines)
|
|
|
-{
|
|
|
- if(defines)
|
|
|
- {
|
|
|
- // Expand the list of definitions.
|
|
|
- cmSystemTools::ExpandListArgument(defines, this->Defines);
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-//----------------------------------------------------------------------------
|
|
|
-void cmVisualStudioGeneratorOptions::AddFlag(const char* flag,
|
|
|
- const char* value)
|
|
|
-{
|
|
|
- this->FlagMap[flag] = value;
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
bool cmVisualStudioGeneratorOptions::IsDebug()
|
|
|
{
|
|
|
return this->FlagMap.find("DebugInformationFormat") != this->FlagMap.end();
|
|
|
@@ -147,54 +133,8 @@ void cmVisualStudioGeneratorOptions::Parse(const char* flags)
|
|
|
}
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
-void cmVisualStudioGeneratorOptions::HandleFlag(const char* flag)
|
|
|
+void cmVisualStudioGeneratorOptions::StoreUnknownFlag(const char* flag)
|
|
|
{
|
|
|
- // If the last option was -D then this option is the definition.
|
|
|
- if(this->DoingDefine)
|
|
|
- {
|
|
|
- this->DoingDefine = false;
|
|
|
- this->Defines.push_back(flag);
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- // Look for known arguments.
|
|
|
- if(flag[0] == '-' || flag[0] == '/')
|
|
|
- {
|
|
|
- // Look for preprocessor definitions.
|
|
|
- if(this->CurrentTool == Compiler && flag[1] == 'D')
|
|
|
- {
|
|
|
- if(flag[2] == '\0')
|
|
|
- {
|
|
|
- // The next argument will have the definition.
|
|
|
- this->DoingDefine = true;
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
- // Store this definition.
|
|
|
- this->Defines.push_back(flag+2);
|
|
|
- }
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- // Look through the available flag tables.
|
|
|
- bool flag_handled = false;
|
|
|
- if(this->FlagTable &&
|
|
|
- this->CheckFlagTable(this->FlagTable, flag, flag_handled))
|
|
|
- {
|
|
|
- return;
|
|
|
- }
|
|
|
- if(this->ExtraFlagTable &&
|
|
|
- this->CheckFlagTable(this->ExtraFlagTable, flag, flag_handled))
|
|
|
- {
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- // If any map entry handled the flag we are done.
|
|
|
- if(flag_handled)
|
|
|
- {
|
|
|
- return;
|
|
|
- }
|
|
|
- }
|
|
|
// This option is not known. Store it in the output flags.
|
|
|
this->FlagString += " ";
|
|
|
this->FlagString +=
|
|
|
@@ -205,77 +145,6 @@ void cmVisualStudioGeneratorOptions::HandleFlag(const char* flag)
|
|
|
}
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
-bool
|
|
|
-cmVisualStudioGeneratorOptions
|
|
|
-::CheckFlagTable(cmVS7FlagTable const* table, const char* flag,
|
|
|
- bool& flag_handled)
|
|
|
-{
|
|
|
- // Look for an entry in the flag table matching this flag.
|
|
|
- for(cmVS7FlagTable const* entry = table; entry->IDEName; ++entry)
|
|
|
- {
|
|
|
- bool entry_found = false;
|
|
|
- if(entry->special & cmVS7FlagTable::UserValue)
|
|
|
- {
|
|
|
- // This flag table entry accepts a user-specified value. If
|
|
|
- // the entry specifies UserRequired we must match only if a
|
|
|
- // non-empty value is given.
|
|
|
- int n = static_cast<int>(strlen(entry->commandFlag));
|
|
|
- if(strncmp(flag+1, entry->commandFlag, n) == 0 &&
|
|
|
- (!(entry->special & cmVS7FlagTable::UserRequired) ||
|
|
|
- static_cast<int>(strlen(flag+1)) > n))
|
|
|
- {
|
|
|
- if(entry->special & cmVS7FlagTable::UserIgnored)
|
|
|
- {
|
|
|
- // Ignore the user-specified value.
|
|
|
- this->FlagMap[entry->IDEName] = entry->value;
|
|
|
- }
|
|
|
- else if(entry->special & cmVS7FlagTable::SemicolonAppendable)
|
|
|
- {
|
|
|
- const char *new_value = flag+1+n;
|
|
|
-
|
|
|
- std::map<cmStdString,cmStdString>::iterator itr;
|
|
|
- itr = this->FlagMap.find(entry->IDEName);
|
|
|
- if(itr != this->FlagMap.end())
|
|
|
- {
|
|
|
- // Append to old value (if present) with semicolons;
|
|
|
- itr->second += ";";
|
|
|
- itr->second += new_value;
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
- this->FlagMap[entry->IDEName] = new_value;
|
|
|
- }
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
- // Use the user-specified value.
|
|
|
- this->FlagMap[entry->IDEName] = flag+1+n;
|
|
|
- }
|
|
|
- entry_found = true;
|
|
|
- }
|
|
|
- }
|
|
|
- else if(strcmp(flag+1, entry->commandFlag) == 0)
|
|
|
- {
|
|
|
- // This flag table entry provides a fixed value.
|
|
|
- this->FlagMap[entry->IDEName] = entry->value;
|
|
|
- entry_found = true;
|
|
|
- }
|
|
|
-
|
|
|
- // If the flag has been handled by an entry not requesting a
|
|
|
- // search continuation we are done.
|
|
|
- if(entry_found && !(entry->special & cmVS7FlagTable::Continue))
|
|
|
- {
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- // If the entry was found the flag has been handled.
|
|
|
- flag_handled = flag_handled || entry_found;
|
|
|
- }
|
|
|
-
|
|
|
- return false;
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
void cmVisualStudioGeneratorOptions::SetConfiguration(const char* config)
|
|
|
{
|
|
|
this->Configuration = config;
|