More work on language production
This commit is contained in:
parent
142c6503f8
commit
f13dc58d8b
|
@ -0,0 +1,34 @@
|
||||||
|
package org.hl7.fhir.r5.elementmodel;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.NotImplementedException;
|
||||||
|
import org.hl7.fhir.exceptions.DefinitionException;
|
||||||
|
import org.hl7.fhir.exceptions.FHIRException;
|
||||||
|
import org.hl7.fhir.exceptions.FHIRFormatError;
|
||||||
|
import org.hl7.fhir.r5.context.IWorkerContext;
|
||||||
|
import org.hl7.fhir.r5.elementmodel.ParserBase.NamedElement;
|
||||||
|
import org.hl7.fhir.r5.formats.IParser.OutputStyle;
|
||||||
|
|
||||||
|
public class ResourceParser extends ParserBase {
|
||||||
|
|
||||||
|
public ResourceParser(IWorkerContext context) {
|
||||||
|
super(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<NamedElement> parse(InputStream stream) throws IOException, FHIRFormatError, DefinitionException, FHIRException {
|
||||||
|
throw new NotImplementedException("parse(InputStream stream)"); // doesns't make sense
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void compose(Element e, OutputStream destination, OutputStyle style, String base)
|
||||||
|
throws FHIRException, IOException {
|
||||||
|
throw new NotImplementedException("compose(Element e, OutputStream destination, OutputStyle style, String base)"); // doesns't make sense
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -21,7 +21,7 @@ public class ResourceLanguageFileBuilder {
|
||||||
private String source;
|
private String source;
|
||||||
private String target;
|
private String target;
|
||||||
private IWorkerContext context;
|
private IWorkerContext context;
|
||||||
StructureDefinition sd = null;
|
StructureDefinition profile = null;
|
||||||
|
|
||||||
public void prepare(LanguageFileProducer file, IWorkerContext context, String source, String target) {
|
public void prepare(LanguageFileProducer file, IWorkerContext context, String source, String target) {
|
||||||
this.file = file;
|
this.file = file;
|
||||||
|
@ -30,17 +30,30 @@ public class ResourceLanguageFileBuilder {
|
||||||
this.context = context;
|
this.context = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public StructureDefinition getProfile() {
|
||||||
|
return profile;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setProfile(StructureDefinition profile) {
|
||||||
|
this.profile = profile;
|
||||||
|
}
|
||||||
|
|
||||||
public void build(Resource res) throws IOException {
|
public void build(Resource res) throws IOException {
|
||||||
String id = res.fhirType();
|
String id = res.fhirType();
|
||||||
String path = res.fhirType() +"-"+res.getIdBase();
|
String path = res.fhirType() +"-"+res.getIdBase();
|
||||||
|
|
||||||
if (!source.equals(res.getLanguage())) {
|
if (!source.equals(res.getLanguage())) {
|
||||||
throw new FHIRException("Language mismatch");
|
throw new FHIRException("Language mismatch: '"+source+"' => '"+target+"' but resource language is '"+res.getLanguage()+"'");
|
||||||
}
|
}
|
||||||
sd = context.fetchTypeDefinition(res.fhirType());
|
|
||||||
if (sd == null) {
|
if (profile == null) {
|
||||||
|
profile = context.fetchTypeDefinition(res.fhirType());
|
||||||
|
if (profile == null) {
|
||||||
throw new FHIRException("profile");
|
throw new FHIRException("profile");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
file.start(path, path, res.getUserString("path"), source, target);
|
file.start(path, path, res.getUserString("path"), source, target);
|
||||||
|
|
||||||
for (Property p : res.children()) {
|
for (Property p : res.children()) {
|
||||||
|
@ -50,7 +63,6 @@ public class ResourceLanguageFileBuilder {
|
||||||
file.finish();
|
file.finish();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void process(Property p, String id, String path) throws IOException {
|
private void process(Property p, String id, String path) throws IOException {
|
||||||
if (p.hasValues()) {
|
if (p.hasValues()) {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
@ -58,7 +70,7 @@ public class ResourceLanguageFileBuilder {
|
||||||
String pid = id+"."+p.getName();
|
String pid = id+"."+p.getName();
|
||||||
String ppath = path+"."+p.getName()+(p.isList() ? "["+i+"]" : "");
|
String ppath = path+"."+p.getName()+(p.isList() ? "["+i+"]" : "");
|
||||||
i++;
|
i++;
|
||||||
if (isTranslatable(p, b, id)) {
|
if (isTranslatable(p, b, pid)) {
|
||||||
file.makeEntry(ppath, null, null, b.primitiveValue(), getTranslation(b, target));
|
file.makeEntry(ppath, null, null, b.primitiveValue(), getTranslation(b, target));
|
||||||
}
|
}
|
||||||
for (Property pp : b.children()) {
|
for (Property pp : b.children()) {
|
||||||
|
@ -71,7 +83,7 @@ public class ResourceLanguageFileBuilder {
|
||||||
private boolean isTranslatable(Property p, Base b, String id) {
|
private boolean isTranslatable(Property p, Base b, String id) {
|
||||||
if (new ContextUtilities(context).isPrimitiveDatatype(b.fhirType())) { // never any translations for non-primitives
|
if (new ContextUtilities(context).isPrimitiveDatatype(b.fhirType())) { // never any translations for non-primitives
|
||||||
ElementDefinition ed = null;
|
ElementDefinition ed = null;
|
||||||
for (ElementDefinition t : sd.getSnapshot().getElement()) {
|
for (ElementDefinition t : profile.getSnapshot().getElement()) {
|
||||||
if (t.getId().equals(id)) {
|
if (t.getId().equals(id)) {
|
||||||
ed = t;
|
ed = t;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
package org.hl7.fhir.r5.utils;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.hl7.fhir.exceptions.FHIRFormatError;
|
||||||
|
import org.hl7.fhir.r5.context.IWorkerContext;
|
||||||
|
import org.hl7.fhir.r5.formats.JsonParser;
|
||||||
|
import org.hl7.fhir.r5.formats.XmlParser;
|
||||||
|
import org.hl7.fhir.r5.model.Resource;
|
||||||
|
import org.hl7.fhir.r5.model.StructureDefinition;
|
||||||
|
import org.hl7.fhir.r5.test.utils.TestingUtilities;
|
||||||
|
import org.hl7.fhir.utilities.Utilities;
|
||||||
|
import org.hl7.fhir.utilities.i18n.XLIFFProducer;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
public class ResourceLanguageFileBuilderTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testXLIFFGeneration() throws FHIRFormatError, IOException {
|
||||||
|
Resource res = new JsonParser().parse(TestingUtilities.loadTestResourceStream("r5", "structuredefinition-language.json"));
|
||||||
|
res.setUserData("path", "test.resource.xml");
|
||||||
|
ResourceLanguageFileBuilder lang = new ResourceLanguageFileBuilder();
|
||||||
|
IWorkerContext ctxt = TestingUtilities.getSharedWorkerContext();
|
||||||
|
ctxt.cacheResource(new JsonParser().parse(TestingUtilities.loadTestResourceStream("r5", "languages", "StructureDefinition-ed-translatable.json")));
|
||||||
|
ctxt.cacheResource(new JsonParser().parse(TestingUtilities.loadTestResourceStream("r5", "languages", "StructureDefinition-sd-translatable.json")));
|
||||||
|
lang.setProfile(ctxt.fetchResource(StructureDefinition.class, "http://hl7.org/tests/fhir/StructureDefinition/sd-translatable"));
|
||||||
|
lang.prepare(new XLIFFProducer(Utilities.path("[tmp]", "language")), ctxt, "en", "fr");
|
||||||
|
lang.build(res);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -20,32 +20,29 @@ public class XLIFFProducer extends LanguageFileProducer {
|
||||||
public void start(String fileName, String contextId, String contextDesc, String baseLang, String targetLang) {
|
public void start(String fileName, String contextId, String contextDesc, String baseLang, String targetLang) {
|
||||||
this.fileName = fileName;
|
this.fileName = fileName;
|
||||||
xml = new StringBuilder();
|
xml = new StringBuilder();
|
||||||
ln("<xliff xmlns=\"urn:oasis:names:tc:xliff:document:2.0\" version=\"2.0\"");
|
ln("<?xml version=\"1.0\" ?>\r\n");
|
||||||
ln(" srcLang=\""+baseLang+"\" trgLang=\""+targetLang+"\">");
|
ln("<xliff xmlns=\"urn:oasis:names:tc:xliff:document:2.0\" version=\"2.0\">");
|
||||||
ln(" <file id=\""+contextId+"\">");
|
ln(" <file source-language=\""+baseLang+"\" target-language=\""+targetLang+"\" id=\""+contextId+"\" original=\""+contextDesc+"\" datatype=\"KEYVALUEJSON\">");
|
||||||
ln(" <notes>");
|
ln(" <body>");
|
||||||
ln(" <note id=\"n1\">"+Utilities.escapeXml(contextDesc)+"</note>");
|
|
||||||
ln(" </notes>");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void makeEntry(String id, String ref, String context, String source, String target) {
|
public void makeEntry(String id, String ref, String context, String source, String target) {
|
||||||
i++;
|
i++;
|
||||||
ln(" <unit id=\""+id+"\">");
|
ln(" <trans-unit id=\""+id+"\" resname=\""+ref+"\">");
|
||||||
if (context != null) {
|
if (context != null) {
|
||||||
ln(" <notes>");
|
ln(" <notes>");
|
||||||
ln(" <note id=\"n"+i+"\">"+Utilities.escapeXml(context)+"</note>");
|
ln(" <note id=\"n"+i+"\">"+Utilities.escapeXml(context)+"</note>");
|
||||||
ln(" </notes>");
|
ln(" </notes>");
|
||||||
}
|
}
|
||||||
ln(" <segment id=\""+ref+"\">");
|
ln(" <source>"+Utilities.escapeXml(source)+"</source>");
|
||||||
ln(" <source><pc id=\"src"+i+"\">"+Utilities.escapeXml(source)+"</source>");
|
ln(" <target>"+Utilities.escapeXml(target)+"</target>");
|
||||||
ln(" <target><pc id=\"tgt"+i+"\">"+Utilities.escapeXml(target)+"</target>");
|
ln(" </trans-unit>");
|
||||||
ln(" </segment>");
|
|
||||||
ln(" </unit>");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void finish() throws IOException {
|
public void finish() throws IOException {
|
||||||
|
ln(" </body>");
|
||||||
ln(" </file>");
|
ln(" </file>");
|
||||||
ln("</xliff>");
|
ln("</xliff>");
|
||||||
TextFile.stringToFile(xml.toString(), Utilities.path(getFolder(), fileName+".xliff"));
|
TextFile.stringToFile(xml.toString(), Utilities.path(getFolder(), fileName+".xliff"));
|
||||||
|
|
Loading…
Reference in New Issue