[sword-svn] r3242 - in trunk: examples/tasks src/modules

scribe at crosswire.org scribe at crosswire.org
Sat Jul 12 10:06:02 MST 2014


Author: scribe
Date: 2014-07-12 10:06:02 -0700 (Sat, 12 Jul 2014)
New Revision: 3242

Modified:
   trunk/examples/tasks/parallelbibles.cpp
   trunk/src/modules/swmodule.cpp
Log:
parallel Bible display

Modified: trunk/examples/tasks/parallelbibles.cpp
===================================================================
--- trunk/examples/tasks/parallelbibles.cpp	2014-07-12 16:27:44 UTC (rev 3241)
+++ trunk/examples/tasks/parallelbibles.cpp	2014-07-12 17:06:02 UTC (rev 3242)
@@ -33,13 +33,19 @@
 using namespace sword;
 using namespace std;
 
+const bool o = 1;
 
 void parallelDisplay(vector<SWModule *>modules, const char *key) {
 
+	//cout << "Start key:" << key;
+
 	// We'll use the first module's key as our master key to position all other modules.
 	VerseKey *master = (VerseKey *)modules[0]->createKey();
 
 	master->setText(key);
+
+	//cout << "\t key:" << master->getText();
+
 	int curVerse   = master->getVerse();
 	int curChapter = master->getChapter();
 	int curBook    = master->getBook();
@@ -49,15 +55,66 @@
 					&& !master->popError();
 										(*master)++) {
 
-		cout << "<tr class=\"" << (master->getVerse() == curVerse ? "currentverse":"verse") << "\">";
+		if(o) cout << "<tr class=\"" << (master->getVerse() == curVerse ? "currentverse":"verse") << "\">";
+
 		for (vector<SWModule *>::iterator module = modules.begin(); module != modules.end(); ++module) {
+			//cout << "\n\n====================\nfromKey" << master->getOSISRef();
+
 			(*module)->setKey(master);
+			VerseKey slave((*module)->getKey());
+
+			//cout << "setKey" << (*module)->getName() << slave.getBookName() << slave.getRangeText() << slave.getShortText();
+
+			if(o) cout << "<td>" << "<span class=\"versenum\">";
+
+			//cout << "[" << (int)slave.getBook() << " " << (int)master->getBook() << " " << (int)slave.getTestament() << " " << (int)master->getTestament() << "]";
+
+
 			if (!(*module)->popError()) {
-				cout << "<td>" << "<span class=\"versenum\">" << master->getVerse() << "</span> ";
-				cout << (*module)->renderText() << "</td>";
+
+				if(strcmp(slave.getBookName(), master->getBookName())) {
+					if(o) cout << slave.getShortText();
+				}
+				else if(slave.getChapter() != master->getChapter()) {
+					if(o) cout << slave.getChapter() << ":" << slave.getVerse();
+				}
+				else {
+					if(o) cout << slave.getVerse();
+				}
+
+				if(slave.isBoundSet()) {
+					if(o) cout << "-";
+					if(slave.getUpperBound().getBook() != slave.getLowerBound().getBook()) {
+						if(o) cout << slave.getUpperBound().getShortText();
+					}
+					else if(slave.getUpperBound().getChapter() != slave.getLowerBound().getChapter()) {
+						if(o) cout << slave.getUpperBound().getChapter() << ":" << slave.getUpperBound().getVerse();
+					}
+					else {
+						if(o) cout << slave.getUpperBound().getVerse();
+					}
+				}
+
+				if(o) cout << "</span> ";
+
+
+				if(slave.isBoundSet()) {
+					VerseKey temp(slave);
+					for(int i = slave.getLowerBound().getIndex(); i <= slave.getUpperBound().getIndex(); ++i) {
+						if(i > 0) if(o) cout << " ";
+						temp.setIndex(i);
+						(*module)->setKey(temp);
+						if(o) cout << (*module)->renderText();
+					}
+				}
+				else {
+					if(o) cout << (*module)->renderText();
+				}
+
+				if(o) cout << "</td>";
 			}
 		}
-		cout << "</tr>";
+		if(o) cout << "</tr>";
 	}
 	delete master;
 }
@@ -171,9 +228,9 @@
 		modules.push_back(bible);
 	}
 
-	outputHeader(modules, argv[argc-1]);
+	if(o) outputHeader(modules, argv[argc-1]);
 	parallelDisplay(modules, argv[argc-1]);
-	outputFooter(modules);
+	if(o) outputFooter(modules);
 
 	return 0;
 }

Modified: trunk/src/modules/swmodule.cpp
===================================================================
--- trunk/src/modules/swmodule.cpp	2014-07-12 16:27:44 UTC (rev 3241)
+++ trunk/src/modules/swmodule.cpp	2014-07-12 17:06:02 UTC (rev 3242)
@@ -296,7 +296,7 @@
 	if (oldKey)
 		delete oldKey;
 
-	return 0;
+	return error = key->popError();
 }
 
 




More information about the sword-cvs mailing list