本文整理汇总了C++中ParseException函数的典型用法代码示例。如果您正苦于以下问题:C++ ParseException函数的具体用法?C++ ParseException怎么用?C++ ParseException使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了ParseException函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: loadFile
static std::string
loadFile (boost::property_tree::ptree &config,
const boost::filesystem::path &file)
{
boost::filesystem::path extension = file.extension();
boost::filesystem::path extension2 = file.stem().extension();
std::string fileName = file.filename().string();
boost::property_tree::ptree readConfig;
if (extension2.string() == ".conf") {
if (extension.string() == ".json") {
boost::property_tree::read_json (file.string(), readConfig);
} else if (extension.string() == ".info") {
boost::property_tree::read_info (file.string(), readConfig);
} else if (extension.string() == ".ini") {
boost::property_tree::read_ini (file.string(), readConfig);
} else if (extension.string() == ".xml") {
boost::property_tree::read_xml (file.string(), readConfig);
} else {
throw ParseException ("Unknonw file format");
}
} else {
throw ParseException ("Unknonw file format");
}
mergePropertyTrees (config, readConfig);
config.put ("configPath", file.parent_path().string() );
fileName = fileName.substr (0, fileName.size() - extension.string().size() );
fileName = fileName.substr (0, fileName.size() - extension2.string().size() );
return fileName;
}
示例2: while
bool EntTokenizer::NextKV()
{
while(currentPtr != strEnd)
{
switch(*currentPtr)
{
case '\"':
*currentPtr = 0;
currentPtr++;
return true;
case '{':
if(bInBlock)
{
throw ParseException("Unexpected start of block.", GetCharNum());
}
bInBlock = true;
break;
case '}':
if(!bInBlock)
{
throw ParseException("Unexpected end of block.", GetCharNum());
}
bInBlock = false;
blocksRead++;
break;
default:
break;
}
currentPtr++;
}
currentPtr = NULL;
return false;
}
示例3: ParseException
// _____________________________________________________________________________
ParsedQuery SparqlParser::parse(const string& query) {
ParsedQuery result;
result._originalString = query;
// Split prologue
size_t i = query.find("SELECT");
if (i == string::npos) {
throw ParseException("Missing keyword \"SELECT\", "
"currently only select queries are supported.");
}
size_t j = query.find("WHERE");
if (j == string::npos) {
throw ParseException("Missing keyword \"WHERE\", "
"currently only select queries are supported.");
}
if (i >= j) {
throw ParseException("Keyword \"WHERE\" "
"found after keyword \"SELECT\". Invalid query.");
}
size_t k = query.find("}", j);
if (k == string::npos) {
throw ParseException("Missing \"}\" symbol after \"WHERE\".");
}
parsePrologue(ad_utility::strip(query.substr(0, i), " \n\t"), result);
parseSelect(ad_utility::strip(query.substr(i, j - i), " \n\t"), result);
parseWhere(ad_utility::strip(query.substr(j, k - j + 1), " \n\t"), result);
parseSolutionModifiers(ad_utility::strip(query.substr(k + 1), " \n\t"),
result);
return result;
}
示例4: assignOptionArgument
void CommandLineParser::parseDuration()
{
QString durationString;
QString choppedDurationString;
assignOptionArgument(maxDurationoption(), durationString);
choppedDurationString = durationString;
const char suffix = durationString.at(durationString.count() - 1).toLatin1();
const bool hasSuffix = !std::isdigit(suffix);
if (hasSuffix)
choppedDurationString.chop(1);
bool ok;
m_maxDuration = choppedDurationString.toInt(&ok);
if (!ok || m_maxDuration <= 0) {
throw ParseException(QString::fromLocal8Bit("Invalid duration argument '%1'.")
.arg(durationString));
}
if (hasSuffix) {
switch (suffix) {
case 'm': break;
case 'd': m_maxDuration *= 24; // Fall-through.
case 'h': m_maxDuration *= 60; break;
default:
throw ParseException(QString::fromLocal8Bit("Invalid duration suffix '%1'.")
.arg(suffix));
}
}
}
示例5: Q_ASSERT
void CommandLineParser::parse(const QStringList &commandLine)
{
m_profile.clear();
m_startCommit.clear();
m_maxDuration = 0;
m_jobCount = 0;
m_log = false;
m_commandLine = commandLine;
Q_ASSERT(!m_commandLine.isEmpty());
m_command = m_commandLine.takeFirst();
while (!m_commandLine.isEmpty()) {
const QString arg = m_commandLine.takeFirst();
if (arg == profileOption())
assignOptionArgument(arg, m_profile);
else if (arg == startCommitOption())
assignOptionArgument(arg, m_startCommit);
else if (arg == jobCountOption())
assignOptionArgument(arg, m_jobCount);
else if (arg == maxDurationoption())
parseDuration();
else if (arg == logOption())
m_log = true;
else
throw ParseException(QString::fromLocal8Bit("Unknown parameter '%1'").arg(arg));
}
if (m_profile.isEmpty())
throw ParseException("No profile given.");
if (m_startCommit.isEmpty())
throw ParseException("No start commit given.");
}
示例6: switch
string
WKTReader::getNextWord(StringTokenizer *tokenizer)
{
int type=tokenizer->nextToken();
switch(type){
case StringTokenizer::TT_EOF:
throw ParseException("Expected word but encountered end of stream");
case StringTokenizer::TT_EOL:
throw ParseException("Expected word but encountered end of line");
case StringTokenizer::TT_NUMBER:
throw ParseException("Expected word but encountered number", tokenizer->getNVal());
case StringTokenizer::TT_WORD:
{
string word = tokenizer->getSVal();
int i = word.size();
while( --i >= 0 )
{
word[i] = static_cast<char>(toupper(word[i]));
}
return word;
}
case '(':
return "(";
case ')':
return ")";
case ',':
return ",";
}
assert(0);
//throw ParseException("Encountered unexpected StreamTokenizer type");
return "";
}
示例7: while
float WalkingEngineKick::readFloat(char*& buf)
{
while(*buf == ' ' || *buf == '\t')
++buf;
char* result = buf;
if(*buf == '-')
++buf;
while(isdigit(*buf))
++buf;
if(buf == result)
throw ParseException("expected float");
if(*buf == '.')
{
++buf;
while(isdigit(*buf))
++buf;
if(*buf && *buf != ' ' && *buf != '\t' && *buf != '\r' && *buf != '\n')
throw ParseException("expected float");
}
char c = *buf;
*buf = '\0';
float f = float(atof(result));
*buf = c;
return f;
}
示例8: fetchSchemaValues
void SchemaItem::processUniqueAttributeValueSetReferences(const std::map<std::string, std::vector<std::shared_ptr<SchemaValue>>> &uniqueAttributeValueSets)
{
for (auto setRefIt = m_uniqueAttributeValueSetReferences.begin(); setRefIt != m_uniqueAttributeValueSetReferences.end(); ++setRefIt)
{
auto keyIt = uniqueAttributeValueSets.find(setRefIt->second.m_setName);
if (keyIt != uniqueAttributeValueSets.end())
{
for (auto cfgIt = keyIt->second.begin(); cfgIt != keyIt->second.end(); ++cfgIt)
{
std::shared_ptr<SchemaValue> pKeyRefAttribute = *cfgIt; // this is the reference attribute from which attributeName must be a member
std::string cfgValuePath = ((setRefIt->second.m_elementPath != ".") ? setRefIt->second.m_elementPath : "") + "@" + setRefIt->second.m_attributeName;
std::vector<std::shared_ptr<SchemaValue>> cfgValues;
fetchSchemaValues(cfgValuePath, cfgValues);
if (!cfgValues.empty())
{
for (auto attrIt = cfgValues.begin(); attrIt != cfgValues.end(); ++attrIt)
{
(*attrIt)->setUniqueValueSetRef(pKeyRefAttribute);
}
}
else
{
throw(ParseException("Attribute " + (setRefIt->second.m_attributeName + " not found when adding keyRef for key " + (setRefIt->second.m_setName))));
}
}
}
else
{
throw(ParseException("Keyref to key '" + (setRefIt->second.m_setName + "' was not found")));
}
}
}
示例9: data
void DocumentConverter::characters(const XMLCh* const chars,
const unsigned int length)
{
// Should we just ignore these characters?
if (ignoreDepth > 0) return;
// Ignore pure whitespace
unsigned int l;
for (l = 0; l < length; ++l) {
XMLCh c = chars[l];
if (c == ' ' || c == '\n' || c == '\r' || c == '\t') continue;
break;
}
if (l == length) return;
try {
// This conversion should be safe. CDATA may only contain valid XML
// characters. These are defined in the XML 1.0 specification as the set
// 0x9, 0xA, 0xD, 0x20-0xD7FF, 0xE000-0xFFFD, 0x10000-0x10FFFF.
XMLChToVXIchar data(chars);
doc->AddContent(data.c_str(), wcslen(data.c_str()));
}
catch (const VXMLDocumentModel::OutOfMemory &) {
ParseException(L"unable to allocate memory for content");
}
catch (const VXMLDocumentModel::InternalError &) {
ParseException(L"corrupted document tree; unable to add content");
}
}
示例10: while
void CommandLineParser::parseArgs(const std::vector<StringView>& args, CommandLineFlags& result) const
{
size_t numPositionalConsumed = 0;
size_t numFlagConsumed = 0;
while (numFlagConsumed < args.size())
{
auto flag = args[numFlagConsumed];
if (!isOption(flag)) // Positional arguments
{
if (numPositionalConsumed >= posFlagMap.size())
throw ParseException("too many positional arguments");
auto inserted = result.addFlag(posFlagMap[numPositionalConsumed].first, flag);
assert(inserted && "Insertion failed");
++numPositionalConsumed;
}
else // Optional arguments
{
flag.remove_prefix(1);
// See if flag is "-help"
if (flag == "help")
throw HelpException();
auto itr = optFlagMap.find(flag);
if (itr == optFlagMap.end())
throw ParseException("Option not recognized: " + flag.to_string());
if (itr->second.defaultValue)
{
++numFlagConsumed;
if (numFlagConsumed >= args.size())
throw ParseException("More argument needs to be provided after option " + flag.to_string());
auto flagArg = args[numFlagConsumed];
if (isOption(flagArg))
throw ParseException("Found another option instead of an argument after option " + flag.to_string());
auto inserted = result.addFlag(flag, flagArg);
assert(inserted && "Insertion failed");
}
else
{
auto inserted = result.addFlag(flag, "");
assert(inserted && "Insertion failed");
}
}
++numFlagConsumed;
}
if (numPositionalConsumed < posFlagMap.size())
throw ParseException("Not enough positional arguments are provided");
for (auto const& mapping: optFlagMap)
{
if (mapping.second.defaultValue && result.lookup(mapping.first) == nullptr)
result.addFlag(mapping.first, *mapping.second.defaultValue);
}
}
示例11: parseInt
int StringBuilder::parseInt() const
{
if( m_pos == 0 ) throw ParseException("StringBuilder::parseInt(): Cannot parse a '0' length string!");
if( m_pos == m_alloc ) growCapacity((size_t)1); // make sure we have enough room for the following temproary '/0' termination
int lvalue;
if(sscanf(m_buffer,"%d",&lvalue)!=1) throw ParseException("StringBuilder::parseInt()");
return lvalue;
}
示例12: sscanf
double StringBuilder::parseDouble( size_t _index ) const
{
if( m_pos == 0 || _index >= m_pos-1 ) throw ParseException("StringBuilder::parseDouble( size_t _index )");
if( m_pos == m_alloc ) growCapacity((size_t)1); // make sure we have enough room for the following temproary '/0' termination
m_buffer[m_pos] = 0; // ensure a '0' terminated string for sscanf() but do not increase the size of the string
double lvalue;
if(sscanf(&m_buffer[_index],"%lf",&lvalue)!=1) throw ParseException("StringBuilder::parseDouble()");
return lvalue;
}
示例13: ParseException
void CommandLineParser::assignOptionArgument(const QString &option, QString &argument)
{
if (m_commandLine.isEmpty())
throw ParseException(QString::fromLocal8Bit("Option '%1' needs an argument.").arg(option));
argument = m_commandLine.takeFirst();
if (argument.isEmpty()) {
throw ParseException(QString::fromLocal8Bit("Argument for option '%1' must not be empty.")
.arg(option));
}
}
示例14: throw
void SchemaItem::postProcessConfig(const std::map<std::string, std::vector<std::shared_ptr<SchemaValue>>> &uniqueAttributeValueSets)
{
//
// Make sure that the item type value for all children that are insertable (minRequired = 0 or maxAllowed > minRequired)
std::set<std::string> itemTypes;
for (auto it = m_children.begin(); it != m_children.end(); ++it)
{
if (it->second->isInsertable())
{
auto rc = itemTypes.insert(it->second->getItemType());
if (!rc.second)
{
throw(ParseException("Duplicate itemType(" + it->second->getItemType() + ") found for element " + m_properties["name"]));
}
}
}
processUniqueAttributeValueSetReferences(uniqueAttributeValueSets);
//
// Post process the attributes
for (auto it = m_attributes.begin(); it != m_attributes.end(); ++it)
{
//
// If this is a mirroed value, go find the source and attach ourselves so that if that value changes,
// it is replicated to us.
if (it->second->isMirroredValue())
{
std::vector<std::shared_ptr<SchemaValue>> cfgValues;
fetchSchemaValues(it->second->getMirrorFromPath(), cfgValues);
if (!cfgValues.empty() && cfgValues.size() == 1)
{
if (cfgValues.size() == 1)
{
it->second->addMirroredSchemaValue(cfgValues[0]);
}
else
{
throw(ParseException("Multiple sources found for mirror from path for attribute " + it->second->getName() + " (path=" + it->second->getMirrorFromPath()));
}
}
else
{
throw(ParseException("Mirrored from source not found for attribute " + it->second->getName() + " path=" + it->second->getMirrorFromPath()));
}
}
}
//
// Post process all of our children now
for (auto it = m_children.begin(); it!= m_children.end(); ++it)
{
it->second->postProcessConfig(uniqueAttributeValueSets);
}
}
示例15: chopstr
void PopsDat::parse( const std::string& _Line )
{
std::vector<std::string> parts = chopstr( _Line, TOKEN_WHITESPACE.c_str() );
if( parts.size() != 5 ) throw ParseException("POPS: Atom set initial line contains the wrong number of elements");
if(
0 != str2int( parts[0], expectedAtomTypeCount ) ||
0 != str2double( parts[1], b12 ) ||
0 != str2double( parts[2], b13 ) ||
0 != str2double( parts[3], b14 ) ||
0 != str2double( parts[4], bOther )
) throw ParseException("POPS: Invalid value in atom set initial line");
return;
}