~ubuntu-branches/debian/squeeze/sword/squeeze

« back to all changes in this revision

Viewing changes to utilities/diatheke/gbfcgi.cpp

  • Committer: Bazaar Package Importer
  • Author(s): Jonathan Marsden, Jonathan Marsden, Dmitrijs Ledkovs, Closed Bugs
  • Date: 2009-05-30 11:55:55 UTC
  • mfrom: (1.3.1 upstream) (6.1.1 experimental)
  • Revision ID: james.westby@ubuntu.com-20090530115555-r427zsn3amivdpfu
Tags: 1.6.0+dfsg-1
[ Jonathan Marsden ]
* New upstream release. (Closes: #507960) (LP: #320558)
* debian/patches/02_libver.diff:
  - Bump SONAME to 8 -- SWORD 1.6 is not backward compatible with 1.5.11.
* debian/patches/series:
  - Remove 10_diatheke.diff -- included in upstream source.
* debian/patches/:
  - Remove several old unused .diff files.
  - Add 11_regex_only_when_needed.diff to conditionally include regex lib.
  - Add 12_fix_compiler_warnings.diff to remove all compiler warnings.
  - Add 13_fix_osis2mod_compression_default.diff from upstream svn.
  - Add 14_closing_section_not_chapter.diff from upstream svn.
* debian/libsword7.*: 
  - Rename to libsword8.*
  - Change libsword7 to libsword8 within files.
* debian/rules: 
  - SONAME bump to 8.
  - Set library version check to >= 1.6
* debian/control:
  - Change libsword7 to libsword8.
  - Add libsword7 to Conflicts.
  - Fix case of sword to SWORD in package descriptions.
  - Bump Standards-Version to 3.8.1 (no changes needed).
  - Fix section for libsword-dbg to avoid lintian warning.
* debian/rules:
  - Add DFSG get-orig-source target.
* debian/copyright:
  - Fix various mistakes in initial attempt to document copyrights.

[ Dmitrijs Ledkovs ]
* debian/rules: Added utils.mk to use missing-files target and call it on
  each build.
* debian/libsword-dev.install: Added libsword.la, previously missing.
* debian/libsword7.install: Added missing libicu translit files.
* debian/control:
  - Updated all uses of SWORD version to 1.6
  - Added libsword-dbg package
* debian/watch: Fixed a small mistake which was resulting in extra "."
  in final version name.
* debian/rules: simplified manpage processing.
* debian/libsword8.lintian-overrides: added override for module
  installation directory.
* debian/copyright: Updated with information about everyfile.
  Closes: #513448 LP: #322638
* debian/diatheke.examples: moved examples here from the diatheke.install
* debian/rules:
  - enabled shell script based testsuite
  - added commented out cppunit testsuite
* debian/patches/40_missing_includes.diff: 
  - added several missing stdio.h includes to prevent FTBFS of testsuite.

[ Closed Bugs ]
* FTBFS on intrepid (LP: #305172)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/***************************************************************************
 
2
 *                         gbfcgi.cpp  -   GBF to Diatheke/CGI format
 
3
 *                            -------------------
 
4
 *   begin                    : 2001-11-12
 
5
 *   copyright            : 2001 by CrossWire Bible Society
 
6
 *
 
7
 *
 
8
 * Copyright 2009 CrossWire Bible Society (http://www.crosswire.org)
 
9
 *      CrossWire Bible Society
 
10
 *      P. O. Box 2528
 
11
 *      Tempe, AZ  85280-2528
 
12
 *
 
13
 * This program is free software; you can redistribute it and/or modify it
 
14
 * under the terms of the GNU General Public License as published by the
 
15
 * Free Software Foundation version 2.
 
16
 *
 
17
 * This program is distributed in the hope that it will be useful, but
 
18
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 
19
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 
20
 * General Public License for more details.
 
21
 *
 
22
 */
 
23
 
 
24
#include <stdlib.h>
 
25
#include <string.h>
 
26
#include "gbfcgi.h"
 
27
 
 
28
SWORD_NAMESPACE_START
 
29
 
 
30
GBFCGI::GBFCGI() {
 
31
        setTokenStart("<");
 
32
        setTokenEnd(">");
 
33
        
 
34
        setTokenCaseSensitive(true);
 
35
 
 
36
        addTokenSubstitute("Rf", ")</small></font>");
 
37
        addTokenSubstitute("FI", "<i>"); // italics begin
 
38
        addTokenSubstitute("Fi", "</i>");
 
39
        addTokenSubstitute("FB", "<n>"); // bold begin
 
40
        addTokenSubstitute("Fb", "</n>");
 
41
        addTokenSubstitute("FR", "<font color=\"#FF0000\">"); // words of Jesus begin
 
42
        addTokenSubstitute("Fr", "</font>");
 
43
        addTokenSubstitute("FU", "<u>"); // underline begin
 
44
        addTokenSubstitute("Fu", "</u>");
 
45
        addTokenSubstitute("FO", "<cite>"); //  Old Testament quote begin
 
46
        addTokenSubstitute("Fo", "</cite>");
 
47
        addTokenSubstitute("FS", "<sup>"); // Superscript begin// Subscript begin
 
48
        addTokenSubstitute("Fs", "</sup>");
 
49
        addTokenSubstitute("FV", "<sub>"); // Subscript begin
 
50
        addTokenSubstitute("Fv", "</sub>");
 
51
        addTokenSubstitute("TT", "<big>"); // Book title begin
 
52
        addTokenSubstitute("Tt", "</big>");
 
53
        addTokenSubstitute("PP", "<cite>"); //  poetry  begin
 
54
        addTokenSubstitute("Pp", "</cite>");
 
55
        addTokenSubstitute("Fn", "</font>"); //  font  end
 
56
        addTokenSubstitute("CL", "<br />"); //  new line
 
57
        addTokenSubstitute("CM", "<br />"); //  paragraph
 
58
        addTokenSubstitute("CG", "&gt;"); //  ???
 
59
        addTokenSubstitute("CT", "&lt;"); // ???
 
60
        addTokenSubstitute("JR", "<div align=\"right\">"); // right align begin
 
61
        addTokenSubstitute("JC", "<div align=\"center\">"); // center align begin
 
62
        addTokenSubstitute("JL", "</div>"); // align end
 
63
        
 
64
}
 
65
 
 
66
 
 
67
bool GBFCGI::handleToken(SWBuf &buf, const char *token, DualStringMap &userData) {
 
68
        unsigned long i;
 
69
        if (!substituteToken(buf, token)) {
 
70
                if (!strncmp(token, "WG", 2) || !strncmp(token, "WH", 2)) { // strong's numbers
 
71
                        buf += " <small><em>&lt;<a href=\"!DIATHEKE_URL!";
 
72
                        if (token[1] == 'H') {
 
73
                          buf += "StrongsHebrew";
 
74
                        }
 
75
                        else if (token[1] == 'G') {
 
76
                          buf += "StrongsGreek";
 
77
                        }
 
78
                        buf += "=on&verse=";
 
79
                        for (i = 2; i < strlen(token); i++)
 
80
                          buf += token[i];
 
81
                        buf += "\">";
 
82
                        for (i = 2; i < strlen(token); i++)
 
83
                          buf += token[i];
 
84
                        buf += "</a>&gt;</em></small>";
 
85
                }
 
86
 
 
87
                else if (!strncmp(token, "WTG", 3) || !strncmp(token, "WTH", 3)) { // strong's numbers tense
 
88
                        buf += " <small><em>&lt;<a href=\"!DIATHEKE_URL!";
 
89
                        if (token[2] == 'H') {
 
90
                          buf += "StrongsHebrew";
 
91
                        }
 
92
                        else if (token[2] == 'G') {
 
93
                          buf += "StrongsGreek";
 
94
                        }
 
95
                        buf += "=on&verse=";
 
96
                        for (i = 3; i < strlen(token); i++)
 
97
                          buf += token[i];
 
98
                        buf += "\">";
 
99
                        for (i = 3; i < strlen(token); i++)
 
100
                          buf += token[i];
 
101
                        buf += "</a>&gt;</em></small>";
 
102
                }
 
103
 
 
104
                else if (!strncmp(token, "WT", 2)) { // morph tags
 
105
                        buf += " <small><em>(<a href=\"!DIATHEKE_URL!Packard=on&verse=";
 
106
                        for (i = 1; i < strlen(token); i++)
 
107
                          buf += token[i];
 
108
                        buf += "\">";
 
109
                        for (i = 1; i < strlen(token); i++)
 
110
                          buf += token[i];              
 
111
                        buf += "</a>)</em></small>";
 
112
                }
 
113
 
 
114
                else if (!strncmp(token, "RB", 2)) {
 
115
                        buf += "<i>";
 
116
                        userData["hasFootnotePreTag"] = "true";
 
117
                }
 
118
 
 
119
                else if (!strncmp(token, "RF", 2)) {
 
120
                        if(userData["hasFootnotePreTag"] == "true") {
 
121
                                userData["hasFootnotePreTag"] = "false";
 
122
                                buf += "</i> ";
 
123
                        }
 
124
                        buf += "<font color=\"#800000\"><small> (";
 
125
                }
 
126
 
 
127
                else if (!strncmp(token, "FN", 2)) {
 
128
                        buf += "<font face=\"";
 
129
                        for (i = 2; i < strlen(token); i++)                    
 
130
                          buf += token[i];
 
131
                        buf += "\">";
 
132
                }
 
133
 
 
134
                else if (!strncmp(token, "CA", 2)) {    // ASCII value
 
135
                        buf += (char)atoi(&token[2]);
 
136
                }
 
137
                
 
138
                else {
 
139
                        return false;
 
140
                }
 
141
        }
 
142
        return true;
 
143
}
 
144
 
 
145
SWORD_NAMESPACE_END