ICU-4758 Changes to conform to XLIFF 1.1 and the ICU Resource Bundle Profile document.
X-SVN-Rev: 21773
This commit is contained in:
parent
202d784973
commit
a9ab594c6d
@ -8,6 +8,8 @@
|
|||||||
package com.ibm.icu.dev.tool.localeconverter;
|
package com.ibm.icu.dev.tool.localeconverter;
|
||||||
|
|
||||||
import com.ibm.icu.dev.tool.UOption;
|
import com.ibm.icu.dev.tool.UOption;
|
||||||
|
import com.ibm.icu.text.MessageFormat;
|
||||||
|
|
||||||
import org.w3c.dom.Document;
|
import org.w3c.dom.Document;
|
||||||
import org.w3c.dom.Node;
|
import org.w3c.dom.Node;
|
||||||
import org.w3c.dom.NamedNodeMap;
|
import org.w3c.dom.NamedNodeMap;
|
||||||
@ -18,6 +20,9 @@ import org.xml.sax.SAXException;
|
|||||||
import org.xml.sax.SAXParseException;
|
import org.xml.sax.SAXParseException;
|
||||||
import javax.xml.parsers.DocumentBuilder;
|
import javax.xml.parsers.DocumentBuilder;
|
||||||
import javax.xml.parsers.DocumentBuilderFactory;
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import javax.xml.validation.Schema;
|
||||||
|
import javax.xml.validation.SchemaFactory;
|
||||||
|
import javax.xml.XMLConstants;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -34,6 +39,7 @@ public final class XLIFF2ICUConverter {
|
|||||||
private static final int TARGETONLY = 4;
|
private static final int TARGETONLY = 4;
|
||||||
private static final int SOURCEONLY = 5;
|
private static final int SOURCEONLY = 5;
|
||||||
private static final int MAKE_SOURCE_ROOT = 6;
|
private static final int MAKE_SOURCE_ROOT = 6;
|
||||||
|
private static final int XLIFF_1_0 = 7;
|
||||||
|
|
||||||
private static final UOption[] options = new UOption[] {
|
private static final UOption[] options = new UOption[] {
|
||||||
UOption.HELP_H(),
|
UOption.HELP_H(),
|
||||||
@ -42,9 +48,37 @@ public final class XLIFF2ICUConverter {
|
|||||||
UOption.DESTDIR(),
|
UOption.DESTDIR(),
|
||||||
UOption.create("target-only", 't', UOption.OPTIONAL_ARG),
|
UOption.create("target-only", 't', UOption.OPTIONAL_ARG),
|
||||||
UOption.create("source-only", 'c', UOption.OPTIONAL_ARG),
|
UOption.create("source-only", 'c', UOption.OPTIONAL_ARG),
|
||||||
UOption.create("make-source-root", 'r', UOption.NO_ARG)
|
UOption.create("make-source-root", 'r', UOption.NO_ARG),
|
||||||
|
UOption.create("xliff-1.0", 'x', UOption.NO_ARG)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
private static final int ARRAY_RESOURCE = 0;
|
||||||
|
private static final int ALIAS_RESOURCE = 1;
|
||||||
|
private static final int BINARY_RESOURCE = 2;
|
||||||
|
private static final int INTEGER_RESOURCE = 3;
|
||||||
|
private static final int INTVECTOR_RESOURCE = 4;
|
||||||
|
private static final int TABLE_RESOURCE = 5;
|
||||||
|
|
||||||
|
private static final String NEW_RESOURCES[] = {
|
||||||
|
"x-icu-array",
|
||||||
|
"x-icu-alias",
|
||||||
|
"x-icu-binary",
|
||||||
|
"x-icu-integer",
|
||||||
|
"x-icu-intvector",
|
||||||
|
"x-icu-table"
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final String OLD_RESOURCES[] = {
|
||||||
|
"array",
|
||||||
|
"alias",
|
||||||
|
"bin",
|
||||||
|
"int",
|
||||||
|
"intvector",
|
||||||
|
"table"
|
||||||
|
};
|
||||||
|
|
||||||
|
private String resources[];
|
||||||
|
|
||||||
private static final String ROOT = "root";
|
private static final String ROOT = "root";
|
||||||
private static final String RESTYPE = "restype";
|
private static final String RESTYPE = "restype";
|
||||||
private static final String RESNAME = "resname";
|
private static final String RESNAME = "resname";
|
||||||
@ -108,6 +142,7 @@ public final class XLIFF2ICUConverter {
|
|||||||
private boolean makeSourceRoot = false;
|
private boolean makeSourceRoot = false;
|
||||||
private String sourceFileName = null;
|
private String sourceFileName = null;
|
||||||
private boolean sourceOnly = false;
|
private boolean sourceOnly = false;
|
||||||
|
private boolean xliff10 = false;
|
||||||
|
|
||||||
private void processArgs(String[] args) {
|
private void processArgs(String[] args) {
|
||||||
int remainingArgc = 0;
|
int remainingArgc = 0;
|
||||||
@ -130,13 +165,16 @@ public final class XLIFF2ICUConverter {
|
|||||||
if(options[SOURCEDIR].doesOccur) {
|
if(options[SOURCEDIR].doesOccur) {
|
||||||
sourceDir = options[SOURCEDIR].value;
|
sourceDir = options[SOURCEDIR].value;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(options[DESTDIR].doesOccur) {
|
if(options[DESTDIR].doesOccur) {
|
||||||
destDir = options[DESTDIR].value;
|
destDir = options[DESTDIR].value;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(options[TARGETONLY].doesOccur){
|
if(options[TARGETONLY].doesOccur){
|
||||||
targetOnly = true;
|
targetOnly = true;
|
||||||
targetFileName = options[TARGETONLY].value;
|
targetFileName = options[TARGETONLY].value;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(options[SOURCEONLY].doesOccur){
|
if(options[SOURCEONLY].doesOccur){
|
||||||
sourceOnly = true;
|
sourceOnly = true;
|
||||||
sourceFileName = options[SOURCEONLY].value;
|
sourceFileName = options[SOURCEONLY].value;
|
||||||
@ -145,9 +183,15 @@ public final class XLIFF2ICUConverter {
|
|||||||
if(options[MAKE_SOURCE_ROOT].doesOccur){
|
if(options[MAKE_SOURCE_ROOT].doesOccur){
|
||||||
makeSourceRoot = true;
|
makeSourceRoot = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(options[XLIFF_1_0].doesOccur) {
|
||||||
|
xliff10 = true;
|
||||||
|
}
|
||||||
|
|
||||||
if(destDir==null){
|
if(destDir==null){
|
||||||
destDir = ".";
|
destDir = ".";
|
||||||
}
|
}
|
||||||
|
|
||||||
if(sourceOnly == true && targetOnly == true){
|
if(sourceOnly == true && targetOnly == true){
|
||||||
System.err.println("--source-only and --target-only are specified. Please check the arguments and try again.");
|
System.err.println("--source-only and --target-only are specified. Please check the arguments and try again.");
|
||||||
usage();
|
usage();
|
||||||
@ -175,6 +219,7 @@ public final class XLIFF2ICUConverter {
|
|||||||
"-c or --source-only only generate the source language bundle followed by optional output file name.\n"+
|
"-c or --source-only only generate the source language bundle followed by optional output file name.\n"+
|
||||||
" Cannot be used in conjunction with --target-only.\n"+
|
" Cannot be used in conjunction with --target-only.\n"+
|
||||||
"-r or --make-source-root produce root bundle from source elements.\n" +
|
"-r or --make-source-root produce root bundle from source elements.\n" +
|
||||||
|
"-x or --xliff-1.0 source file is XLIFF 1.0" +
|
||||||
"example: com.ibm.icu.dev.tool.localeconverter.XLIFF2ICUConverter -t <optional argument> -s xxx -d yyy myResources.xlf");
|
"example: com.ibm.icu.dev.tool.localeconverter.XLIFF2ICUConverter -t <optional argument> -s xxx -d yyy myResources.xlf");
|
||||||
System.exit(-1);
|
System.exit(-1);
|
||||||
}
|
}
|
||||||
@ -321,9 +366,25 @@ public final class XLIFF2ICUConverter {
|
|||||||
String urls = filenameToURL(xmlfileName);
|
String urls = filenameToURL(xmlfileName);
|
||||||
DocumentBuilderFactory dfactory = DocumentBuilderFactory.newInstance();
|
DocumentBuilderFactory dfactory = DocumentBuilderFactory.newInstance();
|
||||||
dfactory.setNamespaceAware(true);
|
dfactory.setNamespaceAware(true);
|
||||||
dfactory.setValidating(true);
|
|
||||||
Document doc = null;
|
Document doc = null;
|
||||||
|
|
||||||
|
if (xliff10) {
|
||||||
|
dfactory.setValidating(true);
|
||||||
|
resources = OLD_RESOURCES;
|
||||||
|
} else {
|
||||||
|
try {
|
||||||
|
SchemaFactory schemaFactory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
|
||||||
|
Schema schema = schemaFactory.newSchema();
|
||||||
|
|
||||||
|
dfactory.setSchema(schema);
|
||||||
|
} catch (SAXException e) {
|
||||||
|
System.err.println("Can't create the schema...");
|
||||||
|
System.exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
resources = NEW_RESOURCES;
|
||||||
|
}
|
||||||
|
|
||||||
ErrorHandler nullHandler = new ErrorHandler() {
|
ErrorHandler nullHandler = new ErrorHandler() {
|
||||||
public void warning(SAXParseException e) throws SAXException {
|
public void warning(SAXParseException e) throws SAXException {
|
||||||
|
|
||||||
@ -348,6 +409,7 @@ public final class XLIFF2ICUConverter {
|
|||||||
if(nlist.getLength()>1){
|
if(nlist.getLength()>1){
|
||||||
throw new RuntimeException("Multiple <file> elements in the XLIFF file not supported.");
|
throw new RuntimeException("Multiple <file> elements in the XLIFF file not supported.");
|
||||||
}
|
}
|
||||||
|
|
||||||
// get the value of source-language attribute
|
// get the value of source-language attribute
|
||||||
String sourceLang = getLanguageName(doc, SOURCELANGUAGE);
|
String sourceLang = getLanguageName(doc, SOURCELANGUAGE);
|
||||||
// get the value of target-language attribute
|
// get the value of target-language attribute
|
||||||
@ -570,7 +632,9 @@ public final class XLIFF2ICUConverter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
public void writeComments(OutputStream writer, int numIndent){
|
public void writeComments(OutputStream writer, int numIndent){
|
||||||
if(comment!=null || translate != null || noteLen > 0){
|
boolean translateIsDefault = translate == null || translate.equals("yes");
|
||||||
|
|
||||||
|
if(comment!=null || ! translateIsDefault || noteLen > 0){
|
||||||
// print the start of the comment
|
// print the start of the comment
|
||||||
writeIndent(writer, numIndent);
|
writeIndent(writer, numIndent);
|
||||||
write(writer, COMMENTSTART+LINESEP);
|
write(writer, COMMENTSTART+LINESEP);
|
||||||
@ -584,7 +648,7 @@ public final class XLIFF2ICUConverter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// print the translate attribute if any
|
// print the translate attribute if any
|
||||||
if(translate!=null){
|
if(! translateIsDefault){
|
||||||
writeIndent(writer, numIndent);
|
writeIndent(writer, numIndent);
|
||||||
write(writer, TAG+TRANSLATE+SPACE);
|
write(writer, TAG+TRANSLATE+SPACE);
|
||||||
write(writer, translate);
|
write(writer, translate);
|
||||||
@ -897,7 +961,7 @@ public final class XLIFF2ICUConverter {
|
|||||||
strings[0].translate = strings[1].translate = translate;
|
strings[0].translate = strings[1].translate = translate;
|
||||||
set[0] = strings[0];
|
set[0] = strings[0];
|
||||||
set[1] = strings[1];
|
set[1] = strings[1];
|
||||||
}else if(attrType.equals(INTS)){
|
}else if(attrType.equals(resources[INTEGER_RESOURCE])){
|
||||||
ResourceInt[] ints = new ResourceInt[2];
|
ResourceInt[] ints = new ResourceInt[2];
|
||||||
ints[0] = new ResourceInt();
|
ints[0] = new ResourceInt();
|
||||||
ints[1] = new ResourceInt();
|
ints[1] = new ResourceInt();
|
||||||
@ -905,7 +969,7 @@ public final class XLIFF2ICUConverter {
|
|||||||
ints[0].translate = ints[1].translate = translate;
|
ints[0].translate = ints[1].translate = translate;
|
||||||
set[0] = ints[0];
|
set[0] = ints[0];
|
||||||
set[1] = ints[1];
|
set[1] = ints[1];
|
||||||
}else if(attrType.equals(ALIAS)){
|
}else if(attrType.equals(resources[ALIAS_RESOURCE])){
|
||||||
ResourceAlias[] ints = new ResourceAlias[2];
|
ResourceAlias[] ints = new ResourceAlias[2];
|
||||||
ints[0] = new ResourceAlias();
|
ints[0] = new ResourceAlias();
|
||||||
ints[1] = new ResourceAlias();
|
ints[1] = new ResourceAlias();
|
||||||
@ -1127,11 +1191,11 @@ public final class XLIFF2ICUConverter {
|
|||||||
|
|
||||||
// figure out what kind of group this is
|
// figure out what kind of group this is
|
||||||
String resType = getAttributeValue(node, RESTYPE);
|
String resType = getAttributeValue(node, RESTYPE);
|
||||||
if(resType.equals(ARRAYS)){
|
if(resType.equals(resources[ARRAY_RESOURCE])){
|
||||||
parseArray(node, set);
|
parseArray(node, set);
|
||||||
}else if( resType.equals(TABLE)){
|
}else if( resType.equals(resources[TABLE_RESOURCE])){
|
||||||
parseTable(node, set);
|
parseTable(node, set);
|
||||||
}else if( resType.equals(INTVECTOR)){
|
}else if( resType.equals(resources[INTVECTOR_RESOURCE])){
|
||||||
parseIntVector(node, set);
|
parseIntVector(node, set);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1148,18 +1212,20 @@ public final class XLIFF2ICUConverter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void writeHeader(OutputStream writer, String fileName){
|
private void writeHeader(OutputStream writer, String fileName){
|
||||||
|
final String header =
|
||||||
|
"// ***************************************************************************" + LINESEP +
|
||||||
|
"// *" + LINESEP +
|
||||||
|
"// * Tool: com.ibm.icu.dev.tool.localeconverter.XLIFF2ICUConverter.java" + LINESEP +
|
||||||
|
"// * Date & Time: {0,date,MM/dd/yyyy hh:mm:ss a z}"+ LINESEP +
|
||||||
|
"// * Source File: {1}" + LINESEP +
|
||||||
|
"// *" + LINESEP +
|
||||||
|
"// ***************************************************************************" + LINESEP;
|
||||||
|
|
||||||
writeBOM(writer);
|
writeBOM(writer);
|
||||||
Calendar c = Calendar.getInstance();
|
MessageFormat format = new MessageFormat(header);
|
||||||
StringBuffer buffer =new StringBuffer();
|
Object args[] = {new Date(System.currentTimeMillis()), fileName};
|
||||||
buffer.append("// ***************************************************************************" + LINESEP);
|
|
||||||
buffer.append("// *" + LINESEP);
|
|
||||||
buffer.append("// * Tool: com.ibm.icu.dev.tool.localeconverter.XLIFF2ICUConverter.java" + LINESEP);
|
|
||||||
buffer.append("// * Date & Time: " + c.get(Calendar.YEAR) + "/" + (c.get(Calendar.MONTH)+1) + "/" + c.get(Calendar.DAY_OF_MONTH) + " " + c.get(Calendar.HOUR_OF_DAY) + COLON + c.get(Calendar.MINUTE)+ LINESEP);
|
|
||||||
buffer.append("// * Source File: " + fileName + LINESEP);
|
|
||||||
buffer.append("// *" + LINESEP);
|
|
||||||
buffer.append("// ***************************************************************************" + LINESEP);
|
|
||||||
writeLine(writer, buffer.toString());
|
|
||||||
|
|
||||||
|
writeLine(writer, format.format(args));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void writeBOM(OutputStream buffer) {
|
private void writeBOM(OutputStream buffer) {
|
||||||
|
Loading…
Reference in New Issue
Block a user