summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastien Barre <sebastien.barre@kitware.com>2001-05-24 18:59:09 (GMT)
committerSebastien Barre <sebastien.barre@kitware.com>2001-05-24 18:59:09 (GMT)
commita2a40b125918797471919f526edea2990e29bc69 (patch)
tree6714eea1dc357bd5a8395fb0bbb146d0507c58b3
parentffd7cfd7c3482531fe8f7469685ff5a0c19e2b68 (diff)
downloadCMake-a2a40b125918797471919f526edea2990e29bc69.zip
CMake-a2a40b125918797471919f526edea2990e29bc69.tar.gz
CMake-a2a40b125918797471919f526edea2990e29bc69.tar.bz2
updated to handle Tk commands compiled/linked separately. Useful for VTK Tk widgets for example.
-rw-r--r--Source/cmVTKWrapTclCommand.cxx124
-rw-r--r--Source/cmVTKWrapTclCommand.h5
2 files changed, 86 insertions, 43 deletions
diff --git a/Source/cmVTKWrapTclCommand.cxx b/Source/cmVTKWrapTclCommand.cxx
index 8080c43..11136b7 100644
--- a/Source/cmVTKWrapTclCommand.cxx
+++ b/Source/cmVTKWrapTclCommand.cxx
@@ -56,39 +56,72 @@ bool cmVTKWrapTclCommand::Invoke(std::vector<std::string>& args)
return true;
}
- // add in a depend in the vtkVTKWrapTcl executable
- m_Makefile->AddUtility("vtkWrapTcl");
-
- // what is the current source dir
- std::string cdir = m_Makefile->GetCurrentDirectory();
-
// keep the library name
m_LibraryName = args[0];
- m_SourceList = args[1];
-
- // get the list of classes for this library
- cmMakefile::SourceMap &Classes = m_Makefile->GetSources();
- for(std::vector<std::string>::iterator j = (args.begin() + 2);
+
+ // extract the sources and commands parameters
+ std::vector<std::string> sources;
+ bool doing_sources = true;
+
+ for(std::vector<std::string>::iterator j = (args.begin() + 1);
j != args.end(); ++j)
{
- cmMakefile::SourceMap::iterator l = Classes.find(*j);
- for(std::vector<cmSourceFile>::iterator i = l->second.begin();
- i != l->second.end(); i++)
+ if(*j == "SOURCES")
+ {
+ doing_sources = true;
+ }
+ else if (*j == "COMMANDS")
{
- cmSourceFile &curr = *i;
- // if we should wrap the class
- if (!curr.GetWrapExclude())
+ doing_sources = false;
+ }
+ else
+ {
+ if(doing_sources)
+ {
+ sources.push_back(*j);
+ }
+ else
+ {
+ m_Commands.push_back(*j);
+ }
+ }
+ }
+
+ // get the list of classes for this library
+ if (sources.size())
+ {
+ // what is the current source dir
+ std::string cdir = m_Makefile->GetCurrentDirectory();
+
+ // add in a depend in the vtkVTKWrapTcl executable
+ m_Makefile->AddUtility("vtkWrapTcl");
+
+ // get the resulting source list name
+ m_SourceList = sources[0];
+
+ cmMakefile::SourceMap &Classes = m_Makefile->GetSources();
+ for(std::vector<std::string>::iterator j = (sources.begin() + 1);
+ j != sources.end(); ++j)
+ {
+ cmMakefile::SourceMap::iterator l = Classes.find(*j);
+ for(std::vector<cmSourceFile>::iterator i = l->second.begin();
+ i != l->second.end(); i++)
{
- cmSourceFile file;
- file.SetIsAnAbstractClass(curr.IsAnAbstractClass());
- std::string newName = curr.GetSourceName() + "Tcl";
- file.SetName(newName.c_str(), m_Makefile->GetCurrentOutputDirectory(),
- "cxx",false);
- std::string hname = cdir + "/" + curr.GetSourceName() + ".h";
- m_WrapHeaders.push_back(hname);
- // add starting depends
- file.GetDepends().push_back(hname);
- m_WrapClasses.push_back(file);
+ cmSourceFile &curr = *i;
+ // if we should wrap the class
+ if (!curr.GetWrapExclude())
+ {
+ cmSourceFile file;
+ file.SetIsAnAbstractClass(curr.IsAnAbstractClass());
+ std::string newName = curr.GetSourceName() + "Tcl";
+ file.SetName(newName.c_str(), m_Makefile->GetCurrentOutputDirectory(),
+ "cxx",false);
+ std::string hname = cdir + "/" + curr.GetSourceName() + ".h";
+ m_WrapHeaders.push_back(hname);
+ // add starting depends
+ file.GetDepends().push_back(hname);
+ m_WrapClasses.push_back(file);
+ }
}
}
}
@@ -135,18 +168,8 @@ void cmVTKWrapTclCommand::FinalPass()
bool cmVTKWrapTclCommand::CreateInitFile(std::string& res)
{
- unsigned int i;
-
/* we have to make sure that the name is the correct case */
- std::string kitName = m_LibraryName;
- if (kitName[0] > 90) kitName[0] -= 32;
- for (i = 1; i < kitName.size(); i++)
- {
- if ((kitName[i] > 64)&&(kitName[i] < 91))
- {
- kitName[i] += 32;
- }
- }
+ std::string kitName = cmSystemTools::Capitalized(m_LibraryName);
std::vector<std::string> classes;
int lastClass = m_WrapHeaders.size();
@@ -187,6 +210,13 @@ bool cmVTKWrapTclCommand::WriteInit(const char *kitName,
{
return false;
}
+
+ // capitalized commands just once
+ std::vector<std::string> capcommands;
+ for (i = 0; i < m_Commands.size(); i++)
+ {
+ capcommands.push_back(cmSystemTools::Capitalized(m_Commands[i]));
+ }
fprintf(fout,"#include \"vtkTclUtil.h\"\n");
@@ -211,14 +241,20 @@ bool cmVTKWrapTclCommand::WriteInit(const char *kitName,
}
fprintf(fout,"extern void vtkTclDeleteObjectFromHash(void *);\n");
fprintf(fout,"extern void vtkTclListInstances(Tcl_Interp *interp, ClientData arg);\n");
+
+ for (i = 0; i < m_Commands.size(); i++)
+ {
+ fprintf(fout,"\nextern \"C\" {int VTK_EXPORT %s_Init(Tcl_Interp *interp);}\n",
+ capcommands[i].c_str());
+ }
- fprintf(fout,"\n\nextern \"C\" {int VTK_EXPORT %s_SafeInit(Tcl_Interp *interp);}\n\n",
+ fprintf(fout,"\n\nextern \"C\" {int VTK_EXPORT %s_SafeInit(Tcl_Interp *interp);}\n",
kitName);
- fprintf(fout,"\n\nextern \"C\" {int VTK_EXPORT %s_Init(Tcl_Interp *interp);}\n\n",
+ fprintf(fout,"\nextern \"C\" {int VTK_EXPORT %s_Init(Tcl_Interp *interp);}\n",
kitName);
/* create an extern ref to the generic delete function */
- fprintf(fout,"\n\nextern void vtkTclGenericDeleteObject(ClientData cd);\n\n");
+ fprintf(fout,"\nextern void vtkTclGenericDeleteObject(ClientData cd);\n");
/* the main declaration */
fprintf(fout,"\n\nint VTK_EXPORT %s_SafeInit(Tcl_Interp *interp)\n{\n",kitName);
@@ -247,6 +283,12 @@ bool cmVTKWrapTclCommand::WriteInit(const char *kitName,
fprintf(fout," Tcl_CreateCommand(interp,(char *) \"vtkCommand\",vtkCommand,\n (ClientData *)NULL, NULL);\n\n");
}
+ for (i = 0; i < m_Commands.size(); i++)
+ {
+ fprintf(fout," %s_Init(interp);\n", capcommands[i].c_str());
+ }
+ fprintf(fout,"\n");
+
for (i = 0; i < classes.size(); i++)
{
fprintf(fout," vtkTclCreateNew(interp,(char *) \"%s\", %sNewCommand,\n",
diff --git a/Source/cmVTKWrapTclCommand.h b/Source/cmVTKWrapTclCommand.h
index a13025a..2e9da6e 100644
--- a/Source/cmVTKWrapTclCommand.h
+++ b/Source/cmVTKWrapTclCommand.h
@@ -5,7 +5,7 @@
#include "cmCommand.h"
/** \class cmVTKWrapTclCommand
- * \brief Define a command that searches for an include file.
+ * \brief Create Tcl Wrappers for VTK classes.
*
* cmVTKWrapTclCommand is used to define a CMake variable include
* path location by specifying a file and list of directories.
@@ -61,7 +61,7 @@ public:
virtual const char* GetFullDocumentation()
{
return
- "VTK_WRAP_TCL(resultingLibraryName SourceListName SourceLists ...)";
+ "VTK_WRAP_TCL(resultingLibraryName [SOURCES] SourceListName SourceLists ... [COMMANDS CommandName1 CommandName2 ...])";
}
/**
@@ -76,6 +76,7 @@ private:
std::vector<std::string> m_WrapHeaders;
std::string m_LibraryName;
std::string m_SourceList;
+ std::vector<std::string> m_Commands;
};