summaryrefslogtreecommitdiffstats
path: root/Source/cmLocalCodeWarriorGenerator.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmLocalCodeWarriorGenerator.cxx')
-rw-r--r--Source/cmLocalCodeWarriorGenerator.cxx273
1 files changed, 267 insertions, 6 deletions
diff --git a/Source/cmLocalCodeWarriorGenerator.cxx b/Source/cmLocalCodeWarriorGenerator.cxx
index 5745668..250ac22 100644
--- a/Source/cmLocalCodeWarriorGenerator.cxx
+++ b/Source/cmLocalCodeWarriorGenerator.cxx
@@ -52,20 +52,56 @@ void cmLocalCodeWarriorGenerator::WriteTarget(std::ostream& fout,
fout << "<TARGET>\n";
fout << "<NAME>" << tgtName << "</NAME>\n";
- this->WriteSettingList(fout,tgtName,l);
- this->WriteFileList(fout,tgtName,l);
- // this->WriteLinkOrder(fout,l);
+ this->WriteSettingList(fout, tgtName,l);
+ this->WriteFileList(fout, tgtName,l);
+ this->WriteLinkOrder(fout, tgtName, l);
// this->WriteSubTargetList(fout,l);
fout << "</TARGET>\n";
}
+void cmLocalCodeWarriorGenerator::AddFileMapping(std::ostream& fout,
+ const char *ftype,
+ const char *ext,
+ const char *comp,
+ const char *edit,
+ bool precomp,
+ bool launch,
+ bool res,
+ bool ignored)
+{
+ fout << "<SETTING>\n";
+ fout << "<SETTING><NAME>FileType</NAME><VALUE>" << ftype <<
+ "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>FileExtension</NAME><VALUE>" << ext <<
+ "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>Compiler</NAME><VALUE>" << comp <<
+ "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>EditLanguage</NAME><VALUE>" << edit <<
+ "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>Precompile</NAME><VALUE>"
+ << (precomp ? "true" : "false") << "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>Launchable</NAME><VALUE>"
+ << (launch ? "true" : "false") << "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>ResourceFile</NAME><VALUE>"
+ << (res ? "true" : "false") << "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>IgnoredByMake</NAME><VALUE>"
+ << (ignored ? "true" : "false") << "</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+}
+
+
void cmLocalCodeWarriorGenerator::WriteSettingList(std::ostream& fout,
- const char *tgtName,
+ const char *tgtName,
cmTarget const *l)
{
fout << "<SETTINGLIST>\n";
+ fout << "<SETTING><NAME>UserSourceTrees</NAME><VALUE></VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>AlwaysSearchUserPaths</NAME><VALUE>false</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>InterpretDOSAndUnixPaths</NAME><VALUE>false</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>RequireFrameworkStyleIncludes</NAME><VALUE>false</VALUE></SETTING>\n";
+
// list the include paths
fout << "<SETTING><NAME>UserSearchPaths</NAME>\n";
std::vector<std::string>& includes = m_Makefile->GetIncludeDirectories();
@@ -85,14 +121,144 @@ void cmLocalCodeWarriorGenerator::WriteSettingList(std::ostream& fout,
}
fout << "</SETTING>\n";
+ fout << "<SETTING><NAME>SystemSearchPaths</NAME>\n";
+ fout << "<SETTING>\n";
+ fout << "<SETTING><NAME>SearchPath</NAME>\n";
+ fout << "<SETTING><NAME>Path</NAME><VALUE>:MSL:</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathFormat</NAME><VALUE>MacOS</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathRoot</NAME><VALUE>CodeWarrior</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "<SETTING><NAME>Recursive</NAME><VALUE>true</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>FrameworkPath</NAME><VALUE>false</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>HostFlags</NAME><VALUE>All</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "<SETTING>\n";
+ fout << "<SETTING><NAME>SearchPath</NAME>\n";
+ fout << "<SETTING><NAME>Path</NAME><VALUE>:MacOS Support:</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathFormat</NAME><VALUE>MacOS</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathRoot</NAME><VALUE>CodeWarrior</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "<SETTING><NAME>Recursive</NAME><VALUE>true</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>FrameworkPath</NAME><VALUE>false</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>HostFlags</NAME><VALUE>All</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "</SETTING>\n";
+
+ fout << "<SETTING><NAME>MWRuntimeSettings_WorkingDirectory</NAME><VALUE></VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWRuntimeSettings_CommandLine</NAME><VALUE></VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWRuntimeSettings_HostApplication</NAME>\n";
+ fout << "<SETTING><NAME>Path</NAME><VALUE></VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathFormat</NAME><VALUE>Generic</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathRoot</NAME><VALUE>Absolute</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "<SETTING><NAME>MWRuntimeSettings_EnvVars</NAME><VALUE></VALUE></SETTING>\n";
+
+ // <!-- Settings for "Target Settings" panel -->
+ fout << "<SETTING><NAME>Linker</NAME><VALUE>MacOS PPC Linker</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PreLinker</NAME><VALUE></VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PostLinker</NAME><VALUE></VALUE></SETTING>\n";
fout << "<SETTING><NAME>Targetname</NAME><VALUE>" << tgtName
<< "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>OutputDirectory</NAME>\n";
+ fout << "<SETTING><NAME>Path</NAME><VALUE>:</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathFormat</NAME><VALUE>MacOS</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathRoot</NAME><VALUE>Project</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "<SETTING><NAME>SaveEntriesUsingRelativePaths</NAME><VALUE>false</VALUE></SETTING>\n";
+
+ // add the cxx file type
+ fout << "<SETTING><NAME>FileMappings</NAME>\n";
+ this->AddFileMapping(fout,"TEXT",".cxx","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ this->AddFileMapping(fout,"TEXT",".cpp","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ this->AddFileMapping(fout,"TEXT",".c","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ this->AddFileMapping(fout,"TEXT",".cc","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ this->AddFileMapping(fout,"TEXT",".cp","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ this->AddFileMapping(fout,"TEXT",".cpp","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ this->AddFileMapping(fout,"TEXT",".h","MW C/C++ PPC","C/C++",
+ false,false,false,true);
+ this->AddFileMapping(fout,"TEXT",".hpp","MW C/C++ PPC","C/C++",
+ false,false,false,true);
+ this->AddFileMapping(fout,"TEXT",".m","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ this->AddFileMapping(fout,"TEXT",".mm","MW C/C++ PPC","C/C++",
+ false,false,false,false);
+ fout << "</SETTING>\n";
+
+ // <!-- Settings for "MacOS Merge Panel" panel -->
+ fout << "<SETTING><NAME>MWProject_PPC_type</NAME><VALUE>";
+ switch (l->GetType())
+ {
+ case cmTarget::STATIC_LIBRARY:
+ fout << "Library" << "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_outfile</NAME><VALUE>";
+ fout << tgtName << ".lib";
+ fout << "</VALUE></SETTING>\n";
+ break;
+ case cmTarget::SHARED_LIBRARY:
+ case cmTarget::MODULE_LIBRARY:
+ // m_Makefile->GetDefinition("CMAKE_MODULE_SUFFIX");
+ fout << "Shared Library" << "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_outfile</NAME><VALUE>";
+ fout << tgtName << ".dylib";
+ fout << "</VALUE></SETTING>\n";
+ break;
+ case cmTarget::EXECUTABLE:
+ fout << "Application" << "</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_outfile</NAME><VALUE>";
+ fout << tgtName << cmSystemTools::GetExecutableExtension();
+ fout << "</VALUE></SETTING>\n";
+ break;
+ }
+
+ fout << "<SETTING><NAME>MWProject_PPC_filecreator</NAME><VALUE>????</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_filetype</NAME><VALUE>APPL</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_size</NAME><VALUE>384</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_minsize</NAME><VALUE>384</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_stacksize</NAME><VALUE>64</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_flags</NAME><VALUE>22720</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_symfilename</NAME><VALUE></VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_rsrcname</NAME><VALUE></VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_rsrcheader</NAME><VALUE>Native</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_rsrctype</NAME><VALUE>????</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_rsrcid</NAME><VALUE>0</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_rsrcflags</NAME><VALUE>0</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_rsrcstore</NAME><VALUE>0</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_rsrcmerge</NAME><VALUE>0</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_flatrsrc</NAME><VALUE>0</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_flatrsrcoutputdir</NAME>\n";
+ fout << "<SETTING><NAME>Path</NAME><VALUE>:</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathFormat</NAME><VALUE>MacOS</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathRoot</NAME><VALUE>Project</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "<SETTING><NAME>MWProject_PPC_flatrsrcfilename</NAME><VALUE></VALUE></SETTING>\n";
+
+ /*
+ fout << "<SETTING><NAME>MWMerge_MacOS_outputCreator</NAME><VALUE>????</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_outputType</NAME><VALUE>APPL</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_suppressWarning</NAME><VALUE>0</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_copyFragments</NAME><VALUE>1</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_copyResources</NAME><VALUE>1</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_flattenResource</NAME><VALUE>0</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_flatFileName</NAME><VALUE>a.rsrc</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_flatFileOutputPath</NAME>\n";
+ fout << "<SETTING><NAME>Path</NAME><VALUE>:</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathFormat</NAME><VALUE>MacOS</VALUE></SETTING>\n";
+ fout << "<SETTING><NAME>PathRoot</NAME><VALUE>Project</VALUE></SETTING>\n";
+ fout << "</SETTING>\n";
+ fout << "<SETTING><NAME>MWMerge_MacOS_skipResources</NAME><VALUE></VALUE></SETTING>\n";
+ */
fout << "</SETTINGLIST>\n";
}
void cmLocalCodeWarriorGenerator::WriteFileList(std::ostream& fout,
- const char *tgtName,
+ const char *tgtName,
cmTarget const *l)
{
fout << "<FILELIST>\n";
@@ -114,9 +280,61 @@ void cmLocalCodeWarriorGenerator::WriteFileList(std::ostream& fout,
fout << "<FILEFLAGS>Debug</FILEFLAGS>\n";
fout << "</FILE>\n";
}
+
+ // now add in the libraries we depend on
+
+
+ // now add in the system libs (for an executable)
+ if (l->GetType() == cmTarget::EXECUTABLE)
+ {
+ fout << "<FILE>\n";
+ fout << "<PATHTYPE>Name</PATHTYPE>\n";
+ fout << "<PATH>MSL RuntimePPC.Lib</PATH>\n";
+ fout << "<PATHFORMAT>MacOS</PATHFORMAT>\n";
+ fout << "<FILEKIND>Library</FILEKIND>\n";
+ fout << "<FILEFLAGS>Debug</FILEFLAGS>\n";
+ fout << "</FILE>\n";
+ }
+
fout << "</FILELIST>\n";
}
+
+void cmLocalCodeWarriorGenerator::WriteLinkOrder(std::ostream& fout,
+ const char *tgtName,
+ cmTarget const *l)
+{
+ fout << "<LINKORDER>\n";
+
+ // for each file
+ std::vector<cmSourceFile*> const& classes = l->GetSourceFiles();
+ for(std::vector<cmSourceFile*>::const_iterator i = classes.begin();
+ i != classes.end(); i++)
+ {
+ // Add the file to the list of sources.
+ std::string source = (*i)->GetFullPath();
+ fout << "<FILEREF>\n";
+ fout << "<PATHTYPE>Absolute</PATHTYPE>\n";
+ fout << "<PATHROOT>Absolute</PATHROOT>\n";
+ //fout << "<ACCESSPATH>common</ACCESSPATH>\n";
+ fout << "<PATH>" << source << "</PATH>\n";
+ fout << "<PATHFORMAT>Generic</PATHFORMAT>\n";
+ fout << "</FILEREF>\n";
+ }
+
+ // now add in the system libs (for an executable)
+ if (l->GetType() == cmTarget::EXECUTABLE)
+ {
+ fout << "<FILEREF>\n";
+ fout << "<PATHTYPE>Name</PATHTYPE>\n";
+ fout << "<PATH>MSL RuntimePPC.Lib</PATH>\n";
+ fout << "<PATHFORMAT>MacOS</PATHFORMAT>\n";
+ fout << "</FILEREF>\n";
+ }
+
+ fout << "</LINKORDER>\n";
+}
+
void cmLocalCodeWarriorGenerator::WriteGroups(std::ostream& fout)
{
cmTargets &tgts = m_Makefile->GetTargets();
@@ -125,6 +343,7 @@ void cmLocalCodeWarriorGenerator::WriteGroups(std::ostream& fout)
{
this->WriteGroup(fout,l->first.c_str(),&(l->second));
}
+
}
void cmLocalCodeWarriorGenerator::WriteGroup(std::ostream& fout,
@@ -141,11 +360,53 @@ void cmLocalCodeWarriorGenerator::WriteGroup(std::ostream& fout,
std::string source = (*i)->GetFullPath();
fout << "<FILEREF>\n";
fout << "<TARGETNAME>" << tgtName << "</TARGETNAME>\n";
- fout << "<PATHTYPE>Name</PATHTYPE>\n";
+ fout << "<PATHTYPE>Absolute</PATHTYPE>\n";
+ fout << "<PATHROOT>Absolute</PATHROOT>\n";
fout << "<PATH>" << source << "</PATH>\n";
fout << "<PATHFORMAT>Generic</PATHFORMAT>\n";
fout << "</FILEREF>\n";
}
+ // write out the libraries groups
+/*
+ <FILEREF>
+ <TARGETNAME>Classic Release</TARGETNAME>
+ <PATHTYPE>Name</PATHTYPE>
+ <PATH>console.stubs.c</PATH>
+ <PATHFORMAT>MacOS</PATHFORMAT>
+ </FILEREF>
+*/
+
+ if (l->GetType() == cmTarget::EXECUTABLE)
+ {
+ fout << "<FILEREF>\n";
+ fout << "<TARGETNAME>" << tgtName << "</TARGETNAME>\n";
+ fout << "<PATHTYPE>Name</PATHTYPE>\n";
+ fout << "<PATH>MSL RuntimePPC.Lib</PATH>\n";
+ fout << "<PATHFORMAT>MacOS</PATHFORMAT>\n";
+ fout << "</FILEREF>\n";
+ }
+
+/*
+ <FILEREF>
+ <TARGETNAME>Classic Release</TARGETNAME>
+ <PATHTYPE>Name</PATHTYPE>
+ <PATH>MSL C++.PPC.Lib</PATH>
+ <PATHFORMAT>MacOS</PATHFORMAT>
+ </FILEREF>
+ <FILEREF>
+ <TARGETNAME>Classic Release</TARGETNAME>
+ <PATHTYPE>Name</PATHTYPE>
+ <PATH>MSL C.PPC.Lib</PATH>
+ <PATHFORMAT>MacOS</PATHFORMAT>
+ </FILEREF>
+ <FILEREF>
+ <TARGETNAME>Carbon Debug</TARGETNAME>
+ <PATHTYPE>Name</PATHTYPE>
+ <PATH>MSL C.CARBON.Lib</PATH>
+ <PATHFORMAT>MacOS</PATHFORMAT>
+ </FILEREF>
+*/
+
fout << "</GROUP>\n";
}