forked from OSchip/llvm-project
Remove llvm::EscapeString, raw_ostream::write_escaped is much faster.
llvm-svn: 84357
This commit is contained in:
parent
8eff29d805
commit
59449581b2
|
@ -222,10 +222,6 @@ void SplitString(const std::string &Source,
|
||||||
/// \num (where num is a 1-3 byte octal value).
|
/// \num (where num is a 1-3 byte octal value).
|
||||||
void UnescapeString(std::string &Str);
|
void UnescapeString(std::string &Str);
|
||||||
|
|
||||||
/// EscapeString - Modify the argument string, turning '\\' and anything that
|
|
||||||
/// doesn't satisfy std::isprint into an escape sequence.
|
|
||||||
void EscapeString(std::string &Str);
|
|
||||||
|
|
||||||
/// HashString - Hash funtion for strings.
|
/// HashString - Hash funtion for strings.
|
||||||
///
|
///
|
||||||
/// This is the Bernstein hash function.
|
/// This is the Bernstein hash function.
|
||||||
|
|
|
@ -86,29 +86,3 @@ void llvm::UnescapeString(std::string &Str) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// EscapeString - Modify the argument string, turning '\\' and anything that
|
|
||||||
/// doesn't satisfy std::isprint into an escape sequence.
|
|
||||||
void llvm::EscapeString(std::string &Str) {
|
|
||||||
for (unsigned i = 0; i != Str.size(); ++i) {
|
|
||||||
if (Str[i] == '\\') {
|
|
||||||
++i;
|
|
||||||
Str.insert(Str.begin()+i, '\\');
|
|
||||||
} else if (Str[i] == '\t') {
|
|
||||||
Str[i++] = '\\';
|
|
||||||
Str.insert(Str.begin()+i, 't');
|
|
||||||
} else if (Str[i] == '"') {
|
|
||||||
Str.insert(Str.begin()+i++, '\\');
|
|
||||||
} else if (Str[i] == '\n') {
|
|
||||||
Str[i++] = '\\';
|
|
||||||
Str.insert(Str.begin()+i, 'n');
|
|
||||||
} else if (!std::isprint(Str[i])) {
|
|
||||||
// Always expand to a 3-digit octal escape.
|
|
||||||
unsigned Char = Str[i];
|
|
||||||
Str[i++] = '\\';
|
|
||||||
Str.insert(Str.begin()+i++, '0'+((Char/64) & 7));
|
|
||||||
Str.insert(Str.begin()+i++, '0'+((Char/8) & 7));
|
|
||||||
Str.insert(Str.begin()+i , '0'+( Char & 7));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue