source: greenstone3/branches/customizingGreenstone3/src/java/org/greenstone/gsdl3/service/GS2MGPPRetrieve.java@ 15787

Last change on this file since 15787 was 15787, checked in by oranfry, 16 years ago

updating from trunk: brought in trunk changes from r15191 to r15785

  • Property svn:keywords set to Author Date Id Revision
File size: 3.9 KB
RevLine 
[3649]1/*
2 * GS2MGPPRetrieve.java
[8959]3 * Copyright (C) 2005 New Zealand Digital Library, http://www.nzdl.org
[3649]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
[3799]21// Greenstone classes
[3649]22import org.greenstone.mgpp.*;
[9874]23import org.greenstone.gsdl3.core.GSException;
[8959]24import org.greenstone.gsdl3.util.GSFile;
25import org.greenstone.gsdl3.util.GSXML;
[3649]26
[3799]27// XML classes
[8959]28import org.w3c.dom.Element;
29import org.w3c.dom.Text;
[3649]30
[3952]31// General Java classes
32import java.io.File;
[3649]33
[13124]34import org.apache.log4j.*;
35
[8959]36public class GS2MGPPRetrieve
[14441]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 }
[3649]67
[14441]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);
[3799]75 }
[14441]76 if (this.default_level == null || this.default_level.equals("")) {
77 logger.error("default level not specified!");
78 return false;
[9874]79 }
[3901]80
[14441]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 {
[15787]95 long doc_num = this.coll_db.OID2DocnumLong(doc_id);
[14441]96 if (doc_num == -1) {
97 logger.error("OID "+doc_id +" couldn't be converted to mgpp num");
98 return null;
[8959]99 }
[14441]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
[3649]125}
Note: See TracBrowser for help on using the repository browser.