diff options
Diffstat (limited to 'Source/CursesDialog/ccmake.cxx')
-rw-r--r-- | Source/CursesDialog/ccmake.cxx | 84 |
1 files changed, 57 insertions, 27 deletions
diff --git a/Source/CursesDialog/ccmake.cxx b/Source/CursesDialog/ccmake.cxx index 61e50e2..e47e382 100644 --- a/Source/CursesDialog/ccmake.cxx +++ b/Source/CursesDialog/ccmake.cxx @@ -1,5 +1,6 @@ #include "../cmCacheManager.h" #include "../cmSystemTools.h" +#include "../cmake.h" #include <signal.h> #include <sys/ioctl.h> @@ -9,11 +10,11 @@ #include <curses.h> #include <form.h> -static cmCursesMainForm* myform=0; +cmCursesForm* cmCursesForm::CurrentForm=0; void onsig(int sig) { - if (myform) + if (cmCursesForm::CurrentForm) { endwin(); WINDOW* w= initscr(); /* Initialization */ @@ -23,30 +24,44 @@ void onsig(int sig) KEY_DOWN*/ refresh(); int x,y; - getmaxyx(w, y, x); - myform->SetWindow(w); - myform->Render(1,1,x,y); - myform->UpdateStatusBar(); + getmaxyx(stdscr, y, x); + cmCursesForm::CurrentForm->Render(1,1,x,y); + cmCursesForm::CurrentForm->UpdateStatusBar(); } signal(SIGWINCH, onsig); } +void CMakeErrorHandler(const char* message, const char* title, bool& disable) +{ + cmCursesForm::CurrentForm->AddError(message, title); +} + int main(int argc, char** argv) { + unsigned int i; + cmake msg; + std::vector<std::string> args; + for(i =0; i < argc; ++i) + { + args.push_back(argv[i]); + } - if ( argc > 2 ) + for(i=1; i < args.size(); ++i) { - std::cerr << "Usage: " << argv[0] << " source_directory." - << std::endl; - return -1; + std::string arg = args[i]; + if(arg.find("-help",0) != std::string::npos || + arg.find("--help",0) != std::string::npos || + arg.find("/?",0) != std::string::npos || + arg.find("-usage",0) != std::string::npos) + { + msg.Usage(args[0].c_str()); + return -1; + } } - int newCache = false; - if (!cmCacheManager::GetInstance()->LoadCache(cmSystemTools::GetCurrentWorkingDirectory().c_str())) - { - newCache = true; - } + cmSystemTools::DisableRunCommandOutput(); + cmCacheManager::GetInstance()->LoadCache(cmSystemTools::GetCurrentWorkingDirectory().c_str()); WINDOW* w=initscr(); /* Initialization */ noecho(); /* Echo off */ @@ -57,25 +72,40 @@ int main(int argc, char** argv) signal(SIGWINCH, onsig); int x,y; - getmaxyx(w, y, x); - std::string whereCMake = cmSystemTools::GetProgramPath(argv[0]); - whereCMake += "/cmake"; - if ( argc == 2 ) + getmaxyx(stdscr, y, x); + if ( x < cmCursesMainForm::MIN_WIDTH || + y < cmCursesMainForm::MIN_HEIGHT ) { - - myform = new cmCursesMainForm(argv[1], whereCMake.c_str(), newCache); - } - else - { - myform = new cmCursesMainForm("", whereCMake.c_str(), newCache); + endwin(); + std::cerr << "Window is too small. A size of at least " + << cmCursesMainForm::MIN_WIDTH << " x " + << cmCursesMainForm::MIN_HEIGHT + << " is required to run ccmake." << std::endl; + return 1; } - myform->InitializeUI(w); + + + cmCursesMainForm* myform; + + myform = new cmCursesMainForm(args); + + cmSystemTools::SetErrorCallback(CMakeErrorHandler); + + cmCursesForm::CurrentForm = myform; + + myform->InitializeUI(); + myform->RunCMake(false); + myform->Render(1, 1, x, y); myform->HandleInput(); // Need to clean-up better + clear(); + touchwin(stdscr); endwin(); - delete myform; + delete cmCursesForm::CurrentForm; + cmCursesForm::CurrentForm = 0; + return 0; } |