From 8491551d6a290cf9f906b0e43c47a244ab832dd8 Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Tue, 17 Sep 2002 14:19:50 -0400 Subject: [PATCH] Strip the string that user answers --- Source/cmakewizard.cxx | 30 +++++++++++++++++++++--------- 1 file changed, 21 insertions(+), 9 deletions(-) diff --git a/Source/cmakewizard.cxx b/Source/cmakewizard.cxx index db86ef1e4..47e3b9c3e 100644 --- a/Source/cmakewizard.cxx +++ b/Source/cmakewizard.cxx @@ -39,22 +39,34 @@ void cmakewizard::AskUser(const char* key, cmCacheManager::CacheIterator& iter) char buffer[4096]; buffer[0] = 0; fgets(buffer, sizeof(buffer)-1, stdin); - if(buffer[0]) + char ch = 0; + + if(strlen(buffer) > 0) { - std::string value = buffer; - if(iter.GetType() == cmCacheManager::PATH || - iter.GetType() == cmCacheManager::FILEPATH) + std::string sbuffer = buffer; + std::string::size_type pos = sbuffer.find_last_not_of(" \n\r\t"); + std::string value = ""; + if ( pos != std::string::npos ) { - cmSystemTools::ConvertToUnixSlashes(value); + value = sbuffer.substr(0, pos+1); } - if(iter.GetType() == cmCacheManager::BOOL) + + if ( value.size() > 0 ) { - if(!cmSystemTools::IsOn(value.c_str())) + if(iter.GetType() == cmCacheManager::PATH || + iter.GetType() == cmCacheManager::FILEPATH) { - value = "OFF"; + cmSystemTools::ConvertToUnixSlashes(value); } + if(iter.GetType() == cmCacheManager::BOOL) + { + if(!cmSystemTools::IsOn(value.c_str())) + { + value = "OFF"; + } + } + iter.SetValue(value.c_str()); } - iter.SetValue(value.c_str()); } std::cout << "\n"; }