CTest: Fix locale used for VCS updates
6a661f0603
fixed the
locale used for message output but at the same time broke the locale
used for filename encodings.
This commit preserves LC_CTYPE in the presence of LC_ALL.
This commit is contained in:
parent
48040c19d5
commit
a198839a7b
|
@ -159,6 +159,8 @@ set(SRCS
|
||||||
cmCacheManager.cxx
|
cmCacheManager.cxx
|
||||||
cmCacheManager.h
|
cmCacheManager.h
|
||||||
"${CMAKE_CURRENT_BINARY_DIR}/cmCommands.cxx"
|
"${CMAKE_CURRENT_BINARY_DIR}/cmCommands.cxx"
|
||||||
|
cmCLocaleEnvironmentScope.h
|
||||||
|
cmCLocaleEnvironmentScope.cxx
|
||||||
cmCommands.h
|
cmCommands.h
|
||||||
cmCommandArgumentLexer.cxx
|
cmCommandArgumentLexer.cxx
|
||||||
cmCommandArgumentParser.cxx
|
cmCommandArgumentParser.cxx
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include "cmGeneratedFileStream.h"
|
#include "cmGeneratedFileStream.h"
|
||||||
#include "cmXMLParser.h"
|
#include "cmXMLParser.h"
|
||||||
#include "cmXMLSafe.h"
|
#include "cmXMLSafe.h"
|
||||||
|
#include "cmCLocaleEnvironmentScope.h"
|
||||||
|
|
||||||
#include "cmCTestVC.h"
|
#include "cmCTestVC.h"
|
||||||
#include "cmCTestCVS.h"
|
#include "cmCTestCVS.h"
|
||||||
|
@ -66,46 +67,6 @@ static const char* cmCTestUpdateHandlerUpdateToString(int type)
|
||||||
return cmCTestUpdateHandlerUpdateStrings[type];
|
return cmCTestUpdateHandlerUpdateStrings[type];
|
||||||
}
|
}
|
||||||
|
|
||||||
class cmCTestUpdateHandlerLocale
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
cmCTestUpdateHandlerLocale();
|
|
||||||
~cmCTestUpdateHandlerLocale();
|
|
||||||
private:
|
|
||||||
std::string saveLCAll;
|
|
||||||
};
|
|
||||||
|
|
||||||
cmCTestUpdateHandlerLocale::cmCTestUpdateHandlerLocale()
|
|
||||||
{
|
|
||||||
const char* lcall = cmSystemTools::GetEnv("LC_ALL");
|
|
||||||
if(lcall)
|
|
||||||
{
|
|
||||||
saveLCAll = lcall;
|
|
||||||
}
|
|
||||||
// if LC_ALL is not set to C, then
|
|
||||||
// set it, so that svn/cvs info will be in english ascii
|
|
||||||
if(! (lcall && strcmp(lcall, "C") == 0))
|
|
||||||
{
|
|
||||||
cmSystemTools::PutEnv("LC_ALL=C");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
cmCTestUpdateHandlerLocale::~cmCTestUpdateHandlerLocale()
|
|
||||||
{
|
|
||||||
// restore the value of LC_ALL after running the version control
|
|
||||||
// commands
|
|
||||||
if(!saveLCAll.empty())
|
|
||||||
{
|
|
||||||
std::string put = "LC_ALL=";
|
|
||||||
put += saveLCAll;
|
|
||||||
cmSystemTools::PutEnv(put);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
cmSystemTools::UnsetEnv("LC_ALL");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
cmCTestUpdateHandler::cmCTestUpdateHandler()
|
cmCTestUpdateHandler::cmCTestUpdateHandler()
|
||||||
{
|
{
|
||||||
|
@ -194,7 +155,7 @@ int cmCTestUpdateHandler::DetermineType(const char* cmd, const char* type)
|
||||||
int cmCTestUpdateHandler::ProcessHandler()
|
int cmCTestUpdateHandler::ProcessHandler()
|
||||||
{
|
{
|
||||||
// Make sure VCS tool messages are in English so we can parse them.
|
// Make sure VCS tool messages are in English so we can parse them.
|
||||||
cmCTestUpdateHandlerLocale fixLocale;
|
cmCLocaleEnvironmentScope fixLocale;
|
||||||
static_cast<void>(fixLocale);
|
static_cast<void>(fixLocale);
|
||||||
|
|
||||||
// Get source dir
|
// Get source dir
|
||||||
|
|
|
@ -0,0 +1,67 @@
|
||||||
|
/*============================================================================
|
||||||
|
CMake - Cross Platform Makefile Generator
|
||||||
|
Copyright 2015 Kitware, Inc., Insight Software Consortium
|
||||||
|
|
||||||
|
Distributed under the OSI-approved BSD License (the "License");
|
||||||
|
see accompanying file Copyright.txt for details.
|
||||||
|
|
||||||
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
||||||
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
See the License for more information.
|
||||||
|
============================================================================*/
|
||||||
|
|
||||||
|
#include "cmCLocaleEnvironmentScope.h"
|
||||||
|
|
||||||
|
#include "cmSystemTools.h"
|
||||||
|
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
cmCLocaleEnvironmentScope::cmCLocaleEnvironmentScope()
|
||||||
|
{
|
||||||
|
this->SetEnv("LANGUAGE", "");
|
||||||
|
this->SetEnv("LC_MESSAGES", "C");
|
||||||
|
|
||||||
|
std::string lcAll = this->GetEnv("LC_ALL");
|
||||||
|
|
||||||
|
if(!lcAll.empty())
|
||||||
|
{
|
||||||
|
this->SetEnv("LC_ALL", "");
|
||||||
|
this->SetEnv("LC_CTYPE", lcAll);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string cmCLocaleEnvironmentScope::GetEnv(std::string const& key)
|
||||||
|
{
|
||||||
|
const char* value = cmSystemTools::GetEnv(key);
|
||||||
|
return value ? value : std::string();
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmCLocaleEnvironmentScope::SetEnv(
|
||||||
|
std::string const& key, std::string const& value)
|
||||||
|
{
|
||||||
|
std::string oldValue = this->GetEnv(key);
|
||||||
|
|
||||||
|
this->EnvironmentBackup.insert(std::make_pair(key, oldValue));
|
||||||
|
|
||||||
|
if(value.empty())
|
||||||
|
{
|
||||||
|
cmSystemTools::UnsetEnv(key.c_str());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::stringstream tmp;
|
||||||
|
tmp << key << "=" << value;
|
||||||
|
cmSystemTools::PutEnv(tmp.str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cmCLocaleEnvironmentScope::~cmCLocaleEnvironmentScope()
|
||||||
|
{
|
||||||
|
for(backup_map_t::const_iterator i = this->EnvironmentBackup.begin();
|
||||||
|
i != this->EnvironmentBackup.end(); ++i)
|
||||||
|
{
|
||||||
|
std::stringstream tmp;
|
||||||
|
tmp << i->first << "=" << i->second;
|
||||||
|
cmSystemTools::PutEnv(tmp.str());
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,32 @@
|
||||||
|
/*============================================================================
|
||||||
|
CMake - Cross Platform Makefile Generator
|
||||||
|
Copyright 2015 Kitware, Inc., Insight Software Consortium
|
||||||
|
|
||||||
|
Distributed under the OSI-approved BSD License (the "License");
|
||||||
|
see accompanying file Copyright.txt for details.
|
||||||
|
|
||||||
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
||||||
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
See the License for more information.
|
||||||
|
============================================================================*/
|
||||||
|
|
||||||
|
#ifndef cmCLocaleEnvironmentScope_h
|
||||||
|
#define cmCLocaleEnvironmentScope_h
|
||||||
|
|
||||||
|
#include "cmStandardIncludes.h"
|
||||||
|
|
||||||
|
class cmCLocaleEnvironmentScope
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
cmCLocaleEnvironmentScope();
|
||||||
|
~cmCLocaleEnvironmentScope();
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::string GetEnv(std::string const& key);
|
||||||
|
void SetEnv(std::string const& key, std::string const& value);
|
||||||
|
|
||||||
|
typedef std::map<std::string, std::string> backup_map_t;
|
||||||
|
backup_map_t EnvironmentBackup;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue