Merge branch 'upstream-kwsys' into update-kwsys

This commit is contained in:
Brad King 2014-04-03 08:43:51 -04:00
commit 23b4abb260
3 changed files with 46 additions and 12 deletions

View File

@ -110,16 +110,19 @@ Encoding::CommandLineArguments::
Encoding::CommandLineArguments& Encoding::CommandLineArguments&
Encoding::CommandLineArguments::operator=(const CommandLineArguments& other) Encoding::CommandLineArguments::operator=(const CommandLineArguments& other)
{ {
size_t i; if(this != &other)
for(i=0; i<this->argv_.size(); i++)
{ {
free(this->argv_[i]); size_t i;
} for(i=0; i<this->argv_.size(); i++)
{
free(this->argv_[i]);
}
this->argv_.resize(other.argv_.size()); this->argv_.resize(other.argv_.size());
for(i=0; i<this->argv_.size(); i++) for(i=0; i<this->argv_.size(); i++)
{ {
this->argv_[i] = other.argv_[i] ? strdup(other.argv_[i]) : 0; this->argv_[i] = other.argv_[i] ? strdup(other.argv_[i]) : 0;
}
} }
return *this; return *this;

View File

@ -353,6 +353,10 @@ static int kwsysSystem_Shell__GetArgumentSize(const char* in,
if(kwsysSystem_Shell__ArgumentNeedsQuotes(in, isUnix, flags)) if(kwsysSystem_Shell__ArgumentNeedsQuotes(in, isUnix, flags))
{ {
/* Surrounding quotes are needed. Allocate space for them. */ /* Surrounding quotes are needed. Allocate space for them. */
if((flags & kwsysSystem_Shell_Flag_WatcomQuote) && (isUnix))
{
size += 2;
}
size += 2; size += 2;
/* We must escape all ending backslashes when quoting on windows. */ /* We must escape all ending backslashes when quoting on windows. */
@ -377,7 +381,18 @@ static char* kwsysSystem_Shell__GetArgument(const char* in, char* out,
if(needQuotes) if(needQuotes)
{ {
/* Add the opening quote for this argument. */ /* Add the opening quote for this argument. */
*out++ = '"'; if(flags & kwsysSystem_Shell_Flag_WatcomQuote)
{
if(isUnix)
{
*out++ = '"';
}
*out++ = '\'';
}
else
{
*out++ = '"';
}
} }
/* Scan the string for characters that require escaping or quoting. */ /* Scan the string for characters that require escaping or quoting. */
@ -549,7 +564,18 @@ static char* kwsysSystem_Shell__GetArgument(const char* in, char* out,
} }
/* Add the closing quote for this argument. */ /* Add the closing quote for this argument. */
*out++ = '"'; if(flags & kwsysSystem_Shell_Flag_WatcomQuote)
{
*out++ = '\'';
if(isUnix)
{
*out++ = '"';
}
}
else
{
*out++ = '"';
}
} }
/* Store a terminating null without incrementing. */ /* Store a terminating null without incrementing. */

View File

@ -36,6 +36,7 @@
# define kwsysSystem_Shell_Flag_MinGWMake kwsys_ns(System_Shell_Flag_MinGWMake) # define kwsysSystem_Shell_Flag_MinGWMake kwsys_ns(System_Shell_Flag_MinGWMake)
# define kwsysSystem_Shell_Flag_NMake kwsys_ns(System_Shell_Flag_NMake) # define kwsysSystem_Shell_Flag_NMake kwsys_ns(System_Shell_Flag_NMake)
# define kwsysSystem_Shell_Flag_AllowMakeVariables kwsys_ns(System_Shell_Flag_AllowMakeVariables) # define kwsysSystem_Shell_Flag_AllowMakeVariables kwsys_ns(System_Shell_Flag_AllowMakeVariables)
# define kwsysSystem_Shell_Flag_WatcomQuote kwsys_ns(System_Shell_Flag_WatcomQuote)
#endif #endif
#ifdef __VMS #ifdef __VMS
@ -102,14 +103,17 @@ enum kwsysSystem_Shell_Flag_e
kwsysSystem_Shell_Flag_MinGWMake = (1<<4), kwsysSystem_Shell_Flag_MinGWMake = (1<<4),
/** The target shell is in a NMake makefile. */ /** The target shell is in a NMake makefile. */
kwsysSystem_Shell_Flag_NMake = (1<<6), kwsysSystem_Shell_Flag_NMake = (1<<5),
/** Make variable reference syntax $(MAKEVAR) should not be escaped /** Make variable reference syntax $(MAKEVAR) should not be escaped
to allow a build tool to replace it. Replacement values to allow a build tool to replace it. Replacement values
containing spaces, quotes, backslashes, or other containing spaces, quotes, backslashes, or other
non-alphanumeric characters that have significance to some makes non-alphanumeric characters that have significance to some makes
or shells produce undefined behavior. */ or shells produce undefined behavior. */
kwsysSystem_Shell_Flag_AllowMakeVariables = (1<<5) kwsysSystem_Shell_Flag_AllowMakeVariables = (1<<6),
/** The target shell quoting uses extra single Quotes for Watcom tools. */
kwsysSystem_Shell_Flag_WatcomQuote = (1<<7)
}; };
/** /**
@ -156,6 +160,7 @@ kwsysEXPORT char** kwsysSystem_Parse_CommandForUnix(const char* command,
# undef kwsysSystem_Shell_Flag_MinGWMake # undef kwsysSystem_Shell_Flag_MinGWMake
# undef kwsysSystem_Shell_Flag_NMake # undef kwsysSystem_Shell_Flag_NMake
# undef kwsysSystem_Shell_Flag_AllowMakeVariables # undef kwsysSystem_Shell_Flag_AllowMakeVariables
# undef kwsysSystem_Shell_Flag_WatcomQuote
# endif # endif
#endif #endif