Merge branch 'upstream-kwsys' into update-kwsys
This commit is contained in:
commit
23b4abb260
|
@ -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;
|
||||||
|
|
|
@ -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. */
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue