annotate src/de/mpiwg/dwinter/duomo/lexdump/LexOWLTransformer.java @ 0:fb3f3df002df

first release
author dwinter
date Thu, 03 Feb 2011 10:15:16 +0100
parents
children 0fa29ab5e5e0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
fb3f3df002df first release
dwinter
parents:
diff changeset
1 package de.mpiwg.dwinter.duomo.lexdump;
fb3f3df002df first release
dwinter
parents:
diff changeset
2
fb3f3df002df first release
dwinter
parents:
diff changeset
3 import java.io.IOException;
fb3f3df002df first release
dwinter
parents:
diff changeset
4 import java.net.URI;
fb3f3df002df first release
dwinter
parents:
diff changeset
5 import java.net.URISyntaxException;
fb3f3df002df first release
dwinter
parents:
diff changeset
6 import java.net.URLEncoder;
fb3f3df002df first release
dwinter
parents:
diff changeset
7 import java.util.Collection;
fb3f3df002df first release
dwinter
parents:
diff changeset
8 import java.util.HashMap;
fb3f3df002df first release
dwinter
parents:
diff changeset
9 import java.util.HashSet;
fb3f3df002df first release
dwinter
parents:
diff changeset
10 import java.util.Iterator;
fb3f3df002df first release
dwinter
parents:
diff changeset
11 import java.util.List;
fb3f3df002df first release
dwinter
parents:
diff changeset
12 import java.util.Map;
fb3f3df002df first release
dwinter
parents:
diff changeset
13 import java.util.Set;
fb3f3df002df first release
dwinter
parents:
diff changeset
14
fb3f3df002df first release
dwinter
parents:
diff changeset
15 import javax.print.URIException;
fb3f3df002df first release
dwinter
parents:
diff changeset
16
fb3f3df002df first release
dwinter
parents:
diff changeset
17 import org.apache.log4j.Level;
fb3f3df002df first release
dwinter
parents:
diff changeset
18 import org.apache.log4j.Logger;
fb3f3df002df first release
dwinter
parents:
diff changeset
19 import org.jdom.Attribute;
fb3f3df002df first release
dwinter
parents:
diff changeset
20 import org.jdom.Element;
fb3f3df002df first release
dwinter
parents:
diff changeset
21 import org.jdom.JDOMException;
fb3f3df002df first release
dwinter
parents:
diff changeset
22 import org.jdom.xpath.XPath;
fb3f3df002df first release
dwinter
parents:
diff changeset
23
fb3f3df002df first release
dwinter
parents:
diff changeset
24 import com.sun.xml.internal.ws.developer.MemberSubmissionEndpointReference.Elements;
fb3f3df002df first release
dwinter
parents:
diff changeset
25
fb3f3df002df first release
dwinter
parents:
diff changeset
26 import edu.stanford.smi.protege.exception.OntologyLoadException;
fb3f3df002df first release
dwinter
parents:
diff changeset
27 import edu.stanford.smi.protege.model.Instance;
fb3f3df002df first release
dwinter
parents:
diff changeset
28 import edu.stanford.smi.protegex.owl.model.OWLAllValuesFrom;
fb3f3df002df first release
dwinter
parents:
diff changeset
29 import edu.stanford.smi.protegex.owl.model.OWLClass;
fb3f3df002df first release
dwinter
parents:
diff changeset
30 import edu.stanford.smi.protegex.owl.model.OWLDataRange;
fb3f3df002df first release
dwinter
parents:
diff changeset
31 import edu.stanford.smi.protegex.owl.model.OWLIndividual;
fb3f3df002df first release
dwinter
parents:
diff changeset
32 import edu.stanford.smi.protegex.owl.model.OWLNamedClass;
fb3f3df002df first release
dwinter
parents:
diff changeset
33 import edu.stanford.smi.protegex.owl.model.OWLProperty;
fb3f3df002df first release
dwinter
parents:
diff changeset
34 import edu.stanford.smi.protegex.owl.model.OWLUnionClass;
fb3f3df002df first release
dwinter
parents:
diff changeset
35 import edu.stanford.smi.protegex.owl.model.RDFList;
fb3f3df002df first release
dwinter
parents:
diff changeset
36 import edu.stanford.smi.protegex.owl.model.RDFProperty;
fb3f3df002df first release
dwinter
parents:
diff changeset
37 import edu.stanford.smi.protegex.owl.model.RDFResource;
fb3f3df002df first release
dwinter
parents:
diff changeset
38 import edu.stanford.smi.protegex.owl.model.impl.AbstractOWLQuantifierRestriction;
fb3f3df002df first release
dwinter
parents:
diff changeset
39 import edu.stanford.smi.protegex.owl.model.impl.DefaultOWLUnionClass;
fb3f3df002df first release
dwinter
parents:
diff changeset
40
fb3f3df002df first release
dwinter
parents:
diff changeset
41 public class LexOWLTransformer {
fb3f3df002df first release
dwinter
parents:
diff changeset
42 private Logger logger = Logger.getRootLogger();
fb3f3df002df first release
dwinter
parents:
diff changeset
43 private OWLImporter owlDoc;
fb3f3df002df first release
dwinter
parents:
diff changeset
44 private LexDumpImporter lexDoc;
fb3f3df002df first release
dwinter
parents:
diff changeset
45 private Map<String, OWLIndividual> individualIds = new HashMap<String, OWLIndividual>(); // speichere
fb3f3df002df first release
dwinter
parents:
diff changeset
46 // ids
fb3f3df002df first release
dwinter
parents:
diff changeset
47 // fuer
fb3f3df002df first release
dwinter
parents:
diff changeset
48 // weitere
fb3f3df002df first release
dwinter
parents:
diff changeset
49 // Verwendung
fb3f3df002df first release
dwinter
parents:
diff changeset
50
fb3f3df002df first release
dwinter
parents:
diff changeset
51 public LexOWLTransformer(OWLImporter owlDoc, LexDumpImporter lexDoc) {
fb3f3df002df first release
dwinter
parents:
diff changeset
52 this.owlDoc = owlDoc;
fb3f3df002df first release
dwinter
parents:
diff changeset
53 this.lexDoc = lexDoc;
fb3f3df002df first release
dwinter
parents:
diff changeset
54 }
fb3f3df002df first release
dwinter
parents:
diff changeset
55
fb3f3df002df first release
dwinter
parents:
diff changeset
56 /**
fb3f3df002df first release
dwinter
parents:
diff changeset
57 * @param args
fb3f3df002df first release
dwinter
parents:
diff changeset
58 * @throws Exception
fb3f3df002df first release
dwinter
parents:
diff changeset
59 */
fb3f3df002df first release
dwinter
parents:
diff changeset
60 public static void main(String[] args) throws Exception {
fb3f3df002df first release
dwinter
parents:
diff changeset
61 Logger.getRootLogger().setLevel(Level.DEBUG);
fb3f3df002df first release
dwinter
parents:
diff changeset
62 // Import OWL
fb3f3df002df first release
dwinter
parents:
diff changeset
63 //String base = "/Users/dwinter/Documents/Projekte/Diss - data-mining/eclipseWorkspace/de.mpiwg.dwinter.duomo/owlInput";
fb3f3df002df first release
dwinter
parents:
diff changeset
64 String base=args[0];
fb3f3df002df first release
dwinter
parents:
diff changeset
65 String baseUri= base.replace(" ", "%20");
fb3f3df002df first release
dwinter
parents:
diff changeset
66 URI ontologieUri = new URI("file://"+baseUri+"/duomoAnalysis.owl");
fb3f3df002df first release
dwinter
parents:
diff changeset
67 //URI ontologieUri = new URI(
fb3f3df002df first release
dwinter
parents:
diff changeset
68 // "file:///Users/dwinter/Documents/Projekte/Diss%20-%20data-mining/eclipseWorkspace/de.mpiwg.dwinter.duomo/owlInput/duomoAnalysis.owl");
fb3f3df002df first release
dwinter
parents:
diff changeset
69 OWLImporter owlDoc = null;
fb3f3df002df first release
dwinter
parents:
diff changeset
70 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
71
fb3f3df002df first release
dwinter
parents:
diff changeset
72 owlDoc = new OWLImporter(base, ontologieUri);
fb3f3df002df first release
dwinter
parents:
diff changeset
73 // owlDoc.printModel();
fb3f3df002df first release
dwinter
parents:
diff changeset
74 } catch (OntologyLoadException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
75 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
76 System.exit(-1);
fb3f3df002df first release
dwinter
parents:
diff changeset
77 }
fb3f3df002df first release
dwinter
parents:
diff changeset
78 // read and parse lexfile
fb3f3df002df first release
dwinter
parents:
diff changeset
79 //String lexFile = "/Users/dwinter/Documents/Projekte/Diss - data-mining/eclipseWorkspace/duomoData/LEXXDUMP.xml";
fb3f3df002df first release
dwinter
parents:
diff changeset
80 String lexFile=args[1];
fb3f3df002df first release
dwinter
parents:
diff changeset
81 LexDumpImporter lexDoc = null;
fb3f3df002df first release
dwinter
parents:
diff changeset
82 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
83 lexDoc = new LexDumpImporter(lexFile);
fb3f3df002df first release
dwinter
parents:
diff changeset
84 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
85 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
86 System.exit(-1);
fb3f3df002df first release
dwinter
parents:
diff changeset
87 } catch (IOException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
88 System.exit(-1);
fb3f3df002df first release
dwinter
parents:
diff changeset
89 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
90 }
fb3f3df002df first release
dwinter
parents:
diff changeset
91
fb3f3df002df first release
dwinter
parents:
diff changeset
92 // List<Element> cartas = lexDoc.getCartas();
fb3f3df002df first release
dwinter
parents:
diff changeset
93 // System.out.println(cartas.size());
fb3f3df002df first release
dwinter
parents:
diff changeset
94
fb3f3df002df first release
dwinter
parents:
diff changeset
95 LexOWLTransformer tf = new LexOWLTransformer(owlDoc, lexDoc);
fb3f3df002df first release
dwinter
parents:
diff changeset
96 tf.transform();
fb3f3df002df first release
dwinter
parents:
diff changeset
97 owlDoc.save("file:///tmp/out.owl");
fb3f3df002df first release
dwinter
parents:
diff changeset
98 }
fb3f3df002df first release
dwinter
parents:
diff changeset
99
fb3f3df002df first release
dwinter
parents:
diff changeset
100 private void transform() throws JDOMException {
fb3f3df002df first release
dwinter
parents:
diff changeset
101 List<Element> signatures = lexDoc.getSignatures();
fb3f3df002df first release
dwinter
parents:
diff changeset
102
fb3f3df002df first release
dwinter
parents:
diff changeset
103 // Element signature = signatures.get(0);
fb3f3df002df first release
dwinter
parents:
diff changeset
104 int signatureCount = 1;
fb3f3df002df first release
dwinter
parents:
diff changeset
105 int maxsign = signatures.size();
fb3f3df002df first release
dwinter
parents:
diff changeset
106 for (Element signature : signatures) {
fb3f3df002df first release
dwinter
parents:
diff changeset
107 logger.debug(String.format("Signature: %s (%s)", signatureCount,
fb3f3df002df first release
dwinter
parents:
diff changeset
108 maxsign));
fb3f3df002df first release
dwinter
parents:
diff changeset
109 OWLIndividual signatureInd = createSignature(signature);
fb3f3df002df first release
dwinter
parents:
diff changeset
110
fb3f3df002df first release
dwinter
parents:
diff changeset
111 @SuppressWarnings("unchecked")
fb3f3df002df first release
dwinter
parents:
diff changeset
112 List<Element> cards = XPath.selectNodes(signature, ".//carta");
fb3f3df002df first release
dwinter
parents:
diff changeset
113 int cardsCount = 1;
fb3f3df002df first release
dwinter
parents:
diff changeset
114 int maxcards = cards.size();
fb3f3df002df first release
dwinter
parents:
diff changeset
115
fb3f3df002df first release
dwinter
parents:
diff changeset
116 // Element card=cards.get(0);
fb3f3df002df first release
dwinter
parents:
diff changeset
117 for (Element card : cards) {
fb3f3df002df first release
dwinter
parents:
diff changeset
118 logger.debug(String.format("Cards: %s (%s)", cardsCount++,
fb3f3df002df first release
dwinter
parents:
diff changeset
119 maxcards));
fb3f3df002df first release
dwinter
parents:
diff changeset
120 logger.debug(String.format("Signature: %s (%s)",
fb3f3df002df first release
dwinter
parents:
diff changeset
121 signatureCount, maxsign));
fb3f3df002df first release
dwinter
parents:
diff changeset
122 OWLIndividual cardInd = createCard(card, signatureInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
123
fb3f3df002df first release
dwinter
parents:
diff changeset
124 @SuppressWarnings("unchecked")
fb3f3df002df first release
dwinter
parents:
diff changeset
125 List<Element> records = XPath.selectNodes(card, ".//record");
fb3f3df002df first release
dwinter
parents:
diff changeset
126 for (Element record : records) {
fb3f3df002df first release
dwinter
parents:
diff changeset
127 // Element record = records.get(0);
fb3f3df002df first release
dwinter
parents:
diff changeset
128 OWLIndividual recordInd = createRecord(record, cardInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
129 OWLIndividual recordEvent = createEvent(record, recordInd); // Event
fb3f3df002df first release
dwinter
parents:
diff changeset
130 // und
fb3f3df002df first release
dwinter
parents:
diff changeset
131 // Records
fb3f3df002df first release
dwinter
parents:
diff changeset
132 // sind
fb3f3df002df first release
dwinter
parents:
diff changeset
133 // im
fb3f3df002df first release
dwinter
parents:
diff changeset
134 // Original
fb3f3df002df first release
dwinter
parents:
diff changeset
135 // im
fb3f3df002df first release
dwinter
parents:
diff changeset
136 // record-tag
fb3f3df002df first release
dwinter
parents:
diff changeset
137 }
fb3f3df002df first release
dwinter
parents:
diff changeset
138 }
fb3f3df002df first release
dwinter
parents:
diff changeset
139 signatureCount++;
fb3f3df002df first release
dwinter
parents:
diff changeset
140 }
fb3f3df002df first release
dwinter
parents:
diff changeset
141 owlDoc.printModel();
fb3f3df002df first release
dwinter
parents:
diff changeset
142 }
fb3f3df002df first release
dwinter
parents:
diff changeset
143
fb3f3df002df first release
dwinter
parents:
diff changeset
144 private OWLIndividual createEvent(Element record, OWLIndividual recordInd) {
fb3f3df002df first release
dwinter
parents:
diff changeset
145
fb3f3df002df first release
dwinter
parents:
diff changeset
146 logger.debug("Create Event");
fb3f3df002df first release
dwinter
parents:
diff changeset
147 OWLIndividual eventInstance = owlDoc.createInstance("RecordedEvent");
fb3f3df002df first release
dwinter
parents:
diff changeset
148
fb3f3df002df first release
dwinter
parents:
diff changeset
149 owlDoc.setProperty(recordInd, "crm:P70_documents", eventInstance);
fb3f3df002df first release
dwinter
parents:
diff changeset
150
fb3f3df002df first release
dwinter
parents:
diff changeset
151 // timespan
fb3f3df002df first release
dwinter
parents:
diff changeset
152
fb3f3df002df first release
dwinter
parents:
diff changeset
153 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
154 String dateDcStart = lexDoc.getValue(record, ".//datdf/startdate");
fb3f3df002df first release
dwinter
parents:
diff changeset
155
fb3f3df002df first release
dwinter
parents:
diff changeset
156 String dateDcEnd = lexDoc.getValue(record, ".//datdf/startdate");
fb3f3df002df first release
dwinter
parents:
diff changeset
157
fb3f3df002df first release
dwinter
parents:
diff changeset
158 if (!dateDcStart.equals("")) {
fb3f3df002df first release
dwinter
parents:
diff changeset
159 OWLIndividual timeSpan = owlDoc.createTimeSpan(dateDcStart,
fb3f3df002df first release
dwinter
parents:
diff changeset
160 dateDcEnd);
fb3f3df002df first release
dwinter
parents:
diff changeset
161 owlDoc.setProperty(eventInstance, "crm:P4_has_time-span",
fb3f3df002df first release
dwinter
parents:
diff changeset
162 timeSpan);
fb3f3df002df first release
dwinter
parents:
diff changeset
163 }
fb3f3df002df first release
dwinter
parents:
diff changeset
164 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
165 // TODO Auto-generated catch block
fb3f3df002df first release
dwinter
parents:
diff changeset
166 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
167 }
fb3f3df002df first release
dwinter
parents:
diff changeset
168
fb3f3df002df first release
dwinter
parents:
diff changeset
169 // tipol
fb3f3df002df first release
dwinter
parents:
diff changeset
170 String typology;
fb3f3df002df first release
dwinter
parents:
diff changeset
171 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
172 typology = lexDoc.getValue(record, ".//tipol");
fb3f3df002df first release
dwinter
parents:
diff changeset
173 OWLIndividual typolInd = createOrGetTipol(typology);
fb3f3df002df first release
dwinter
parents:
diff changeset
174 owlDoc.setProperty(eventInstance, "has_tipol", typolInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
175
fb3f3df002df first release
dwinter
parents:
diff changeset
176 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
177 // TODO Auto-generated catch block
fb3f3df002df first release
dwinter
parents:
diff changeset
178 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
179 }
fb3f3df002df first release
dwinter
parents:
diff changeset
180
fb3f3df002df first release
dwinter
parents:
diff changeset
181 // reges
fb3f3df002df first release
dwinter
parents:
diff changeset
182 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
183 createNewDependingDataTypePropertyFromXpath(record, eventInstance,
fb3f3df002df first release
dwinter
parents:
diff changeset
184 ".//reges/italian", "has_reges", "it");
fb3f3df002df first release
dwinter
parents:
diff changeset
185 createNewDependingDataTypePropertyFromXpath(record, eventInstance,
fb3f3df002df first release
dwinter
parents:
diff changeset
186 ".//reges/english", "has_reges", "en");
fb3f3df002df first release
dwinter
parents:
diff changeset
187 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
188 // TODO Auto-generated catch block
fb3f3df002df first release
dwinter
parents:
diff changeset
189 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
190 }
fb3f3df002df first release
dwinter
parents:
diff changeset
191
fb3f3df002df first release
dwinter
parents:
diff changeset
192 // nomiq
fb3f3df002df first release
dwinter
parents:
diff changeset
193
fb3f3df002df first release
dwinter
parents:
diff changeset
194 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
195 @SuppressWarnings("unchecked")
fb3f3df002df first release
dwinter
parents:
diff changeset
196 List<Element> nomiqs = XPath.selectNodes(record, ".//nomiq");
fb3f3df002df first release
dwinter
parents:
diff changeset
197 OWLIndividual recordNamesRoles = null;
fb3f3df002df first release
dwinter
parents:
diff changeset
198 for (Element nomiq : nomiqs) {
fb3f3df002df first release
dwinter
parents:
diff changeset
199 String name = lexDoc.getValue(nomiq, "./name");
fb3f3df002df first release
dwinter
parents:
diff changeset
200 String role = lexDoc.getValue(nomiq, "./role");
fb3f3df002df first release
dwinter
parents:
diff changeset
201
fb3f3df002df first release
dwinter
parents:
diff changeset
202 if (!name.equals("") && !role.equals("")) {
fb3f3df002df first release
dwinter
parents:
diff changeset
203 recordNamesRoles = handleNameWithRole(recordInd, name, role);
fb3f3df002df first release
dwinter
parents:
diff changeset
204 } else if (!role.equals("")) {
fb3f3df002df first release
dwinter
parents:
diff changeset
205 recordNamesRoles = handleRole(recordInd, role);
fb3f3df002df first release
dwinter
parents:
diff changeset
206 } else if (!name.equals("")) {
fb3f3df002df first release
dwinter
parents:
diff changeset
207 recordNamesRoles = handleName(recordInd, name);
fb3f3df002df first release
dwinter
parents:
diff changeset
208 }
fb3f3df002df first release
dwinter
parents:
diff changeset
209
fb3f3df002df first release
dwinter
parents:
diff changeset
210 if (recordNamesRoles != null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
211 owlDoc.setProperty(eventInstance,
fb3f3df002df first release
dwinter
parents:
diff changeset
212 "recordsDuomoObjectNameRoles", recordNamesRoles);
fb3f3df002df first release
dwinter
parents:
diff changeset
213 String id = lexDoc.getValue(nomiq, "./@id");
fb3f3df002df first release
dwinter
parents:
diff changeset
214 individualIds.put(id, recordNamesRoles);
fb3f3df002df first release
dwinter
parents:
diff changeset
215 }
fb3f3df002df first release
dwinter
parents:
diff changeset
216 }
fb3f3df002df first release
dwinter
parents:
diff changeset
217
fb3f3df002df first release
dwinter
parents:
diff changeset
218 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
219 // TODO Auto-generated catch block
fb3f3df002df first release
dwinter
parents:
diff changeset
220 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
221 }
fb3f3df002df first release
dwinter
parents:
diff changeset
222
fb3f3df002df first release
dwinter
parents:
diff changeset
223 // istit
fb3f3df002df first release
dwinter
parents:
diff changeset
224 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
225 String istit = lexDoc.getValue(record, "./istit");
fb3f3df002df first release
dwinter
parents:
diff changeset
226 OWLIndividual istitInd = owlDoc.getIndividualByReadableId(
fb3f3df002df first release
dwinter
parents:
diff changeset
227 "IndicesInstitutions", istit);
fb3f3df002df first release
dwinter
parents:
diff changeset
228 if (istitInd == null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
229 istitInd = createOrGetInstitution(istit);
fb3f3df002df first release
dwinter
parents:
diff changeset
230 }
fb3f3df002df first release
dwinter
parents:
diff changeset
231
fb3f3df002df first release
dwinter
parents:
diff changeset
232 owlDoc.setProperty(eventInstance, "recordsDuomoObjectInstitution",
fb3f3df002df first release
dwinter
parents:
diff changeset
233 istitInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
234
fb3f3df002df first release
dwinter
parents:
diff changeset
235 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
236 // TODO Auto-generated catch block
fb3f3df002df first release
dwinter
parents:
diff changeset
237 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
238 }
fb3f3df002df first release
dwinter
parents:
diff changeset
239
fb3f3df002df first release
dwinter
parents:
diff changeset
240 // types
fb3f3df002df first release
dwinter
parents:
diff changeset
241
fb3f3df002df first release
dwinter
parents:
diff changeset
242 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
243 List<Element> types = XPath.selectNodes(record, ".//type");
fb3f3df002df first release
dwinter
parents:
diff changeset
244 for (Element type : types) {
fb3f3df002df first release
dwinter
parents:
diff changeset
245 createType(eventInstance, type);
fb3f3df002df first release
dwinter
parents:
diff changeset
246 }
fb3f3df002df first release
dwinter
parents:
diff changeset
247 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
248 // TODO Auto-generated catch block
fb3f3df002df first release
dwinter
parents:
diff changeset
249 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
250 }
fb3f3df002df first release
dwinter
parents:
diff changeset
251
fb3f3df002df first release
dwinter
parents:
diff changeset
252 return eventInstance;
fb3f3df002df first release
dwinter
parents:
diff changeset
253 }
fb3f3df002df first release
dwinter
parents:
diff changeset
254
fb3f3df002df first release
dwinter
parents:
diff changeset
255 private void createType(OWLIndividual eventInstance, Element type) {
fb3f3df002df first release
dwinter
parents:
diff changeset
256
fb3f3df002df first release
dwinter
parents:
diff changeset
257 String typeId;
fb3f3df002df first release
dwinter
parents:
diff changeset
258 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
259 typeId = lexDoc.getValue(type, "./ptr/@target");
fb3f3df002df first release
dwinter
parents:
diff changeset
260 String clsName = owlDoc.getClassNameFromTypeId(typeId);
fb3f3df002df first release
dwinter
parents:
diff changeset
261 OWLNamedClass cls = owlDoc.getClassFromTypeId(typeId);
fb3f3df002df first release
dwinter
parents:
diff changeset
262 OWLIndividual typeInd = owlDoc.createInstance(clsName);
fb3f3df002df first release
dwinter
parents:
diff changeset
263
fb3f3df002df first release
dwinter
parents:
diff changeset
264 OWLNamedClass subjectClass = getPreferredTargetClass(cls,
fb3f3df002df first release
dwinter
parents:
diff changeset
265 "has_subject");
fb3f3df002df first release
dwinter
parents:
diff changeset
266 OWLNamedClass predicateClass = getPreferredTargetClass(cls,
fb3f3df002df first release
dwinter
parents:
diff changeset
267 "has_predicate");
fb3f3df002df first release
dwinter
parents:
diff changeset
268
fb3f3df002df first release
dwinter
parents:
diff changeset
269 List<Element> freeTexts = XPath.selectNodes(type, "./freetext");
fb3f3df002df first release
dwinter
parents:
diff changeset
270 for (Element freeText : freeTexts) {
fb3f3df002df first release
dwinter
parents:
diff changeset
271
fb3f3df002df first release
dwinter
parents:
diff changeset
272 String subjPointer = lexDoc.getValue(freeText,
fb3f3df002df first release
dwinter
parents:
diff changeset
273 "./sub/ptrtoperson/@target");
fb3f3df002df first release
dwinter
parents:
diff changeset
274 String subjText = lexDoc.getValue(freeText, "./sub");
fb3f3df002df first release
dwinter
parents:
diff changeset
275
fb3f3df002df first release
dwinter
parents:
diff changeset
276 OWLIndividual subjInd = createSubjectOrPredicate(subjectClass,
fb3f3df002df first release
dwinter
parents:
diff changeset
277 subjPointer, subjText);
fb3f3df002df first release
dwinter
parents:
diff changeset
278
fb3f3df002df first release
dwinter
parents:
diff changeset
279 String predPointer = lexDoc.getValue(freeText,
fb3f3df002df first release
dwinter
parents:
diff changeset
280 "./pred/ptrtoperson/@target");
fb3f3df002df first release
dwinter
parents:
diff changeset
281 String predText = lexDoc.getValue(freeText, "./pred");
fb3f3df002df first release
dwinter
parents:
diff changeset
282
fb3f3df002df first release
dwinter
parents:
diff changeset
283 OWLIndividual predInd = createSubjectOrPredicate(
fb3f3df002df first release
dwinter
parents:
diff changeset
284 predicateClass, predPointer, predText);
fb3f3df002df first release
dwinter
parents:
diff changeset
285
fb3f3df002df first release
dwinter
parents:
diff changeset
286 if (subjInd != null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
287 owlDoc.setProperty(typeInd, "has_subject", subjInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
288 }
fb3f3df002df first release
dwinter
parents:
diff changeset
289
fb3f3df002df first release
dwinter
parents:
diff changeset
290 if (predInd != null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
291 owlDoc.setProperty(typeInd, "has_predicate", predInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
292 }
fb3f3df002df first release
dwinter
parents:
diff changeset
293
fb3f3df002df first release
dwinter
parents:
diff changeset
294 owlDoc.setProperty(eventInstance, "recordsDuomoObjectConcept",
fb3f3df002df first release
dwinter
parents:
diff changeset
295 typeInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
296 }
fb3f3df002df first release
dwinter
parents:
diff changeset
297
fb3f3df002df first release
dwinter
parents:
diff changeset
298 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
299 // TODO Auto-generated catch block
fb3f3df002df first release
dwinter
parents:
diff changeset
300 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
301 }
fb3f3df002df first release
dwinter
parents:
diff changeset
302
fb3f3df002df first release
dwinter
parents:
diff changeset
303 }
fb3f3df002df first release
dwinter
parents:
diff changeset
304
fb3f3df002df first release
dwinter
parents:
diff changeset
305 private OWLIndividual createSubjectOrPredicate(OWLNamedClass toClass,
fb3f3df002df first release
dwinter
parents:
diff changeset
306 String subjPointer, String subjText) {
fb3f3df002df first release
dwinter
parents:
diff changeset
307 OWLIndividual subjInd = null;
fb3f3df002df first release
dwinter
parents:
diff changeset
308
fb3f3df002df first release
dwinter
parents:
diff changeset
309 if (!subjPointer.equals("")) {
fb3f3df002df first release
dwinter
parents:
diff changeset
310 subjInd = toClass.createOWLIndividual(null);
fb3f3df002df first release
dwinter
parents:
diff changeset
311 OWLIndividual ind = individualIds.get(subjPointer);
fb3f3df002df first release
dwinter
parents:
diff changeset
312 if (ind == null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
313 logger.debug("target ID does not exist:" + subjPointer);
fb3f3df002df first release
dwinter
parents:
diff changeset
314 } else {
fb3f3df002df first release
dwinter
parents:
diff changeset
315 owlDoc.setProperty(subjInd, "has_NameOrRoleFromIndex", ind);
fb3f3df002df first release
dwinter
parents:
diff changeset
316 }
fb3f3df002df first release
dwinter
parents:
diff changeset
317 }
fb3f3df002df first release
dwinter
parents:
diff changeset
318
fb3f3df002df first release
dwinter
parents:
diff changeset
319 if (!subjText.equals("")) {
fb3f3df002df first release
dwinter
parents:
diff changeset
320 if (subjInd == null)
fb3f3df002df first release
dwinter
parents:
diff changeset
321 subjInd = toClass.createOWLIndividual(null);
fb3f3df002df first release
dwinter
parents:
diff changeset
322
fb3f3df002df first release
dwinter
parents:
diff changeset
323 OWLNamedClass idcls = owlDoc.owlModel
fb3f3df002df first release
dwinter
parents:
diff changeset
324 .getOWLNamedClass("Identifier"); // is die klasse selbst
fb3f3df002df first release
dwinter
parents:
diff changeset
325 // schon ein identifiert
fb3f3df002df first release
dwinter
parents:
diff changeset
326 if (toClass.getNamedSuperclasses(true).contains(idcls)) { // to
fb3f3df002df first release
dwinter
parents:
diff changeset
327 owlDoc.setProperty(subjInd, "has_readable_id", subjText);
fb3f3df002df first release
dwinter
parents:
diff changeset
328 } else {
fb3f3df002df first release
dwinter
parents:
diff changeset
329
fb3f3df002df first release
dwinter
parents:
diff changeset
330 OWLIndividual ident = owlDoc
fb3f3df002df first release
dwinter
parents:
diff changeset
331 .createInstance("IdentifierPredicateOrSubject");
fb3f3df002df first release
dwinter
parents:
diff changeset
332 owlDoc.setProperty(ident, "has_readable_id", subjText);
fb3f3df002df first release
dwinter
parents:
diff changeset
333 owlDoc.setProperty(subjInd, "crm:P48_has_preferred_identifier",
fb3f3df002df first release
dwinter
parents:
diff changeset
334 ident);
fb3f3df002df first release
dwinter
parents:
diff changeset
335 }
fb3f3df002df first release
dwinter
parents:
diff changeset
336 }
fb3f3df002df first release
dwinter
parents:
diff changeset
337 return subjInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
338 }
fb3f3df002df first release
dwinter
parents:
diff changeset
339
fb3f3df002df first release
dwinter
parents:
diff changeset
340 private OWLNamedClass getPreferredTargetClass(OWLNamedClass cls,
fb3f3df002df first release
dwinter
parents:
diff changeset
341 String propertyName) {
fb3f3df002df first release
dwinter
parents:
diff changeset
342 RDFProperty prop = owlDoc.owlModel.getRDFProperty(propertyName);
fb3f3df002df first release
dwinter
parents:
diff changeset
343
fb3f3df002df first release
dwinter
parents:
diff changeset
344 // finde welche klasse als subject erlaubt ist
fb3f3df002df first release
dwinter
parents:
diff changeset
345 Collection<?> restrictions = cls.getRestrictions(prop, true);
fb3f3df002df first release
dwinter
parents:
diff changeset
346
fb3f3df002df first release
dwinter
parents:
diff changeset
347 RDFResource restrictionValues = prop.getRange(); // nimm erstmal den
fb3f3df002df first release
dwinter
parents:
diff changeset
348 // gesammten Range
fb3f3df002df first release
dwinter
parents:
diff changeset
349
fb3f3df002df first release
dwinter
parents:
diff changeset
350 // schaue jetzt nach ob eb es einschraenkungen gibt.
fb3f3df002df first release
dwinter
parents:
diff changeset
351 for (Iterator<?> it = restrictions.iterator(); it.hasNext();) {
fb3f3df002df first release
dwinter
parents:
diff changeset
352 Object restriction = it.next();
fb3f3df002df first release
dwinter
parents:
diff changeset
353 if (OWLAllValuesFrom.class.isInstance(restriction)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
354 OWLAllValuesFrom ar = (OWLAllValuesFrom) restriction;
fb3f3df002df first release
dwinter
parents:
diff changeset
355 restrictionValues = ar.getAllValuesFrom();
fb3f3df002df first release
dwinter
parents:
diff changeset
356 break;
fb3f3df002df first release
dwinter
parents:
diff changeset
357 }
fb3f3df002df first release
dwinter
parents:
diff changeset
358
fb3f3df002df first release
dwinter
parents:
diff changeset
359 }
fb3f3df002df first release
dwinter
parents:
diff changeset
360 OWLNamedClass toClass = null;
fb3f3df002df first release
dwinter
parents:
diff changeset
361 if (OWLNamedClass.class.isInstance(restrictionValues)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
362 toClass = (OWLNamedClass) restrictionValues;
fb3f3df002df first release
dwinter
parents:
diff changeset
363 } else if (OWLDataRange.class.isInstance(restrictionValues)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
364 RDFList dr = ((OWLDataRange) restrictionValues).getOneOf();
fb3f3df002df first release
dwinter
parents:
diff changeset
365 for (Object d : dr.getValues()) {
fb3f3df002df first release
dwinter
parents:
diff changeset
366 System.out.println(d);
fb3f3df002df first release
dwinter
parents:
diff changeset
367 toClass = (OWLNamedClass) d;
fb3f3df002df first release
dwinter
parents:
diff changeset
368 // FIXME: geht das??
fb3f3df002df first release
dwinter
parents:
diff changeset
369 }
fb3f3df002df first release
dwinter
parents:
diff changeset
370 } else if (DefaultOWLUnionClass.class.isInstance(restrictionValues)) { // mehr
fb3f3df002df first release
dwinter
parents:
diff changeset
371 // als
fb3f3df002df first release
dwinter
parents:
diff changeset
372 // eine
fb3f3df002df first release
dwinter
parents:
diff changeset
373 // moeglich
fb3f3df002df first release
dwinter
parents:
diff changeset
374 DefaultOWLUnionClass ou = (DefaultOWLUnionClass) restrictionValues;
fb3f3df002df first release
dwinter
parents:
diff changeset
375 Set set = new HashSet();
fb3f3df002df first release
dwinter
parents:
diff changeset
376 ou.getNestedNamedClasses(set);
fb3f3df002df first release
dwinter
parents:
diff changeset
377
fb3f3df002df first release
dwinter
parents:
diff changeset
378 for (Iterator<?> it = set.iterator(); it.hasNext();) {
fb3f3df002df first release
dwinter
parents:
diff changeset
379 OWLNamedClass cl = (OWLNamedClass) it.next();
fb3f3df002df first release
dwinter
parents:
diff changeset
380 OWLNamedClass idcls = owlDoc.owlModel
fb3f3df002df first release
dwinter
parents:
diff changeset
381 .getOWLNamedClass("Identifier"); // nimm die Klasse die
fb3f3df002df first release
dwinter
parents:
diff changeset
382 // ein Identifier
fb3f3df002df first release
dwinter
parents:
diff changeset
383 // ist.
fb3f3df002df first release
dwinter
parents:
diff changeset
384 if (cl.getNamedSuperclasses(true).contains(idcls)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
385 toClass = cl;
fb3f3df002df first release
dwinter
parents:
diff changeset
386 break;
fb3f3df002df first release
dwinter
parents:
diff changeset
387 }
fb3f3df002df first release
dwinter
parents:
diff changeset
388
fb3f3df002df first release
dwinter
parents:
diff changeset
389 }
fb3f3df002df first release
dwinter
parents:
diff changeset
390 }
fb3f3df002df first release
dwinter
parents:
diff changeset
391 return toClass;
fb3f3df002df first release
dwinter
parents:
diff changeset
392 }
fb3f3df002df first release
dwinter
parents:
diff changeset
393
fb3f3df002df first release
dwinter
parents:
diff changeset
394 private OWLIndividual handleRole(OWLIndividual recordInd, String role) {
fb3f3df002df first release
dwinter
parents:
diff changeset
395 OWLIndividual roleInd = owlDoc.getIndividualByReadableId(
fb3f3df002df first release
dwinter
parents:
diff changeset
396 "IndicesRoles", role);
fb3f3df002df first release
dwinter
parents:
diff changeset
397 if (roleInd == null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
398 roleInd = createRole(role);
fb3f3df002df first release
dwinter
parents:
diff changeset
399 }
fb3f3df002df first release
dwinter
parents:
diff changeset
400
fb3f3df002df first release
dwinter
parents:
diff changeset
401 return roleInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
402 }
fb3f3df002df first release
dwinter
parents:
diff changeset
403
fb3f3df002df first release
dwinter
parents:
diff changeset
404 private OWLIndividual handleName(OWLIndividual recordInd, String name) {
fb3f3df002df first release
dwinter
parents:
diff changeset
405 OWLIndividual nameInd = owlDoc.getIndividualByReadableId(
fb3f3df002df first release
dwinter
parents:
diff changeset
406 "IndicesNames", name);
fb3f3df002df first release
dwinter
parents:
diff changeset
407 if (nameInd == null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
408 nameInd = createRole(name);
fb3f3df002df first release
dwinter
parents:
diff changeset
409 }
fb3f3df002df first release
dwinter
parents:
diff changeset
410
fb3f3df002df first release
dwinter
parents:
diff changeset
411 return nameInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
412 }
fb3f3df002df first release
dwinter
parents:
diff changeset
413
fb3f3df002df first release
dwinter
parents:
diff changeset
414 private OWLIndividual handleNameWithRole(OWLIndividual recordInd,
fb3f3df002df first release
dwinter
parents:
diff changeset
415 String name, String role) {
fb3f3df002df first release
dwinter
parents:
diff changeset
416 // teste ob schon ein solcer Eintrag existiert
fb3f3df002df first release
dwinter
parents:
diff changeset
417 OWLIndividual nameInd = owlDoc.getIndividualByReadableId(
fb3f3df002df first release
dwinter
parents:
diff changeset
418 "IndicesNames", name);
fb3f3df002df first release
dwinter
parents:
diff changeset
419 Boolean createNewNameWithRole = false;
fb3f3df002df first release
dwinter
parents:
diff changeset
420 if (nameInd == null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
421 nameInd = createOrGetName(name);
fb3f3df002df first release
dwinter
parents:
diff changeset
422 createNewNameWithRole = true; // name existierte nicht dann kann
fb3f3df002df first release
dwinter
parents:
diff changeset
423 // auch NameWithRole nicht
fb3f3df002df first release
dwinter
parents:
diff changeset
424 // existierten.
fb3f3df002df first release
dwinter
parents:
diff changeset
425 }
fb3f3df002df first release
dwinter
parents:
diff changeset
426 OWLIndividual roleInd = owlDoc.getIndividualByReadableId(
fb3f3df002df first release
dwinter
parents:
diff changeset
427 "IndicesRoles", role);
fb3f3df002df first release
dwinter
parents:
diff changeset
428 if (roleInd == null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
429 roleInd = createRole(role);
fb3f3df002df first release
dwinter
parents:
diff changeset
430 createNewNameWithRole = true; // role existierte nicht dann kann
fb3f3df002df first release
dwinter
parents:
diff changeset
431 // auch NameWithRole nicht
fb3f3df002df first release
dwinter
parents:
diff changeset
432 // existierten.
fb3f3df002df first release
dwinter
parents:
diff changeset
433 }
fb3f3df002df first release
dwinter
parents:
diff changeset
434 OWLIndividual nameWithRoleInd = null;
fb3f3df002df first release
dwinter
parents:
diff changeset
435 if (!createNewNameWithRole) { // schon klar, dass er nicht existiert
fb3f3df002df first release
dwinter
parents:
diff changeset
436 nameWithRoleInd = getNameWithRole(nameInd, roleInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
437 }
fb3f3df002df first release
dwinter
parents:
diff changeset
438
fb3f3df002df first release
dwinter
parents:
diff changeset
439 if (nameWithRoleInd == null) { // existiert nicht
fb3f3df002df first release
dwinter
parents:
diff changeset
440 nameWithRoleInd = createNameWithRole(nameInd, roleInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
441 }
fb3f3df002df first release
dwinter
parents:
diff changeset
442
fb3f3df002df first release
dwinter
parents:
diff changeset
443 return nameWithRoleInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
444 }
fb3f3df002df first release
dwinter
parents:
diff changeset
445
fb3f3df002df first release
dwinter
parents:
diff changeset
446 private OWLIndividual getNameWithRole(OWLIndividual nameInd,
fb3f3df002df first release
dwinter
parents:
diff changeset
447 OWLIndividual roleInd) {
fb3f3df002df first release
dwinter
parents:
diff changeset
448 List<OWLIndividual> indicesWithNames = owlDoc.getIndividuals(
fb3f3df002df first release
dwinter
parents:
diff changeset
449 "IndicesNameWithRole", "refers_to_name", nameInd); // suche alle
fb3f3df002df first release
dwinter
parents:
diff changeset
450 // infrage
fb3f3df002df first release
dwinter
parents:
diff changeset
451 // kommenden
fb3f3df002df first release
dwinter
parents:
diff changeset
452 // nameen
fb3f3df002df first release
dwinter
parents:
diff changeset
453
fb3f3df002df first release
dwinter
parents:
diff changeset
454 if (indicesWithNames == null) { // kein Treffer
fb3f3df002df first release
dwinter
parents:
diff changeset
455 return null;
fb3f3df002df first release
dwinter
parents:
diff changeset
456 }
fb3f3df002df first release
dwinter
parents:
diff changeset
457
fb3f3df002df first release
dwinter
parents:
diff changeset
458 for (OWLIndividual name : indicesWithNames) {
fb3f3df002df first release
dwinter
parents:
diff changeset
459 Object role = owlDoc.getRelatedIndividual(name, "refers_to_role");
fb3f3df002df first release
dwinter
parents:
diff changeset
460 if (roleInd.equals(role)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
461 return name;
fb3f3df002df first release
dwinter
parents:
diff changeset
462 }
fb3f3df002df first release
dwinter
parents:
diff changeset
463 }
fb3f3df002df first release
dwinter
parents:
diff changeset
464 return null;
fb3f3df002df first release
dwinter
parents:
diff changeset
465 }
fb3f3df002df first release
dwinter
parents:
diff changeset
466
fb3f3df002df first release
dwinter
parents:
diff changeset
467 private OWLIndividual createOrGetTipol(String typology) {
fb3f3df002df first release
dwinter
parents:
diff changeset
468 OWLIndividual tipol = owlDoc.createOrGetInstanceWithIdentifier("Typology","Identifier",typology);
fb3f3df002df first release
dwinter
parents:
diff changeset
469 return tipol;
fb3f3df002df first release
dwinter
parents:
diff changeset
470 }
fb3f3df002df first release
dwinter
parents:
diff changeset
471
fb3f3df002df first release
dwinter
parents:
diff changeset
472 private OWLIndividual createNameWithRole(OWLIndividual nameInd,
fb3f3df002df first release
dwinter
parents:
diff changeset
473 OWLIndividual roleInd) {
fb3f3df002df first release
dwinter
parents:
diff changeset
474
fb3f3df002df first release
dwinter
parents:
diff changeset
475 OWLIndividual nameWithRoleInd = owlDoc
fb3f3df002df first release
dwinter
parents:
diff changeset
476 .createInstance("IndicesNameWithRole");
fb3f3df002df first release
dwinter
parents:
diff changeset
477
fb3f3df002df first release
dwinter
parents:
diff changeset
478 owlDoc.setProperty(nameWithRoleInd, "refers_to_name", nameInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
479 owlDoc.setProperty(nameWithRoleInd, "refers_to_role", roleInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
480
fb3f3df002df first release
dwinter
parents:
diff changeset
481 return nameWithRoleInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
482
fb3f3df002df first release
dwinter
parents:
diff changeset
483 }
fb3f3df002df first release
dwinter
parents:
diff changeset
484
fb3f3df002df first release
dwinter
parents:
diff changeset
485 private OWLIndividual createOrGetInstitution(String name) {
fb3f3df002df first release
dwinter
parents:
diff changeset
486 OWLIndividual nameInd = owlDoc.createOrGetInstanceWithIdentifier("IndicesInstitutions","IdentifierInstitutions",name);
fb3f3df002df first release
dwinter
parents:
diff changeset
487
fb3f3df002df first release
dwinter
parents:
diff changeset
488 return nameInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
489 }
fb3f3df002df first release
dwinter
parents:
diff changeset
490
fb3f3df002df first release
dwinter
parents:
diff changeset
491 private OWLIndividual createOrGetName(String name) {
fb3f3df002df first release
dwinter
parents:
diff changeset
492 OWLIndividual nameInd = owlDoc.createOrGetInstanceWithIdentifier("IndicesNames","IdentifierNames",name);
fb3f3df002df first release
dwinter
parents:
diff changeset
493 return nameInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
494 }
fb3f3df002df first release
dwinter
parents:
diff changeset
495
fb3f3df002df first release
dwinter
parents:
diff changeset
496 private OWLIndividual createRole(String name) {
fb3f3df002df first release
dwinter
parents:
diff changeset
497 OWLIndividual roleInd = owlDoc.createOrGetInstanceWithIdentifier("IndicesRoles","IdentifierRoles",name);
fb3f3df002df first release
dwinter
parents:
diff changeset
498 return roleInd;
fb3f3df002df first release
dwinter
parents:
diff changeset
499 }
fb3f3df002df first release
dwinter
parents:
diff changeset
500
fb3f3df002df first release
dwinter
parents:
diff changeset
501 private OWLIndividual createRecord(Element record, OWLIndividual cardInd)
fb3f3df002df first release
dwinter
parents:
diff changeset
502 throws JDOMException {
fb3f3df002df first release
dwinter
parents:
diff changeset
503 OWLIndividual recordInstance = owlDoc.createInstance("Record");
fb3f3df002df first release
dwinter
parents:
diff changeset
504 owlDoc.setProperty(recordInstance, "is_on_card", cardInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
505 createNewDependingInstanceFromXpath(record, recordInstance, "./@id",
fb3f3df002df first release
dwinter
parents:
diff changeset
506 new String[] { "has_readable_id", "rdfs:label" },
fb3f3df002df first release
dwinter
parents:
diff changeset
507 "IdentifierCurrent", "crm:P48_has_preferred_identifier");
fb3f3df002df first release
dwinter
parents:
diff changeset
508
fb3f3df002df first release
dwinter
parents:
diff changeset
509 String value = lexDoc.getValue(record, ".//textblockid");
fb3f3df002df first release
dwinter
parents:
diff changeset
510 if (!value.equals(""))
fb3f3df002df first release
dwinter
parents:
diff changeset
511 owlDoc.setProperty(recordInstance, "has_textblockid", value);
fb3f3df002df first release
dwinter
parents:
diff changeset
512
fb3f3df002df first release
dwinter
parents:
diff changeset
513 String endOnCarta = lexDoc.getValue(record, "./@end_on_carta");
fb3f3df002df first release
dwinter
parents:
diff changeset
514 if (!endOnCarta.equals("")) {
fb3f3df002df first release
dwinter
parents:
diff changeset
515 OWLIndividual signature = (OWLIndividual) owlDoc
fb3f3df002df first release
dwinter
parents:
diff changeset
516 .getRelatedIndividual(cardInd, "has_signature");
fb3f3df002df first release
dwinter
parents:
diff changeset
517 addRecordToCarta(recordInstance, value, signature);
fb3f3df002df first release
dwinter
parents:
diff changeset
518 }
fb3f3df002df first release
dwinter
parents:
diff changeset
519
fb3f3df002df first release
dwinter
parents:
diff changeset
520 String dateDcStart = lexDoc.getValue(record, ".//datdc/startdate");
fb3f3df002df first release
dwinter
parents:
diff changeset
521 String dateDcEnd = lexDoc.getValue(record, ".//datdc/startdate");
fb3f3df002df first release
dwinter
parents:
diff changeset
522
fb3f3df002df first release
dwinter
parents:
diff changeset
523 OWLIndividual timeSpan = owlDoc.createTimeSpan(dateDcStart, dateDcEnd);
fb3f3df002df first release
dwinter
parents:
diff changeset
524
fb3f3df002df first release
dwinter
parents:
diff changeset
525 owlDoc.setProperty(recordInstance, "crm:P4_has_time-span", timeSpan);
fb3f3df002df first release
dwinter
parents:
diff changeset
526
fb3f3df002df first release
dwinter
parents:
diff changeset
527 return recordInstance;
fb3f3df002df first release
dwinter
parents:
diff changeset
528 }
fb3f3df002df first release
dwinter
parents:
diff changeset
529
fb3f3df002df first release
dwinter
parents:
diff changeset
530 private void addRecordToCarta(OWLIndividual recordInstance, String cardID,
fb3f3df002df first release
dwinter
parents:
diff changeset
531 OWLIndividual signature) {
fb3f3df002df first release
dwinter
parents:
diff changeset
532
fb3f3df002df first release
dwinter
parents:
diff changeset
533 OWLIndividual card = owlDoc.getIndividualByReadableId("Card", cardID);
fb3f3df002df first release
dwinter
parents:
diff changeset
534
fb3f3df002df first release
dwinter
parents:
diff changeset
535 if (card == null) {
fb3f3df002df first release
dwinter
parents:
diff changeset
536 card = createCard(cardID, signature);
fb3f3df002df first release
dwinter
parents:
diff changeset
537 }
fb3f3df002df first release
dwinter
parents:
diff changeset
538
fb3f3df002df first release
dwinter
parents:
diff changeset
539 owlDoc.setProperty(recordInstance, "is_on_card", card);
fb3f3df002df first release
dwinter
parents:
diff changeset
540 }
fb3f3df002df first release
dwinter
parents:
diff changeset
541
fb3f3df002df first release
dwinter
parents:
diff changeset
542 private OWLIndividual createSignature(Element signature)
fb3f3df002df first release
dwinter
parents:
diff changeset
543 throws JDOMException {
fb3f3df002df first release
dwinter
parents:
diff changeset
544 Element segHeaderElement = (Element) XPath.selectSingleNode(signature,
fb3f3df002df first release
dwinter
parents:
diff changeset
545 ".//segheader");
fb3f3df002df first release
dwinter
parents:
diff changeset
546 String segheader = segHeaderElement.getTextTrim();
fb3f3df002df first release
dwinter
parents:
diff changeset
547
fb3f3df002df first release
dwinter
parents:
diff changeset
548 OWLIndividual signatureInstance = owlDoc.createInstance("Signatur");
fb3f3df002df first release
dwinter
parents:
diff changeset
549 owlDoc.setProperty(signatureInstance, "rdfs:label", segheader);
fb3f3df002df first release
dwinter
parents:
diff changeset
550 return signatureInstance;
fb3f3df002df first release
dwinter
parents:
diff changeset
551 }
fb3f3df002df first release
dwinter
parents:
diff changeset
552
fb3f3df002df first release
dwinter
parents:
diff changeset
553 private OWLIndividual createCard(String cardId, OWLIndividual signature) {
fb3f3df002df first release
dwinter
parents:
diff changeset
554
fb3f3df002df first release
dwinter
parents:
diff changeset
555 OWLIndividual cardInstance = owlDoc.createInstance("Card");
fb3f3df002df first release
dwinter
parents:
diff changeset
556
fb3f3df002df first release
dwinter
parents:
diff changeset
557 owlDoc.setProperty(cardInstance, "has_signature", signature);
fb3f3df002df first release
dwinter
parents:
diff changeset
558
fb3f3df002df first release
dwinter
parents:
diff changeset
559 OWLIndividual preferredId = owlDoc.createInstance("IdentifierCurrent");
fb3f3df002df first release
dwinter
parents:
diff changeset
560 owlDoc.setProperty(preferredId, "has_readable_id", cardId);
fb3f3df002df first release
dwinter
parents:
diff changeset
561 owlDoc.setProperty(preferredId, "rdfs:label", cardId);
fb3f3df002df first release
dwinter
parents:
diff changeset
562
fb3f3df002df first release
dwinter
parents:
diff changeset
563 owlDoc.setProperty(cardInstance, "crm:P48_has_preferred_identifier",
fb3f3df002df first release
dwinter
parents:
diff changeset
564 preferredId);
fb3f3df002df first release
dwinter
parents:
diff changeset
565
fb3f3df002df first release
dwinter
parents:
diff changeset
566 return cardInstance;
fb3f3df002df first release
dwinter
parents:
diff changeset
567 }
fb3f3df002df first release
dwinter
parents:
diff changeset
568
fb3f3df002df first release
dwinter
parents:
diff changeset
569 private OWLIndividual createCard(Element card, OWLIndividual signatureInd) {
fb3f3df002df first release
dwinter
parents:
diff changeset
570
fb3f3df002df first release
dwinter
parents:
diff changeset
571 OWLIndividual cardInstance = owlDoc.createInstance("Card");
fb3f3df002df first release
dwinter
parents:
diff changeset
572
fb3f3df002df first release
dwinter
parents:
diff changeset
573 try {
fb3f3df002df first release
dwinter
parents:
diff changeset
574
fb3f3df002df first release
dwinter
parents:
diff changeset
575 createNewDependingInstanceFromXpath(card, cardInstance,
fb3f3df002df first release
dwinter
parents:
diff changeset
576 ".//cartanr", new String[] { "has_readable_id",
fb3f3df002df first release
dwinter
parents:
diff changeset
577 "rdfs:label" }, "IdentifierCurrent",
fb3f3df002df first release
dwinter
parents:
diff changeset
578 "crm:P48_has_preferred_identifier");
fb3f3df002df first release
dwinter
parents:
diff changeset
579
fb3f3df002df first release
dwinter
parents:
diff changeset
580 createNewDependingInstanceFromXpath(card, cardInstance,
fb3f3df002df first release
dwinter
parents:
diff changeset
581 ".//cartaant", new String[] { "has_readable_id",
fb3f3df002df first release
dwinter
parents:
diff changeset
582 "rdfs:label" }, "IdentifierCurrent",
fb3f3df002df first release
dwinter
parents:
diff changeset
583 "crm:P1_is_identified_by");
fb3f3df002df first release
dwinter
parents:
diff changeset
584
fb3f3df002df first release
dwinter
parents:
diff changeset
585 owlDoc.setProperty(cardInstance, "has_signature", signatureInd);
fb3f3df002df first release
dwinter
parents:
diff changeset
586
fb3f3df002df first release
dwinter
parents:
diff changeset
587 } catch (JDOMException e) {
fb3f3df002df first release
dwinter
parents:
diff changeset
588 e.printStackTrace();
fb3f3df002df first release
dwinter
parents:
diff changeset
589 return null;
fb3f3df002df first release
dwinter
parents:
diff changeset
590 }
fb3f3df002df first release
dwinter
parents:
diff changeset
591
fb3f3df002df first release
dwinter
parents:
diff changeset
592 return cardInstance;
fb3f3df002df first release
dwinter
parents:
diff changeset
593 }
fb3f3df002df first release
dwinter
parents:
diff changeset
594
fb3f3df002df first release
dwinter
parents:
diff changeset
595 private void createNewDependingInstanceFromXpath(Element card,
fb3f3df002df first release
dwinter
parents:
diff changeset
596 OWLIndividual cardInstance, String xpath, String[] propertyNames,
fb3f3df002df first release
dwinter
parents:
diff changeset
597 String newInstanceClassName, String relationNameToNewInstance)
fb3f3df002df first release
dwinter
parents:
diff changeset
598 throws JDOMException {
fb3f3df002df first release
dwinter
parents:
diff changeset
599
fb3f3df002df first release
dwinter
parents:
diff changeset
600 List<?> identifierIdEls = (List<?>) XPath.selectNodes(card, xpath);
fb3f3df002df first release
dwinter
parents:
diff changeset
601 for (Object identifierIdEl : identifierIdEls) {
fb3f3df002df first release
dwinter
parents:
diff changeset
602 String identifierId = "";
fb3f3df002df first release
dwinter
parents:
diff changeset
603 if (Element.class.isInstance(identifierIdEl)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
604 identifierId = ((Element) identifierIdEl).getTextTrim();
fb3f3df002df first release
dwinter
parents:
diff changeset
605 } else if (Attribute.class.isInstance(identifierIdEl)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
606 identifierId = ((Attribute) identifierIdEl).getValue();
fb3f3df002df first release
dwinter
parents:
diff changeset
607 }
fb3f3df002df first release
dwinter
parents:
diff changeset
608
fb3f3df002df first release
dwinter
parents:
diff changeset
609 OWLIndividual identifier = owlDoc
fb3f3df002df first release
dwinter
parents:
diff changeset
610 .createInstance(newInstanceClassName);
fb3f3df002df first release
dwinter
parents:
diff changeset
611 for (int i = 0; i < propertyNames.length; i++) {
fb3f3df002df first release
dwinter
parents:
diff changeset
612 owlDoc.setProperty(identifier, propertyNames[i], identifierId);
fb3f3df002df first release
dwinter
parents:
diff changeset
613 }
fb3f3df002df first release
dwinter
parents:
diff changeset
614
fb3f3df002df first release
dwinter
parents:
diff changeset
615 owlDoc.setProperty(cardInstance, relationNameToNewInstance,
fb3f3df002df first release
dwinter
parents:
diff changeset
616 identifier);
fb3f3df002df first release
dwinter
parents:
diff changeset
617 }
fb3f3df002df first release
dwinter
parents:
diff changeset
618
fb3f3df002df first release
dwinter
parents:
diff changeset
619 }
fb3f3df002df first release
dwinter
parents:
diff changeset
620
fb3f3df002df first release
dwinter
parents:
diff changeset
621 // createNewDependingDataTypePropertyFromXpath(record, eventInstance,
fb3f3df002df first release
dwinter
parents:
diff changeset
622 // ".//resges/italian", "has_reges",
fb3f3df002df first release
dwinter
parents:
diff changeset
623 // "italian");
fb3f3df002df first release
dwinter
parents:
diff changeset
624 private void createNewDependingDataTypePropertyFromXpath(Element record,
fb3f3df002df first release
dwinter
parents:
diff changeset
625 OWLIndividual eventInstance, String xpath, String propertyName,
fb3f3df002df first release
dwinter
parents:
diff changeset
626 String lang) throws JDOMException {
fb3f3df002df first release
dwinter
parents:
diff changeset
627
fb3f3df002df first release
dwinter
parents:
diff changeset
628 List<?> identifierIdEls = (List<?>) XPath.selectNodes(record, xpath);
fb3f3df002df first release
dwinter
parents:
diff changeset
629 for (Object identifierIdEl : identifierIdEls) {
fb3f3df002df first release
dwinter
parents:
diff changeset
630 String identifierId = "";
fb3f3df002df first release
dwinter
parents:
diff changeset
631 if (Element.class.isInstance(identifierIdEl)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
632 identifierId = ((Element) identifierIdEl).getTextTrim();
fb3f3df002df first release
dwinter
parents:
diff changeset
633 } else if (Attribute.class.isInstance(identifierIdEl)) {
fb3f3df002df first release
dwinter
parents:
diff changeset
634 identifierId = ((Attribute) identifierIdEl).getValue();
fb3f3df002df first release
dwinter
parents:
diff changeset
635 }
fb3f3df002df first release
dwinter
parents:
diff changeset
636
fb3f3df002df first release
dwinter
parents:
diff changeset
637 owlDoc.setDataTypePropery(eventInstance, propertyName,
fb3f3df002df first release
dwinter
parents:
diff changeset
638 identifierId, lang);
fb3f3df002df first release
dwinter
parents:
diff changeset
639 }
fb3f3df002df first release
dwinter
parents:
diff changeset
640 }
fb3f3df002df first release
dwinter
parents:
diff changeset
641 }