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

Last change on this file since 13270 was 13270, checked in by shaoqun, 17 years ago

replace Category class which is deprecated with Logger class

  • Property svn:keywords set to Author Date Id Revision
File size: 3.7 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{
39 static Logger logger = Logger.getLogger(org.greenstone.gsdl3.service.GS2MGPPRetrieve.class.getName());
40
41 // Parameters used
42 private static final String LEVEL_PARAM = "level";
43
44 // Elements used in the config file that are specific to this class
45 private static final String DEFAULT_LEVEL_ELEM = "defaultLevel";
46
47 private MGPPWrapper mgpp_src = null;
48
49 private String default_level = null;
50 private String mgpp_textdir = null;
51
52 public GS2MGPPRetrieve() {
53 this.mgpp_src = new MGPPWrapper();
54 }
55
56 public void cleanUp() {
57 super.cleanUp();
58 this.mgpp_src.unloadIndexData();
59 }
60
61 /** configure this service */
62 public boolean configure(Element info, Element extra_info)
63 {
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.NAME_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) throws GSException {
95 String lang = "en"; // **********
96 long doc_num = this.gdbm_src.OID2Docnum(doc_id);
97 if (doc_num == -1) {
98 logger.error("OID "+doc_id +" couldn't be converted to mgpp num");
99 return null;
100 }
101 Element content_node = this.doc.createElement(GSXML.NODE_CONTENT_ELEM);
102
103 String doc_content = "";
104 try {
105 doc_content = this.mgpp_src.getDocument(this.mgpp_textdir,
106 this.default_level,
107 doc_num);
108 if (doc_content != null) {
109 doc_content = resolveTextMacros(doc_content, doc_id, lang);
110 }
111 } catch (Exception e) {
112 logger.info("exception happended with mgpp_src.getDocument()" + e);
113 doc_content = "this is the content for section hash id "+ doc_id+", mgpp doc num "+doc_num+"\n";
114
115 }
116 Text t = this.doc.createTextNode(doc_content);
117 content_node.appendChild(t);
118 return content_node;
119
120 }
121
122
123}
Note: See TracBrowser for help on using the repository browser.