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

Last change on this file since 13124 was 13124, checked in by shaoqun, 18 years ago

added the code to use log4j and replace system.out or system.err to logger.info or logger.error respectively. The commented out output has been replaced with logger.debug. The log file is in web/logs/greenstone.log

  • 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 Category logger = Category.getInstance(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.