source: greenstone3/trunk/src/java/org/greenstone/gsdl3/service/GS2MGPPRetrieve.java@ 15326

Last change on this file since 15326 was 15326, checked in by kjdon, 16 years ago

added support for JDBM (or other) in place of GDBM: use SimpleCollectionDatabase instead of GDBMWrapper. new Element in buildConfig file: databaseType, set to gdbm or jdbm. If not present, assume gdbm. Also may be some small style changes to some files

  • Property svn:keywords set to Author Date Id Revision
File size: 3.9 KB
Line 
1/*
2 * GS2MGPPRetrieve.java
3 * Copyright (C) 2005 New Zealand Digital Library, http://www.nzdl.org
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18 */
19package org.greenstone.gsdl3.service;
20
21// Greenstone classes
22import org.greenstone.mgpp.*;
23import org.greenstone.gsdl3.core.GSException;
24import org.greenstone.gsdl3.util.GSFile;
25import org.greenstone.gsdl3.util.GSXML;
26
27// XML classes
28import org.w3c.dom.Element;
29import org.w3c.dom.Text;
30
31// General Java classes
32import java.io.File;
33
34import org.apache.log4j.*;
35
36public class GS2MGPPRetrieve
37 extends AbstractGS2DocumentRetrieve {
38 static Logger logger = Logger.getLogger(org.greenstone.gsdl3.service.GS2MGPPRetrieve.class.getName());
39
40 // Parameters used
41 private static final String LEVEL_PARAM = "level";
42
43 // Elements used in the config file that are specific to this class
44 private static final String DEFAULT_LEVEL_ELEM = "defaultLevel";
45
46 private static MGPPRetrieveWrapper mgpp_src = null;
47
48 private String default_level = null;
49 private String mgpp_textdir = null;
50
51 public GS2MGPPRetrieve() {
52 if(mgpp_src == null) {
53 mgpp_src = new MGPPRetrieveWrapper();
54 }
55 }
56
57 public void cleanUp() {
58 super.cleanUp();
59 mgpp_src.unloadIndexData();
60 }
61
62 /** configure this service */
63 public boolean configure(Element info, Element extra_info) {
64 if (!super.configure(info, extra_info)){
65 return false;
66 }
67
68 // Do specific configuration
69 logger.info("Configuring GS2MGPPRetrieve...");
70
71 // Get the default level out of <defaultLevel> (buildConfig.xml)
72 Element def = (Element) GSXML.getChildByTagName(info, DEFAULT_LEVEL_ELEM);
73 if (def != null) {
74 this.default_level = def.getAttribute(GSXML.SHORTNAME_ATT);
75 }
76 if (this.default_level == null || this.default_level.equals("")) {
77 logger.error("default level not specified!");
78 return false;
79 }
80
81 // The location of the MGPP text files
82 mgpp_textdir = GSFile.collectionBaseDir(this.site_home, this.cluster_name) +
83 File.separatorChar + GSFile.collectionTextPath(this.index_stem);
84
85 // Do generic configuration
86 return true;
87
88 }
89
90 /** returns the content of a node
91 * should return a nodeContent element:
92 * <nodeContent>text content or other elements</nodeContent>
93 */
94 protected Element getNodeContent(String doc_id, String lang) throws GSException {
95 long doc_num = this.coll_db.OID2DocnumLong(doc_id);
96 if (doc_num == -1) {
97 logger.error("OID "+doc_id +" couldn't be converted to mgpp num");
98 return null;
99 }
100 Element content_node = this.doc.createElement(GSXML.NODE_CONTENT_ELEM);
101 synchronized (mgpp_src) {
102 String doc_content = "";
103 try {
104
105 doc_content = mgpp_src.getDocument(this.mgpp_textdir,
106 this.default_level,
107 doc_num);
108
109 if (doc_content != null) {
110 doc_content = resolveTextMacros(doc_content, doc_id, lang);
111 }
112
113 } catch (Exception e) {
114 logger.info("exception happended with mgpp_src.getDocument()" + e);
115 doc_content = "this is the content for section hash id "+ doc_id+", mgpp doc num "+doc_num+"\n";
116
117 }
118 Text t = this.doc.createTextNode(doc_content);
119 content_node.appendChild(t);
120 return content_node;
121 }//end of synchronized
122 }
123
124
125}
Note: See TracBrowser for help on using the repository browser.