summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKen Martin <ken.martin@kitware.com>2006-05-22 19:41:52 (GMT)
committerKen Martin <ken.martin@kitware.com>2006-05-22 19:41:52 (GMT)
commit53dce3b2314d4f3c95d60b5027fec18e8beb02a9 (patch)
tree87b070c897a975956a44eb9d3e720944f6db0cb3
parent29b75dda9789768ad8b3699d13f48d1f6d49051e (diff)
downloadCMake-53dce3b2314d4f3c95d60b5027fec18e8beb02a9.zip
CMake-53dce3b2314d4f3c95d60b5027fec18e8beb02a9.tar.gz
CMake-53dce3b2314d4f3c95d60b5027fec18e8beb02a9.tar.bz2
ENH: part of the progress reporting checkin
-rw-r--r--Source/cmake.cxx63
1 files changed, 63 insertions, 0 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx
index f037fc3..d3801cc 100644
--- a/Source/cmake.cxx
+++ b/Source/cmake.cxx
@@ -29,6 +29,7 @@
# include "cmVariableWatch.h"
# include "cmVersion.h"
# include <cmsys/Terminal.h>
+# include <cmsys/Directory.hxx>
#endif
// only build kdevelop generator on non-windows platforms
@@ -973,6 +974,68 @@ int cmake::ExecuteCMakeCommand(std::vector<std::string>& args)
return 1;
}
+ // Command to start progress for a build
+ else if (args[1] == "cmake_progress_start" && args.size() == 4)
+ {
+ // bascially remove the directory
+ std::string dirName = args[2];
+ dirName += "/Progress";
+ cmSystemTools::RemoveADirectory(dirName.c_str());
+ cmSystemTools::MakeDirectory(dirName.c_str());
+ // write the count into the directory
+ std::string fName = dirName;
+ fName += "/count.txt";
+ FILE *progFile = fopen(fName.c_str(),"w");
+ if (progFile)
+ {
+ int count = atoi(args[3].c_str());
+ fprintf(progFile,"%i\n",count);
+ fclose(progFile);
+ }
+ return 0;
+ }
+
+ // Command to report progress for a build
+ else if (args[1] == "cmake_progress_report" && args.size() >= 4)
+ {
+ std::string dirName = args[2];
+ dirName += "/Progress";
+ std::string fName;
+ FILE *progFile;
+ unsigned int i;
+ for (i = 3; i < args.size(); ++i)
+ {
+ fName = dirName;
+ fName += "/";
+ fName += args[i];
+ progFile = fopen(fName.c_str(),"w");
+ if (progFile)
+ {
+ fprintf(progFile,"empty");
+ fclose(progFile);
+ }
+ }
+ cmsys::Directory dir;
+ dir.Load(dirName.c_str());
+ size_t fileNum = dir.GetNumberOfFiles();
+ // read the count
+ fName = dirName;
+ fName += "/count.txt";
+ progFile = fopen(fName.c_str(),"r");
+ if (progFile)
+ {
+ int count = 0;
+ fscanf(progFile,"%i",&count);
+ if (count > 0)
+ {
+ // print the progress
+ fprintf(stdout,"%3i%% complete\n",((fileNum-3)*100)/count);
+ }
+ fclose(progFile);
+ }
+ return 0;
+ }
+
// Command to create a symbolic link. Fails on platforms not
// supporting them.
else if (args[1] == "create_symlink" && args.size() == 4)