本文整理汇总了C++中ustring类的典型用法代码示例。如果您正苦于以下问题:C++ ustring类的具体用法?C++ ustring怎么用?C++ ustring使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了ustring类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: ASTNode
ASTfunction_declaration::ASTfunction_declaration (OSLCompilerImpl *comp,
TypeSpec type, ustring name,
ASTNode *form, ASTNode *stmts, ASTNode *meta)
: ASTNode (function_declaration_node, comp, 0, meta, form, stmts),
m_name(name), m_sym(NULL), m_is_builtin(false)
{
m_typespec = type;
Symbol *f = comp->symtab().clash (name);
if (f && f->symtype() != SymTypeFunction) {
error ("\"%s\" already declared in this scope as a ", name.c_str(),
f->typespec().string().c_str());
// FIXME -- print the file and line of the other definition
f = NULL;
}
// FIXME -- allow multiple function declarations, but only if they
// aren't the same polymorphic type.
if (name[0] == '_' && name[1] == '_' && name[2] == '_') {
error ("\"%s\" : sorry, can't start with three underscores",
name.c_str());
}
m_sym = new FunctionSymbol (name, type, this);
func()->nextpoly ((FunctionSymbol *)f);
std::string argcodes = oslcompiler->code_from_type (m_typespec);
for (ASTNode *arg = form; arg; arg = arg->nextptr()) {
const TypeSpec &t (arg->typespec());
if (t == TypeSpec() /* UNKNOWN */) {
m_typespec = TypeDesc::UNKNOWN;
return;
}
argcodes += oslcompiler->code_from_type (t);
ASSERT (arg->nodetype() == variable_declaration_node);
ASTvariable_declaration *v = (ASTvariable_declaration *)arg;
if (v->init())
v->error ("function parameter '%s' may not have a default initializer.",
v->name().c_str());
}
func()->argcodes (ustring (argcodes));
oslcompiler->symtab().insert (m_sym);
// Typecheck it right now, upon declaration
typecheck (typespec ());
}
示例2: gw_path_get_dirname
ustring gw_path_get_dirname(const ustring & filename)
{
ustring returnvalue;
gchar *dirname;
dirname = g_path_get_dirname(filename.c_str());
returnvalue = dirname;
g_free(dirname);
return returnvalue;
}
示例3: gw_path_get_basename
ustring gw_path_get_basename(const ustring & filename)
{
ustring returnvalue;
gchar *basename;
basename = g_path_get_basename(filename.c_str());
returnvalue = basename;
g_free(basename);
return returnvalue;
}
示例4: getMarkedCharPos
_size_t_ getMarkedCharPos (ustring ch) {
_size_t_ mark =
LettersWithMarks.find (removeAccentFromChar (ch.lowercase ()));
if (mark != ustring::npos)
mark %= LettersWithoutMarks.length ();
return mark;
}
示例5:
void CGlobalRecords::wide2str16(const ustring& str1, u16string& str2)
{
ustring::const_iterator cBegin, cEnd;
size_t len;
str2.clear();
len = str1.length();
str2.reserve(len);
cBegin = str1.begin();
cEnd = str1.end();
while(cBegin != cEnd) {
str2.push_back((unsigned16_t)*cBegin++);
}
XL_ASSERT(str2.length() == str1.length());
}
示例6: parsePixbuf
void DataValue::parsePixbuf(const ustring &text, void *value) {
gsize size;
guchar *buf = g_base64_decode(text.c_str(), &size);
Glib::RefPtr<Gdk::PixbufLoader> loader = Gdk::PixbufLoader::create();
loader->write(buf, size);
loader->close();
(*(TypePixbuf*)value) = loader->get_pixbuf();
g_free(buf);
}
示例7: ascii_toupper
inline ustring ascii_toupper(ustring str)
{
ustring ret;
for (ustring::const_iterator it = str.begin();
it != str.end();
++it)
{
uchar x = *it;
if (x >= 0x61 && x <= 0x7A)
x -= 0x20;
ret.append(x);
}
return ret;
}
示例8: script_decode_usfm_file
void script_decode_usfm_file(const ustring & filename)
// Decodes a USFM file, that means, puts the original USFM code back.
{
// Read the file. Bail out if there's no text.
ustring input;
{
gchar *contents;
g_file_get_contents(filename.c_str(), &contents, NULL, NULL);
if (!contents)
return;
input = contents;
g_free(contents);
}
if (input.empty())
return;
// Go through the input, changing usfm codes to their numerical equivalent,
// and copying data to the output.
// E.g. "\_105_100" would become "\id".
ustring output;
while (!input.empty()) {
ustring character = input.substr(0, 1);
input.erase(0, 1);
output.append(character);
if (character == "\\") {
size_t pos = input.find(" ");
if (pos == string::npos)
pos = input.length();
ustring encoded_text = input.substr(0, pos);
input.erase(0, pos);
Parse parse(encoded_text, false, "_");
for (unsigned int i = 0; i < parse.words.size(); i++) {
gunichar unichar = convert_to_int(parse.words[i]);
gchar buf[7];
gint length = g_unichar_to_utf8(unichar, (gchar *) & buf);
buf[length] = '\0';
character = buf;
output.append(character);
}
}
}
// Write the data back to the file.
g_file_set_contents(filename.c_str(), output.c_str(), -1, NULL);
}
示例9: ASTNode
ASTvariable_declaration::ASTvariable_declaration (OSLCompilerImpl *comp,
const TypeSpec &type,
ustring name, ASTNode *init,
bool isparam, bool ismeta,
bool isoutput, bool initlist)
: ASTNode (variable_declaration_node, comp, 0, init, NULL /* meta */),
m_name(name), m_sym(NULL),
m_isparam(isparam), m_isoutput(isoutput), m_ismetadata(ismeta),
m_initlist(initlist)
{
m_typespec = type;
Symbol *f = comp->symtab().clash (name);
if (f) {
std::string e = Strutil::format ("\"%s\" already declared in this scope", name.c_str());
if (f->node()) {
boost::filesystem::path p(f->node()->sourcefile().string());
e += Strutil::format ("\n\t\tprevious declaration was at %s:%d",
p.filename().c_str(), f->node()->sourceline());
}
if (f->scope() == 0 && f->symtype() == SymTypeFunction && isparam) {
// special case: only a warning for param to mask global function
warning ("%s", e.c_str());
} else {
error ("%s", e.c_str());
}
}
if (name[0] == '_' && name[1] == '_' && name[2] == '_') {
error ("\"%s\" : sorry, can't start with three underscores",
name.c_str());
}
SymType symtype = isparam ? (isoutput ? SymTypeOutputParam : SymTypeParam)
: SymTypeLocal;
m_sym = new Symbol (name, type, symtype, this);
if (! m_ismetadata)
oslcompiler->symtab().insert (m_sym);
// A struct really makes several subvariables
if (type.is_structure() || type.is_structure_array()) {
ASSERT (! m_ismetadata);
// Add the fields as individual declarations
m_compiler->add_struct_fields (type.structspec(), m_sym->name(),
symtype, type.arraylength(), this);
}
}
示例10: q
int
Dictionary::dict_find (int nodeID, ustring query)
{
if (nodeID <= 0 || nodeID >= (int)m_nodes.size())
return 0; // invalid node ID
const Dictionary::Node &node (m_nodes[nodeID]);
Query q (node.document, nodeID, query);
QueryMap::iterator qfound = m_cache.find (q);
if (qfound != m_cache.end()) {
return qfound->second.valueoffset;
}
// Query was not found. Do the expensive lookup and cache it
pugi::xpath_node_set matches;
try {
matches = node.node.select_nodes (query.c_str());
}
catch (const pugi::xpath_exception& e) {
m_context->error ("Invalid dict_find query '%s': %s",
query.c_str(), e.what());
return 0;
}
if (matches.empty()) {
m_cache[q] = QueryResult (false); // mark invalid
return 0; // Not found
}
int firstmatch = (int) m_nodes.size();
int last = -1;
for (int i = 0, e = (int)matches.size(); i < e; ++i) {
m_nodes.push_back (Node (node.document, matches[i].node()));
int nodeid = (int) m_nodes.size()-1;
if (last < 0) {
// If this is the first match, add a cache entry for it
m_cache[q] = QueryResult (true /* it's a node */, nodeid);
} else {
// If this is a subsequent match, set the last match's 'next'
m_nodes[last].next = nodeid;
}
last = nodeid;
}
return firstmatch;
}
示例11: script_encode_usfm_file
void script_encode_usfm_file(const ustring & filename)
// Encodes a USFM file. The purpose is that the USFM marked are not changed by the script.
// The assumption is that numbers are not affected.
{
// Read the file. Bail out if there's no text.
ustring input;
{
gchar *contents;
g_file_get_contents(filename.c_str(), &contents, NULL, NULL);
if (!contents)
return;
input = contents;
g_free(contents);
}
if (input.empty())
return;
// Go through the input, changing usfm codes to their numerical equivalent,
// and copying data to the output.
// E.g. "\id" would become "\_105_100".
ustring output;
bool within_usfm = false;
for (unsigned int i = 0; i < input.length(); i++) {
ustring character = input.substr(i, 1);
if (within_usfm)
if (character == " ")
within_usfm = false;
if (within_usfm) {
gunichar unichar;
gunichar *uc;
uc = g_utf8_to_ucs4_fast(character.c_str(), -1, NULL);
unichar = *uc;
g_free(uc);
character = "_" + convert_to_string(unichar);
}
output.append(character);
if (character == "\\")
within_usfm = true;
}
// Write the data back to the file.
g_file_set_contents(filename.c_str(), output.c_str(), -1, NULL);
}
示例12: getAccentFromChar
Accents getAccentFromChar (ustring ch) {
_size_t_ accent = VowelsWithAccents.find (ch.lowercase ());
if (accent != ustring::npos)
accent %= NUMBER_OF_ACCENTS;
else
accent = NO_ACCENT;
return accent;
}
示例13: bibleworks_define_parsing_person
void bibleworks_define_parsing_person (ustring& parsing, ustring& definition)
// This looks in the "parsing" whether the person is given.
// If so, it adds the description to the "definition" and removes the relevant code from the "parsing".
{
ustring person = parsing.substr (0, 1);
bool person_found = true;
if (person == "1") {
definition.append (" first person");
} else if (person == "2") {
definition.append (" second person");
} else if (person == "3") {
definition.append (" third person");
} else {
person_found = false;
}
if (person_found) {
parsing.erase (0, 1);
}
}
示例14: fprintf
void
OSLCompilerImpl::warning (ustring filename, int line, const char *format, ...)
{
va_list ap;
va_start (ap, format);
std::string errmsg = format ? OIIO::Strutil::vformat (format, ap) : "";
fprintf (stderr, "%s:%d: warning: %s\n",
filename.c_str(), line, errmsg.c_str());
va_end (ap);
}
示例15: check_matched_pairs
void CheckMatchingPairs::check_matched_pairs(ustring & text)
// Checks on matched pairs. Output any problems found.
{
for (unsigned int i = 0; i < text.length(); i++) {
// Get the unicode character;
gunichar unichar;
unichar = g_utf8_get_char(text.substr(i, 1).c_str());
// If we found a mirror character, investigate further.
gunichar mirror;
if (g_unichar_get_mirror_char(unichar, &mirror)) {
// Do we ignore this one?
if (ignores.find(unichar) != ignores.end())
continue;
// See whether this one opens or closes a pair.
if (gopeners.find(unichar) != gopeners.end()) {
// It opens: Add data.
MatchingPairOpener opener(text.substr(i, 1), unichar, book, chapter, verse, get_context(text, i));
openers.push_back(opener);
continue;
} else {
// It closes: check for previously seen opener.
bool give_message = false;
if (openers.empty()) {
give_message = true;
}
if (!give_message) {
if (openers[openers.size() - 1].unichar == mirror) {
// Remove last one.
openers.pop_back();
} else {
// Flag message.
give_message = true;
}
}
if (give_message) {
// Give message;
message(book, chapter, verse, _("Pair not opened: ") + get_context(text, i));
}
}
}
}
}