1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
/******************************************************************************
*
* versevalid.cpp - This example demonstrates how to check if a string
* is a valid verse reference
*
* $Id: verseranges.cpp 2980 2013-09-14 21:51:47Z scribe $
*
* Copyright 2011-2013 CrossWire Bible Society (http://www.crosswire.org)
* CrossWire Bible Society
* P. O. Box 2528
* Tempe, AZ 85280-2528
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation version 2.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
*/
#include <iostream>
#include <swmgr.h>
#include <swmodule.h>
#include <versekey.h>
#include <localemgr.h>
using namespace sword;
using namespace std;
int main(int argc, char **argv) {
if (argc == 1) {
std::cerr << "usage: " << argv[0] << " <test string> [locale name] [Bible]\n\n";
exit(-1);
}
cout << "\n";
const char *testString = argv[1];
const char *localeName = argc > 2 ? argv[2] : 0;
const char *bibleName = argc > 3 ? argv[3] : 0;
VerseKey *vk = 0;
if (localeName) {
LocaleMgr::getSystemLocaleMgr()->setDefaultLocaleName(localeName);
}
if (bibleName) {
SWMgr manager;
SWModule *bible = manager.getModule(bibleName);
if (!bible) {
cout << bibleName << " not installed for example. Please install.\n\n";
exit(-2);
}
vk = (VerseKey *)bible->createKey();
}
if (!vk) vk = new VerseKey();
vk->setText(testString);
std::cout << "error: " << (int)vk->popError() << "\n\n";
std::cout << "parsed: " << vk->getText() << "\n\n";
delete vk;
cout << endl;
return 0;
}
|