Merge from Puck.
This commit is contained in:
parent
16c24fa114
commit
fe7c652be2
15 changed files with 1923 additions and 64 deletions
|
@ -10,5 +10,6 @@
|
||||||
<classpathentry kind="lib" path="lib/log4j-1.2.17.jar"/>
|
<classpathentry kind="lib" path="lib/log4j-1.2.17.jar"/>
|
||||||
<classpathentry kind="lib" path="lib/slf4j-api-1.7.5.jar"/>
|
<classpathentry kind="lib" path="lib/slf4j-api-1.7.5.jar"/>
|
||||||
<classpathentry kind="lib" path="lib/slf4j-log4j12-1.7.5.jar"/>
|
<classpathentry kind="lib" path="lib/slf4j-log4j12-1.7.5.jar"/>
|
||||||
|
<classpathentry kind="lib" path="lib/commons-lang3-3.1.jar"/>
|
||||||
<classpathentry kind="output" path="bin"/>
|
<classpathentry kind="output" path="bin"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
|
|
|
@ -121,7 +121,7 @@
|
||||||
|
|
||||||
<!-- Package lib -->
|
<!-- Package lib -->
|
||||||
<copy todir="${dist.dir}/lib" overwrite="true">
|
<copy todir="${dist.dir}/lib" overwrite="true">
|
||||||
<fileset dir="lib" />
|
<fileset dir="lib" excludes="hamcrest-core*,junit*" />
|
||||||
</copy>
|
</copy>
|
||||||
|
|
||||||
</target>
|
</target>
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
Description of used libraries:
|
Description of used libraries:
|
||||||
|
- commons-lang: useful tools (StringUtils...)
|
||||||
- hamcrest-core: required by junit
|
- hamcrest-core: required by junit
|
||||||
- junit: unit tests API
|
- junit: unit tests API
|
||||||
- log4j: log API
|
- log4j: log API
|
||||||
|
|
BIN
lib/commons-lang3-3.1-sources.jar
Normal file
BIN
lib/commons-lang3-3.1-sources.jar
Normal file
Binary file not shown.
BIN
lib/commons-lang3-3.1.jar
Normal file
BIN
lib/commons-lang3-3.1.jar
Normal file
Binary file not shown.
|
@ -16,7 +16,7 @@ import java.util.ArrayList;
|
||||||
public class StringList extends ArrayList<String>
|
public class StringList extends ArrayList<String>
|
||||||
{
|
{
|
||||||
private static final long serialVersionUID = -1154185934830213732L;
|
private static final long serialVersionUID = -1154185934830213732L;
|
||||||
public String LINE_SEPARATOR = "\n";
|
public static final String LINE_SEPARATOR = "\n";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -34,6 +34,22 @@ public class StringList extends ArrayList<String>
|
||||||
super(size);
|
super(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public StringList(final String[] source)
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
|
||||||
|
if (source != null)
|
||||||
|
{
|
||||||
|
for (String string : source)
|
||||||
|
{
|
||||||
|
this.add(string);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -49,6 +65,37 @@ public class StringList extends ArrayList<String>
|
||||||
return (result);
|
return (result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public StringList append(final double value)
|
||||||
|
{
|
||||||
|
StringList result;
|
||||||
|
|
||||||
|
result = this.append(String.valueOf(value));
|
||||||
|
|
||||||
|
//
|
||||||
|
return (result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public StringList append(final Double value)
|
||||||
|
{
|
||||||
|
StringList result;
|
||||||
|
|
||||||
|
if (value != null)
|
||||||
|
{
|
||||||
|
this.append(String.valueOf(value));
|
||||||
|
}
|
||||||
|
|
||||||
|
result = this;
|
||||||
|
|
||||||
|
//
|
||||||
|
return (result);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -117,15 +164,15 @@ public class StringList extends ArrayList<String>
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public StringList append(final StringList string)
|
public StringList append(final StringList strings)
|
||||||
{
|
{
|
||||||
StringList result;
|
StringList result;
|
||||||
|
|
||||||
if (string != null)
|
if (strings != null)
|
||||||
{
|
{
|
||||||
for (int nString = 0; nString < string.size(); nString++)
|
for (String string : strings)
|
||||||
{
|
{
|
||||||
this.add(string.getByIndex(nString));
|
this.add(string);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -163,6 +210,19 @@ public class StringList extends ArrayList<String>
|
||||||
return (result);
|
return (result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public StringList appendln(final double value)
|
||||||
|
{
|
||||||
|
StringList result;
|
||||||
|
|
||||||
|
result = this.append(value).appendln();
|
||||||
|
|
||||||
|
//
|
||||||
|
return (result);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -248,9 +308,9 @@ public class StringList extends ArrayList<String>
|
||||||
{
|
{
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
for (int nString = 0; nString < this.size(); nString++)
|
for (String string : this)
|
||||||
{
|
{
|
||||||
result += this.getByIndex(nString).length();
|
result += string.length();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -284,27 +344,64 @@ public class StringList extends ArrayList<String>
|
||||||
{
|
{
|
||||||
String result;
|
String result;
|
||||||
|
|
||||||
StringBuffer preResult = new StringBuffer(this.lenght());
|
StringBuffer buffer = new StringBuffer(this.lenght());
|
||||||
|
|
||||||
for (int nString = 0; nString < this.size(); nString++)
|
for (String string : this)
|
||||||
{
|
{
|
||||||
preResult.append(this.getByIndex(nString));
|
buffer.append(string);
|
||||||
}
|
}
|
||||||
|
|
||||||
result = new String(preResult);
|
result = buffer.toString();
|
||||||
|
|
||||||
//
|
//
|
||||||
return (result);
|
return (result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public String toStringSeparatedBy(final String separator)
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
//
|
||||||
|
StringList buffer = new StringList(this.lenght() * 2);
|
||||||
|
for (String string : this)
|
||||||
|
{
|
||||||
|
buffer.append(string);
|
||||||
|
buffer.append(separator);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (separator != null)
|
||||||
|
{
|
||||||
|
buffer.removeLast();
|
||||||
|
}
|
||||||
|
|
||||||
|
result = buffer.toString();
|
||||||
|
|
||||||
|
//
|
||||||
|
return (result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeInto(final java.io.PrintWriter out) throws IOException
|
||||||
|
{
|
||||||
|
for (String string : this)
|
||||||
|
{
|
||||||
|
out.write(string);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public void writeInto(final java.io.Writer out) throws IOException
|
public void writeInto(final java.io.Writer out) throws IOException
|
||||||
{
|
{
|
||||||
for (int nString = 0; nString < this.size(); nString++)
|
for (String string : this)
|
||||||
{
|
{
|
||||||
out.write(this.getByIndex(nString));
|
out.write(string);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -315,7 +412,7 @@ public class StringList extends ArrayList<String>
|
||||||
{
|
{
|
||||||
String result;
|
String result;
|
||||||
|
|
||||||
StringList strings = new StringList();
|
StringList strings = new StringList(number);
|
||||||
for (int index = 0; index < number; index++)
|
for (int index = 0; index < number; index++)
|
||||||
{
|
{
|
||||||
strings.append(source);
|
strings.append(source);
|
||||||
|
@ -330,29 +427,17 @@ public class StringList extends ArrayList<String>
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static public String toString(final String[] strings)
|
static public String toString(final String[] source)
|
||||||
{
|
{
|
||||||
String result;
|
String result;
|
||||||
|
|
||||||
if (strings == null)
|
if (source == null)
|
||||||
{
|
{
|
||||||
result = null;
|
result = null;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
StringConcatenator string = new StringConcatenator();
|
result = new StringList(source).toString();
|
||||||
|
|
||||||
for (int nString = 0; nString < strings.length; nString++)
|
|
||||||
{
|
|
||||||
string.append(strings[nString]);
|
|
||||||
|
|
||||||
if (nString < strings.length - 1)
|
|
||||||
{
|
|
||||||
string.append(' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
result = string.toString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -424,19 +509,19 @@ public class StringList extends ArrayList<String>
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static public String toStringWithBrackets(final String[] strings)
|
static public String toStringWithBrackets(final String[] source)
|
||||||
{
|
{
|
||||||
String result;
|
String result;
|
||||||
|
|
||||||
if (strings == null)
|
if (source == null)
|
||||||
{
|
{
|
||||||
result = null;
|
result = null;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
StringConcatenator merge = new StringConcatenator();
|
StringList merge = new StringList();
|
||||||
|
|
||||||
for (String string : strings)
|
for (String string : source)
|
||||||
{
|
{
|
||||||
merge.append("[").append(string).append("]");
|
merge.append("[").append(string).append("]");
|
||||||
}
|
}
|
||||||
|
@ -451,29 +536,17 @@ public class StringList extends ArrayList<String>
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static public String toStringWithCommas(final String[] strings)
|
static public String toStringWithCommas(final String[] source)
|
||||||
{
|
{
|
||||||
String result;
|
String result;
|
||||||
|
|
||||||
if (strings == null)
|
if (source == null)
|
||||||
{
|
{
|
||||||
result = null;
|
result = null;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
StringConcatenator merge = new StringConcatenator();
|
result = new StringList(source).toStringSeparatedBy(",");
|
||||||
|
|
||||||
for (String string : strings)
|
|
||||||
{
|
|
||||||
if (merge.size() != 0)
|
|
||||||
{
|
|
||||||
merge.append(",");
|
|
||||||
}
|
|
||||||
|
|
||||||
merge.append(string);
|
|
||||||
}
|
|
||||||
|
|
||||||
result = merge.toString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -483,29 +556,17 @@ public class StringList extends ArrayList<String>
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static public String toStringWithFrenchCommas(final String[] strings)
|
static public String toStringWithFrenchCommas(final String[] source)
|
||||||
{
|
{
|
||||||
String result;
|
String result;
|
||||||
|
|
||||||
if (strings == null)
|
if (source == null)
|
||||||
{
|
{
|
||||||
result = null;
|
result = null;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
StringConcatenator merge = new StringConcatenator();
|
result = new StringList(source).toStringSeparatedBy(", ");
|
||||||
|
|
||||||
for (String string : strings)
|
|
||||||
{
|
|
||||||
if (merge.size() != 0)
|
|
||||||
{
|
|
||||||
merge.append(", ");
|
|
||||||
}
|
|
||||||
|
|
||||||
merge.append(string);
|
|
||||||
}
|
|
||||||
|
|
||||||
result = merge.toString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
404
src/fr/devinsy/util/ToolBox.java
Normal file
404
src/fr/devinsy/util/ToolBox.java
Normal file
|
@ -0,0 +1,404 @@
|
||||||
|
package fr.devinsy.util;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.OutputStreamWriter;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
@author christian.momon@devinsy.fr, June 2008, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class ToolBox
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* Source.
|
||||||
|
*
|
||||||
|
* @return Extension value or null.
|
||||||
|
*/
|
||||||
|
public static File addToName(final File file, final String addition)
|
||||||
|
{
|
||||||
|
File result;
|
||||||
|
|
||||||
|
if (file == null)
|
||||||
|
{
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
else if (addition == null)
|
||||||
|
{
|
||||||
|
result = file;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//
|
||||||
|
String sourceFileName = file.getAbsolutePath();
|
||||||
|
int separatorIndex = sourceFileName.lastIndexOf('.');
|
||||||
|
|
||||||
|
//
|
||||||
|
String targetFileName;
|
||||||
|
if (separatorIndex > 0)
|
||||||
|
{
|
||||||
|
targetFileName = sourceFileName.substring(0, separatorIndex) + addition + sourceFileName.substring(separatorIndex);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
targetFileName = sourceFileName + addition;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
result = new File(targetFileName);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String clean(final String source)
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
result = source.replaceAll("[^\\w ]", " ");
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns information about the calling class of a calledClass.
|
||||||
|
*
|
||||||
|
* @param calledClassName
|
||||||
|
* the class name which is the subject of the search.
|
||||||
|
*
|
||||||
|
* @return information about the calling class.
|
||||||
|
*/
|
||||||
|
public static StackTraceElement getCaller(final String calledClassName)
|
||||||
|
{
|
||||||
|
StackTraceElement result;
|
||||||
|
|
||||||
|
//
|
||||||
|
StackTraceElement[] stack = Thread.currentThread().getStackTrace();
|
||||||
|
// System.out.println("////////////////////////////");
|
||||||
|
// for (int i = 0; (i < stack.length) && (i < 4); i++) {
|
||||||
|
// System.out.println(i + " " + stack[i].getClassName());
|
||||||
|
// }
|
||||||
|
|
||||||
|
// Search for first entry of class called.
|
||||||
|
boolean ended = false;
|
||||||
|
Integer indexOfCalled = null;
|
||||||
|
int depth = 1;
|
||||||
|
while (!ended)
|
||||||
|
{
|
||||||
|
if (depth < stack.length)
|
||||||
|
{
|
||||||
|
String currentClassName = stack[depth].getClassName();
|
||||||
|
if (currentClassName.equals(calledClassName))
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
indexOfCalled = Integer.valueOf(depth);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depth += 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Search for caller of class called.
|
||||||
|
if (indexOfCalled == null)
|
||||||
|
{
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = null;
|
||||||
|
ended = false;
|
||||||
|
depth = indexOfCalled;
|
||||||
|
while (!ended)
|
||||||
|
{
|
||||||
|
if (depth < stack.length)
|
||||||
|
{
|
||||||
|
String currentClassName = stack[depth].getClassName();
|
||||||
|
if (currentClassName.equals(calledClassName))
|
||||||
|
{
|
||||||
|
depth += 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
result = stack[depth];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the extension of a file.
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* Source.
|
||||||
|
*
|
||||||
|
* @return Extension value or null.
|
||||||
|
*/
|
||||||
|
public static String getExtension(final File file)
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
if (file == null)
|
||||||
|
{
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
int separatorIndex = file.getName().lastIndexOf('.');
|
||||||
|
if (separatorIndex > 0)
|
||||||
|
{
|
||||||
|
result = file.getName().substring(separatorIndex + 1).toLowerCase();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param pattern
|
||||||
|
* @param source
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static int indexOf(final String pattern, final List<String> source)
|
||||||
|
{
|
||||||
|
int result;
|
||||||
|
|
||||||
|
if (source == null)
|
||||||
|
{
|
||||||
|
result = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
boolean ended = false;
|
||||||
|
result = -1;
|
||||||
|
int currentIndex = 0;
|
||||||
|
while (!ended)
|
||||||
|
{
|
||||||
|
if (currentIndex < source.size())
|
||||||
|
{
|
||||||
|
String sourceString = source.get(currentIndex);
|
||||||
|
if (StringUtils.equals(sourceString, pattern))
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
result = currentIndex;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
currentIndex += 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
currentIndex = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* @throws FileNotFoundException
|
||||||
|
* @throws UnsupportedEncodingException
|
||||||
|
*/
|
||||||
|
public static void save(final File file, final String string) throws UnsupportedEncodingException, FileNotFoundException
|
||||||
|
{
|
||||||
|
PrintWriter out = null;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
out = new PrintWriter(new OutputStreamWriter(new FileOutputStream(file), "UTF-8"));
|
||||||
|
|
||||||
|
out.println(string);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if (out != null)
|
||||||
|
{
|
||||||
|
out.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param source
|
||||||
|
* @param extension
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static File setExtension(final File source, final String extension)
|
||||||
|
{
|
||||||
|
File result;
|
||||||
|
|
||||||
|
if ((source == null) || (extension == null))
|
||||||
|
{
|
||||||
|
result = source;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
String sourceFileName = source.getAbsolutePath();
|
||||||
|
int separatorIndex = sourceFileName.lastIndexOf('.');
|
||||||
|
|
||||||
|
//
|
||||||
|
String targetFileName;
|
||||||
|
if (separatorIndex > 0)
|
||||||
|
{
|
||||||
|
targetFileName = sourceFileName.substring(0, separatorIndex) + extension;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
targetFileName = sourceFileName + extension;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
result = new File(targetFileName);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static Double[] sort(final Set<Double> source)
|
||||||
|
{
|
||||||
|
Double[] result;
|
||||||
|
|
||||||
|
if (source == null)
|
||||||
|
{
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = new Double[source.size()];
|
||||||
|
|
||||||
|
source.toArray(result);
|
||||||
|
Arrays.sort(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Concatenates int values from an array, adding decoration strings.
|
||||||
|
*
|
||||||
|
* @param values
|
||||||
|
* Source of int values.
|
||||||
|
* @param prefix
|
||||||
|
* Decoration to put on start.
|
||||||
|
* @param separator
|
||||||
|
* Decoration to put between values.
|
||||||
|
* @param postfix
|
||||||
|
* Decoration to put on end.
|
||||||
|
*
|
||||||
|
* @return A decorated string representing the int values.
|
||||||
|
*/
|
||||||
|
public static String toString(final int[] values, final String prefix, final String separator, final String postfix)
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
StringList buffer = new StringList();
|
||||||
|
|
||||||
|
//
|
||||||
|
if (prefix != null)
|
||||||
|
{
|
||||||
|
buffer.append(prefix);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
boolean firstPassed = false;
|
||||||
|
for (int value : values)
|
||||||
|
{
|
||||||
|
if (firstPassed)
|
||||||
|
{
|
||||||
|
buffer.append(separator);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
firstPassed = true;
|
||||||
|
}
|
||||||
|
buffer.append(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
if (postfix != null)
|
||||||
|
{
|
||||||
|
buffer.append(postfix);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
result = buffer.toString();
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param source
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static String toString(final String source)
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
if (source == null)
|
||||||
|
{
|
||||||
|
result = "";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = source;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
131
src/fr/devinsy/util/xml/XMLAttributes.java
Normal file
131
src/fr/devinsy/util/xml/XMLAttributes.java
Normal file
|
@ -0,0 +1,131 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import javax.xml.stream.events.Attribute;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLAttributes extends HashMap<String, Attribute> implements Iterable<Attribute> {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 8456469741805779474L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public XMLAttributes() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public XMLAttributes(final int capacity) {
|
||||||
|
super(capacity);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public XMLAttributes(final Iterator<Attribute> source) {
|
||||||
|
super();
|
||||||
|
if (source != null) {
|
||||||
|
while (source.hasNext()) {
|
||||||
|
Attribute attribute = source.next();
|
||||||
|
|
||||||
|
add(attribute);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public XMLAttributes(final XMLAttributes source) {
|
||||||
|
super();
|
||||||
|
addAll(source);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param attribute
|
||||||
|
*/
|
||||||
|
public void add(final Attribute attribute) {
|
||||||
|
if (attribute != null) {
|
||||||
|
put(attribute.getName().getLocalPart(), attribute);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param source
|
||||||
|
*/
|
||||||
|
public void addAll(final XMLAttributes source) {
|
||||||
|
for (Attribute attribute : source) {
|
||||||
|
this.add(attribute);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Attribute getByLabel(final String label) {
|
||||||
|
Attribute result;
|
||||||
|
|
||||||
|
result = get(label);
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Iterator<Attribute> iterator() {
|
||||||
|
Iterator<Attribute> result;
|
||||||
|
|
||||||
|
result = this.values().iterator();
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Set<String> labels() {
|
||||||
|
Set<String> result;
|
||||||
|
|
||||||
|
result = this.keySet();
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public List<Attribute> toList() {
|
||||||
|
List<Attribute> result;
|
||||||
|
|
||||||
|
result = new ArrayList<Attribute>(values());
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
32
src/fr/devinsy/util/xml/XMLBadFormatException.java
Normal file
32
src/fr/devinsy/util/xml/XMLBadFormatException.java
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLBadFormatException extends Exception {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 768256303984176512L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param code
|
||||||
|
* @param message
|
||||||
|
*/
|
||||||
|
public XMLBadFormatException(final String message) {
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param code
|
||||||
|
* @param message
|
||||||
|
* @param exception
|
||||||
|
*/
|
||||||
|
public XMLBadFormatException(final String message, final Exception exception) {
|
||||||
|
super(message, exception);
|
||||||
|
}
|
||||||
|
}
|
497
src/fr/devinsy/util/xml/XMLReader.java
Normal file
497
src/fr/devinsy/util/xml/XMLReader.java
Normal file
|
@ -0,0 +1,497 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
|
|
||||||
|
import javax.xml.namespace.QName;
|
||||||
|
import javax.xml.stream.XMLEventReader;
|
||||||
|
import javax.xml.stream.XMLInputFactory;
|
||||||
|
import javax.xml.stream.XMLStreamException;
|
||||||
|
import javax.xml.stream.events.XMLEvent;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import fr.devinsy.util.xml.XMLTag.TagType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
@author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLReader {
|
||||||
|
|
||||||
|
static private final Logger logger = LoggerFactory.getLogger(XMLReader.class);
|
||||||
|
|
||||||
|
protected XMLEventReader in;
|
||||||
|
private XMLEvent nextEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
protected XMLReader() {
|
||||||
|
this.in = null;
|
||||||
|
this.nextEvent = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws FileNotFoundException
|
||||||
|
* @throws UnsupportedEncodingException
|
||||||
|
*/
|
||||||
|
public XMLReader(final File file) throws FileNotFoundException, XMLStreamException {
|
||||||
|
|
||||||
|
this.nextEvent = null;
|
||||||
|
XMLInputFactory factory = XMLInputFactory.newInstance();
|
||||||
|
this.in = factory.createXMLEventReader(new FileInputStream(file), "UTF-8");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param target
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws UnsupportedEncodingException
|
||||||
|
*/
|
||||||
|
public XMLReader(final InputStream source) throws XMLStreamException {
|
||||||
|
|
||||||
|
this.nextEvent = null;
|
||||||
|
XMLInputFactory factory = XMLInputFactory.newInstance();
|
||||||
|
this.in = factory.createXMLEventReader(source);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws XMLStreamException
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void close() {
|
||||||
|
if (this.in != null) {
|
||||||
|
try {
|
||||||
|
this.in.close();
|
||||||
|
} catch (XMLStreamException exception) {
|
||||||
|
exception.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This methods does a premonition act. Useful to detect end of a list.
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
* @throws XMLStreamException
|
||||||
|
*/
|
||||||
|
public boolean hasNextStartTag(final String label) throws XMLStreamException {
|
||||||
|
boolean result;
|
||||||
|
|
||||||
|
// Load next event.
|
||||||
|
if (this.nextEvent == null) {
|
||||||
|
if (in.hasNext()) {
|
||||||
|
this.nextEvent = in.nextEvent();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Analyze next event.
|
||||||
|
if (this.nextEvent == null) {
|
||||||
|
result = false;
|
||||||
|
} else if ((this.nextEvent.isStartElement()) && (StringUtils.equals(this.nextEvent.asStartElement().getName().getLocalPart(), label))) {
|
||||||
|
result = true;
|
||||||
|
} else {
|
||||||
|
result = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
* @throws XMLStreamException
|
||||||
|
*/
|
||||||
|
public XMLTag readContentTag(final String label) throws XMLBadFormatException, XMLStreamException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
//
|
||||||
|
result = readTag();
|
||||||
|
|
||||||
|
//
|
||||||
|
if (result == null) {
|
||||||
|
throw new XMLBadFormatException("XML file ends prematurely, content tag [" + label + "] is expected.");
|
||||||
|
} else if (result.getType() != TagType.CONTENT) {
|
||||||
|
throw new XMLBadFormatException("Content tag [" + label + "] is missing.");
|
||||||
|
} else if (!StringUtils.equals(label, result.getLabel())) {
|
||||||
|
throw new XMLBadFormatException("Tag with label [" + label + "] is missing.");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
*/
|
||||||
|
public XMLTag readEndTag(final String label) throws XMLStreamException, XMLBadFormatException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
//
|
||||||
|
result = readTag();
|
||||||
|
|
||||||
|
//
|
||||||
|
if (result == null) {
|
||||||
|
throw new XMLBadFormatException("XML file ends prematurely, end tag [" + label + "] is expected.");
|
||||||
|
} else if (result.getType() != TagType.END) {
|
||||||
|
throw new XMLBadFormatException("End tag [" + label + "] is missing.");
|
||||||
|
} else if (!StringUtils.equals(result.getLabel(), label)) {
|
||||||
|
throw new XMLBadFormatException("Tag with label [" + label + "] is missing.");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public XMLTag readListTag(final String label) throws XMLStreamException, XMLBadFormatException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
//
|
||||||
|
result = readTag();
|
||||||
|
|
||||||
|
//
|
||||||
|
if (result == null) {
|
||||||
|
throw new XMLBadFormatException("XML file ends prematurely, tag [" + label + "] is expected.");
|
||||||
|
} else if ((result.getType() != TagType.START) && (result.getType() != TagType.EMPTY)) {
|
||||||
|
throw new XMLBadFormatException("List tag [" + label + "] is missing.");
|
||||||
|
} else if (!StringUtils.equals(label, result.getLabel())) {
|
||||||
|
throw new XMLBadFormatException("Tag with label [" + label + "] is missing.");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public XMLTag readNullableContentTag(final String label) throws XMLStreamException, XMLBadFormatException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
//
|
||||||
|
result = readTag();
|
||||||
|
|
||||||
|
//
|
||||||
|
if (result == null) {
|
||||||
|
throw new XMLBadFormatException("XML file ends prematurely, tag [" + label + "] is expected.");
|
||||||
|
} else if (!StringUtils.equals(label, result.getLabel())) {
|
||||||
|
throw new XMLBadFormatException("Nullable content tag [" + label + "] is missing.");
|
||||||
|
} else if ((result.getType() != TagType.EMPTY) && (result.getType() != TagType.CONTENT)) {
|
||||||
|
throw new XMLBadFormatException("Nullable content tag [" + label + "] is missing.");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public XMLTag readStartTag(final String label) throws XMLStreamException, XMLBadFormatException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
//
|
||||||
|
result = readTag();
|
||||||
|
|
||||||
|
//
|
||||||
|
if (result == null) {
|
||||||
|
throw new XMLBadFormatException("XML file ends prematurely, start tag [" + label + "] is expected.");
|
||||||
|
} else if (result.getType() != TagType.START) {
|
||||||
|
throw new XMLBadFormatException("Start tag [" + label + "] is missing.");
|
||||||
|
} else if (!StringUtils.equals(result.getLabel(), label)) {
|
||||||
|
throw new XMLBadFormatException("Tag with label [" + label + "] is missing.");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Transducer graph :
|
||||||
|
* <ul>
|
||||||
|
* <li>START_DOCUMENT => HEADER TAG
|
||||||
|
* <li>START_ELEMENT(X) + START_ELEMENT(Y) => <X><Y> => START TAG
|
||||||
|
* <li>START_ELEMENT(X) + CHARACTERS(C) + START_ELEMENT(Y) => <X>SPACES<Y>=>
|
||||||
|
* START TAG
|
||||||
|
* <li>START_ELEMENT(X) + CHARACTERS(C) + END_ELEMENT(X) => <X>C</X> =>
|
||||||
|
* CONTENT TAG
|
||||||
|
* <li>START_ELEMENT(X) + END_ELEMENT(X) => <X></X> => <X/> => EMPTY
|
||||||
|
* <li>END_ELEMENT(X) => </X> => END TAG
|
||||||
|
* <li>END_DOCUMENT => FOOTER TAG
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public XMLTag readTag() throws XMLStreamException, XMLBadFormatException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
int level = 1;
|
||||||
|
boolean ended = false;
|
||||||
|
result = null;
|
||||||
|
XMLAttributes attributesBuffer = null;
|
||||||
|
QName nameBuffer = null;
|
||||||
|
String contentBuffer = null;
|
||||||
|
while (!ended) {
|
||||||
|
//
|
||||||
|
XMLEvent event;
|
||||||
|
if (this.nextEvent != null) {
|
||||||
|
event = this.nextEvent;
|
||||||
|
this.nextEvent = null;
|
||||||
|
} else if (in.hasNext()) {
|
||||||
|
event = in.nextEvent();
|
||||||
|
} else {
|
||||||
|
event = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (event == null) {
|
||||||
|
result = null;
|
||||||
|
} else {
|
||||||
|
logger.debug("eventType=" + XMLTools.toString(event));
|
||||||
|
switch (level) {
|
||||||
|
case 1:
|
||||||
|
switch (event.getEventType()) {
|
||||||
|
case XMLEvent.START_DOCUMENT:
|
||||||
|
// START_DOCUMENT => START DOCUMENT TAG
|
||||||
|
ended = true;
|
||||||
|
result = new XMLTag(null, TagType.HEADER, null);
|
||||||
|
break;
|
||||||
|
case XMLEvent.START_ELEMENT:
|
||||||
|
// START_ELEMENT(X) => ...
|
||||||
|
nameBuffer = event.asStartElement().getName();
|
||||||
|
attributesBuffer = new XMLAttributes(event.asStartElement().getAttributes());
|
||||||
|
level += 1;
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_ELEMENT:
|
||||||
|
// END_ELEMENT(X) => </X> => END TAG
|
||||||
|
ended = true;
|
||||||
|
result = new XMLTag(event.asEndElement().getName(), TagType.END, null);
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_DOCUMENT:
|
||||||
|
// END_DOCUMENT => END DOCUMENT TAG
|
||||||
|
ended = true;
|
||||||
|
result = new XMLTag(null, TagType.FOOTER, null);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
switch (event.getEventType()) {
|
||||||
|
case XMLEvent.START_ELEMENT:
|
||||||
|
// START_ELEMENT(X) + START_ELEMENT(Y) => <X><Y>
|
||||||
|
// => START TAG
|
||||||
|
ended = true;
|
||||||
|
result = new XMLTag(nameBuffer, TagType.START, attributesBuffer);
|
||||||
|
this.nextEvent = event;
|
||||||
|
break;
|
||||||
|
case XMLEvent.CHARACTERS:
|
||||||
|
// START_ELEMENT(X) + CHARACTERS(C) => ...
|
||||||
|
contentBuffer = event.asCharacters().getData();
|
||||||
|
level += 1;
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_ELEMENT:
|
||||||
|
// START_ELEMENT(X) + END_ELEMENT(X) => <X></X>
|
||||||
|
// => <X/> => EMPTY
|
||||||
|
ended = true;
|
||||||
|
result = new XMLTag(nameBuffer, TagType.EMPTY, attributesBuffer);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new XMLBadFormatException("Unexpected XMLEvent [" + event.getEventType() + "].");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
switch (event.getEventType()) {
|
||||||
|
case XMLEvent.START_ELEMENT:
|
||||||
|
// START_ELEMENT(X) + CHARACTERS(C) +
|
||||||
|
// START_ELEMENT(Y) =>
|
||||||
|
// <X>SPACES<Y> => START TAG
|
||||||
|
ended = true;
|
||||||
|
result = new XMLTag(nameBuffer, TagType.START, attributesBuffer);
|
||||||
|
this.nextEvent = event;
|
||||||
|
break;
|
||||||
|
case XMLEvent.CHARACTERS:
|
||||||
|
// START_ELEMENT(X) + CHARACTERS(C1) +
|
||||||
|
// CHARACTERS(C2)=> ...
|
||||||
|
contentBuffer += event.asCharacters().getData();
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_ELEMENT:
|
||||||
|
// START_ELEMENT(X) + CHARACTERS(C) +
|
||||||
|
// END_ELEMENT(X) => <X>C</X>
|
||||||
|
// => CONTENT TAG
|
||||||
|
ended = true;
|
||||||
|
result = new XMLTag(nameBuffer, TagType.CONTENT, attributesBuffer);
|
||||||
|
result.setContent(contentBuffer);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new XMLBadFormatException("Unexpected XMLEvent [" + event.getEventType() + "].");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new XMLBadFormatException("Unexpected level [" + level + "].");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.debug("=> " + XMLTools.toString(result));
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param label
|
||||||
|
* @return
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
*/
|
||||||
|
public XMLTag readXMLFooter() throws XMLStreamException, XMLBadFormatException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
//
|
||||||
|
result = readTag();
|
||||||
|
|
||||||
|
//
|
||||||
|
if (result == null) {
|
||||||
|
throw new XMLBadFormatException("XML file ends prematurely, end document event is expected.");
|
||||||
|
} else if (result.getType() != TagType.FOOTER) {
|
||||||
|
throw new XMLBadFormatException("End document tag is missing.");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @throws XMLException
|
||||||
|
* @throws XMLStreamException
|
||||||
|
* @throws XMLBadFormatException
|
||||||
|
*/
|
||||||
|
public XMLTag readXMLHeader() throws XMLStreamException, XMLBadFormatException {
|
||||||
|
XMLTag result;
|
||||||
|
|
||||||
|
//
|
||||||
|
result = readTag();
|
||||||
|
|
||||||
|
//
|
||||||
|
//
|
||||||
|
if (result == null) {
|
||||||
|
throw new XMLBadFormatException("XML file ends prematurely, start document event is expected.");
|
||||||
|
} else if (result.getType() != TagType.HEADER) {
|
||||||
|
throw new XMLBadFormatException("XML header is missing.");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param args
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
public static void main(final String args[]) throws Exception {
|
||||||
|
|
||||||
|
XMLInputFactory factory = XMLInputFactory.newInstance();
|
||||||
|
XMLEventReader in = factory.createXMLEventReader(new FileReader("/home/cpm/C/Puck/Dev/Puck/test/TT/t3.puc"));
|
||||||
|
|
||||||
|
XMLEvent event;
|
||||||
|
while (in.hasNext()) {
|
||||||
|
event = in.nextEvent();
|
||||||
|
|
||||||
|
switch (event.getEventType()) {
|
||||||
|
case XMLEvent.ATTRIBUTE:
|
||||||
|
System.out.println("ATTRIBUTE ");
|
||||||
|
break;
|
||||||
|
case XMLEvent.CDATA:
|
||||||
|
System.out.println("CDATA");
|
||||||
|
break;
|
||||||
|
case XMLEvent.CHARACTERS:
|
||||||
|
System.out.println("CHARACTERS [" + event.asCharacters().getData() + "]");
|
||||||
|
break;
|
||||||
|
case XMLEvent.COMMENT:
|
||||||
|
System.out.println("COMMENT");
|
||||||
|
break;
|
||||||
|
case XMLEvent.DTD:
|
||||||
|
System.out.println("DTD");
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_DOCUMENT:
|
||||||
|
System.out.println("END_DOCUMENT");
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_ELEMENT:
|
||||||
|
System.out.println("END_ELEMENT " + event.asEndElement().getName());
|
||||||
|
break;
|
||||||
|
case XMLEvent.ENTITY_DECLARATION:
|
||||||
|
System.out.println("ENTITY_DECLARATION");
|
||||||
|
break;
|
||||||
|
case XMLEvent.ENTITY_REFERENCE:
|
||||||
|
System.out.println("ENTITY_REFERENCE");
|
||||||
|
break;
|
||||||
|
case XMLEvent.NAMESPACE:
|
||||||
|
System.out.println("NAMESPACE");
|
||||||
|
break;
|
||||||
|
case XMLEvent.NOTATION_DECLARATION:
|
||||||
|
System.out.println("NOTATION_DECLARATION");
|
||||||
|
break;
|
||||||
|
case XMLEvent.PROCESSING_INSTRUCTION:
|
||||||
|
System.out.println("PROCESSING_INSTRUCTION");
|
||||||
|
break;
|
||||||
|
case XMLEvent.SPACE:
|
||||||
|
System.out.println("SPACE");
|
||||||
|
break;
|
||||||
|
case XMLEvent.START_DOCUMENT:
|
||||||
|
System.out.println("START_DOCUMENT");
|
||||||
|
break;
|
||||||
|
case XMLEvent.START_ELEMENT:
|
||||||
|
System.out.println("START_ELEMENT [name=" + event.asStartElement().getName() + "][namespaceURI="
|
||||||
|
+ event.asStartElement().getName().getNamespaceURI() + "][prefix=" + event.asStartElement().getName().getPrefix() + "][localPart="
|
||||||
|
+ event.asStartElement().getName().getLocalPart() + "]");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
System.out.println("DEFAULT");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
117
src/fr/devinsy/util/xml/XMLTag.java
Normal file
117
src/fr/devinsy/util/xml/XMLTag.java
Normal file
|
@ -0,0 +1,117 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
import javax.xml.namespace.QName;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
@author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLTag {
|
||||||
|
|
||||||
|
public enum TagType {
|
||||||
|
HEADER,
|
||||||
|
START,
|
||||||
|
END,
|
||||||
|
EMPTY,
|
||||||
|
CONTENT,
|
||||||
|
FOOTER
|
||||||
|
}
|
||||||
|
|
||||||
|
private QName name;
|
||||||
|
private TagType type;
|
||||||
|
private XMLAttributes attributes;
|
||||||
|
private String content;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public XMLTag(final QName name, final TagType type, final XMLAttributes attributes) {
|
||||||
|
this.name = name;
|
||||||
|
this.type = type;
|
||||||
|
this.attributes = attributes;
|
||||||
|
this.content = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public XMLAttributes attributes() {
|
||||||
|
return this.attributes;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getContent() {
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getLabel() {
|
||||||
|
String result;
|
||||||
|
|
||||||
|
if (this.name == null) {
|
||||||
|
result = "";
|
||||||
|
} else {
|
||||||
|
result = this.name.getLocalPart();
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public QName getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getNamespaceURI() {
|
||||||
|
String result;
|
||||||
|
|
||||||
|
if (this.name == null) {
|
||||||
|
result = "";
|
||||||
|
} else {
|
||||||
|
result = this.name.getNamespaceURI();
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getPrefix() {
|
||||||
|
String result;
|
||||||
|
|
||||||
|
if (this.name == null) {
|
||||||
|
result = "";
|
||||||
|
} else {
|
||||||
|
result = this.name.getPrefix();
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public TagType getType() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setContent(final String content) {
|
||||||
|
this.content = content;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(final QName name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setType(final TagType type) {
|
||||||
|
this.type = type;
|
||||||
|
}
|
||||||
|
}
|
303
src/fr/devinsy/util/xml/XMLTools.java
Normal file
303
src/fr/devinsy/util/xml/XMLTools.java
Normal file
|
@ -0,0 +1,303 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
import java.util.zip.ZipInputStream;
|
||||||
|
|
||||||
|
import javax.xml.stream.events.XMLEvent;
|
||||||
|
import javax.xml.transform.sax.SAXSource;
|
||||||
|
import javax.xml.transform.stream.StreamSource;
|
||||||
|
import javax.xml.validation.Schema;
|
||||||
|
import javax.xml.validation.SchemaFactory;
|
||||||
|
import javax.xml.validation.Validator;
|
||||||
|
|
||||||
|
import org.xml.sax.InputSource;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLTools
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param source
|
||||||
|
* @throws SAXException
|
||||||
|
* @throws IOException
|
||||||
|
* @throws PuckException
|
||||||
|
*/
|
||||||
|
static public boolean isValid(final File xmlFile, final File xsdFile) throws SAXException, IOException
|
||||||
|
{
|
||||||
|
boolean result;
|
||||||
|
|
||||||
|
//
|
||||||
|
InputStream xmlSource;
|
||||||
|
if (isZipFile(xmlFile))
|
||||||
|
{
|
||||||
|
ZipInputStream zin = new ZipInputStream(new FileInputStream(xmlFile));
|
||||||
|
zin.getNextEntry();
|
||||||
|
xmlSource = zin;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xmlSource = new FileInputStream(xmlFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
result = isValid(xmlSource, new FileInputStream(xsdFile));
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param source
|
||||||
|
* @throws SAXException
|
||||||
|
* @throws IOException
|
||||||
|
* @throws PuckException
|
||||||
|
*/
|
||||||
|
static public boolean isValid(final File xmlFile, final InputStream xsdSource) throws SAXException, IOException
|
||||||
|
{
|
||||||
|
boolean result;
|
||||||
|
|
||||||
|
//
|
||||||
|
InputStream xmlSource;
|
||||||
|
if (isZipFile(xmlFile))
|
||||||
|
{
|
||||||
|
ZipInputStream zin = new ZipInputStream(new FileInputStream(xmlFile));
|
||||||
|
zin.getNextEntry();
|
||||||
|
xmlSource = zin;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xmlSource = new FileInputStream(xmlFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
result = isValid(xmlSource, xsdSource);
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param source
|
||||||
|
* @throws SAXException
|
||||||
|
* @throws IOException
|
||||||
|
* @throws PuckException
|
||||||
|
*/
|
||||||
|
static public boolean isValid(final InputStream xmlSource, final InputStream xsdSource) throws SAXException, IOException
|
||||||
|
{
|
||||||
|
boolean result;
|
||||||
|
|
||||||
|
if (xmlSource == null)
|
||||||
|
{
|
||||||
|
result = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
//
|
||||||
|
SchemaFactory factory = SchemaFactory.newInstance("http://www.w3.org/2001/XMLSchema");
|
||||||
|
InputSource sourceentree = new InputSource(xsdSource);
|
||||||
|
SAXSource sourceXSD = new SAXSource(sourceentree);
|
||||||
|
Schema schema = factory.newSchema(sourceXSD);
|
||||||
|
Validator validator = schema.newValidator();
|
||||||
|
|
||||||
|
//
|
||||||
|
validator.validate(new StreamSource(xmlSource));
|
||||||
|
result = true;
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (final IllegalArgumentException exception)
|
||||||
|
{
|
||||||
|
exception.printStackTrace();
|
||||||
|
result = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* @return
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public static boolean isZipFile(final File file) throws IOException
|
||||||
|
{
|
||||||
|
boolean result;
|
||||||
|
|
||||||
|
//
|
||||||
|
byte[] buffer = new byte[4];
|
||||||
|
FileInputStream is = null;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
is = new FileInputStream(file);
|
||||||
|
is.read(buffer);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if (is != null)
|
||||||
|
{
|
||||||
|
is.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 50 4B 3 4
|
||||||
|
if ((buffer[0] == 0x50) && (buffer[1] == 0x4B) && (buffer[2] == 0x03) && (buffer[3] == 0x04))
|
||||||
|
{
|
||||||
|
result = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
static public String readTag(final BufferedReader in) throws Exception
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
Pattern TAG_PATTERN = Pattern.compile("^<([\\w-_\\.]+)>.*</([\\w-_\\.]+)>$");
|
||||||
|
Pattern SHORT_TAG_PATTERN = Pattern.compile("^<.+/>$");
|
||||||
|
|
||||||
|
result = in.readLine();
|
||||||
|
boolean ended = false;
|
||||||
|
while (!ended)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* DEBUG Matcher tagMatcher2 = TAG_PATTERN.matcher(result); if
|
||||||
|
* (tagMatcher2.find()) { logger.info("group count,0,1,2 = [" +
|
||||||
|
* tagMatcher2.groupCount() + "][" + tagMatcher2.group(0) + "][" +
|
||||||
|
* tagMatcher2.group(1) + "][" + tagMatcher2.group(2) + "]"); }
|
||||||
|
*/
|
||||||
|
|
||||||
|
Matcher tagMatcher = TAG_PATTERN.matcher(result);
|
||||||
|
Matcher shortTagMatcher = SHORT_TAG_PATTERN.matcher(result);
|
||||||
|
|
||||||
|
if ((tagMatcher.find()) && (tagMatcher.groupCount() == 2) && (tagMatcher.group(1).equals(tagMatcher.group(2))))
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
}
|
||||||
|
else if (shortTagMatcher.matches())
|
||||||
|
{
|
||||||
|
ended = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result += in.readLine();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return (result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param value
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static String toString(final XMLEvent source)
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
switch (source.getEventType())
|
||||||
|
{
|
||||||
|
case XMLEvent.ATTRIBUTE:
|
||||||
|
result = "ATTRIBUTE ";
|
||||||
|
break;
|
||||||
|
case XMLEvent.CDATA:
|
||||||
|
result = "CDATA";
|
||||||
|
break;
|
||||||
|
case XMLEvent.CHARACTERS:
|
||||||
|
result = "CHARACTERS [" + source.asCharacters().getData() + "]";
|
||||||
|
break;
|
||||||
|
case XMLEvent.COMMENT:
|
||||||
|
result = "COMMENT";
|
||||||
|
break;
|
||||||
|
case XMLEvent.DTD:
|
||||||
|
result = "DTD";
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_DOCUMENT:
|
||||||
|
result = "END_DOCUMENT";
|
||||||
|
break;
|
||||||
|
case XMLEvent.END_ELEMENT:
|
||||||
|
result = "END_ELEMENT " + source.asEndElement().getName();
|
||||||
|
break;
|
||||||
|
case XMLEvent.ENTITY_DECLARATION:
|
||||||
|
result = "ENTITY_DECLARATION";
|
||||||
|
break;
|
||||||
|
case XMLEvent.ENTITY_REFERENCE:
|
||||||
|
result = "ENTITY_REFERENCE";
|
||||||
|
break;
|
||||||
|
case XMLEvent.NAMESPACE:
|
||||||
|
result = "NAMESPACE";
|
||||||
|
break;
|
||||||
|
case XMLEvent.NOTATION_DECLARATION:
|
||||||
|
result = "NOTATION_DECLARATION";
|
||||||
|
break;
|
||||||
|
case XMLEvent.PROCESSING_INSTRUCTION:
|
||||||
|
result = "PROCESSING_INSTRUCTION";
|
||||||
|
break;
|
||||||
|
case XMLEvent.SPACE:
|
||||||
|
result = "SPACE";
|
||||||
|
break;
|
||||||
|
case XMLEvent.START_DOCUMENT:
|
||||||
|
result = "START_DOCUMENT";
|
||||||
|
break;
|
||||||
|
case XMLEvent.START_ELEMENT:
|
||||||
|
result = "START_ELEMENT [name=" + source.asStartElement().getName() + "][namespaceURI=" + source.asStartElement().getName().getNamespaceURI() + "][prefix="
|
||||||
|
+ source.asStartElement().getName().getPrefix() + "][localPart=" + source.asStartElement().getName().getLocalPart() + "]";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param event
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static String toString(final XMLTag source)
|
||||||
|
{
|
||||||
|
String result;
|
||||||
|
|
||||||
|
if (source == null)
|
||||||
|
{
|
||||||
|
result = "null";
|
||||||
|
}
|
||||||
|
result = "[label=" + source.getLabel() + "][type=" + source.getType().toString() + "][content=" + source.getContent() + "]";
|
||||||
|
|
||||||
|
//
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
209
src/fr/devinsy/util/xml/XMLWriter.java
Normal file
209
src/fr/devinsy/util/xml/XMLWriter.java
Normal file
|
@ -0,0 +1,209 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.OutputStreamWriter;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
|
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLWriter {
|
||||||
|
|
||||||
|
protected PrintWriter out;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
protected XMLWriter() {
|
||||||
|
this.out = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* @throws FileNotFoundException
|
||||||
|
* @throws UnsupportedEncodingException
|
||||||
|
*/
|
||||||
|
public XMLWriter(final File file) throws UnsupportedEncodingException, FileNotFoundException {
|
||||||
|
this.out = new PrintWriter(new OutputStreamWriter(new FileOutputStream(file), "UTF-8"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param target
|
||||||
|
* @throws UnsupportedEncodingException
|
||||||
|
*/
|
||||||
|
public XMLWriter(final OutputStream target) throws UnsupportedEncodingException {
|
||||||
|
this.out = new PrintWriter(new OutputStreamWriter(target, "UTF-8"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void close() {
|
||||||
|
if (this.out != null) {
|
||||||
|
this.out.flush();
|
||||||
|
this.out.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void flush() {
|
||||||
|
if (this.out != null) {
|
||||||
|
this.out.flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param comment
|
||||||
|
*/
|
||||||
|
public void writeComment(final String comment) {
|
||||||
|
out.print("<!-- ");
|
||||||
|
if (comment != null) {
|
||||||
|
writeTagContent(comment);
|
||||||
|
}
|
||||||
|
out.print(" -->");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeEmptyTag(final String label, final String... attributes) {
|
||||||
|
out.print("<");
|
||||||
|
out.print(label);
|
||||||
|
writeTagAttributes(attributes);
|
||||||
|
out.print("/>");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeEndTag(final String label) {
|
||||||
|
out.print("</");
|
||||||
|
out.print(label);
|
||||||
|
out.print(">");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeStartTag(final String label, final String... attributes) {
|
||||||
|
out.print("<");
|
||||||
|
out.print(label);
|
||||||
|
writeTagAttributes(attributes);
|
||||||
|
out.print(">");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeTag(final String label, final String content, final String... attributes) {
|
||||||
|
|
||||||
|
if (content == null) {
|
||||||
|
writeEmptyTag(label, attributes);
|
||||||
|
} else {
|
||||||
|
writeStartTag(label, attributes);
|
||||||
|
writeTagContent(content);
|
||||||
|
writeEndTag(label);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeTagAttributes(final String... attributes) {
|
||||||
|
//
|
||||||
|
if ((attributes != null) && (attributes.length > 0)) {
|
||||||
|
for (int count = 0; count < attributes.length; count += 2) {
|
||||||
|
out.print(" ");
|
||||||
|
out.print(attributes[count]);
|
||||||
|
out.print("=\"");
|
||||||
|
out.print(attributes[count + 1]);
|
||||||
|
out.print("\"");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeTagContent(final String content) {
|
||||||
|
//
|
||||||
|
for (int count = 0; count < content.length(); count++) {
|
||||||
|
//
|
||||||
|
char car = content.charAt(count);
|
||||||
|
|
||||||
|
switch (car) {
|
||||||
|
case '<':
|
||||||
|
out.print("<");
|
||||||
|
break;
|
||||||
|
case '>':
|
||||||
|
out.print(">");
|
||||||
|
break;
|
||||||
|
case '&':
|
||||||
|
out.print("&");
|
||||||
|
break;
|
||||||
|
case '"':
|
||||||
|
out.print(""");
|
||||||
|
break;
|
||||||
|
case '\'':
|
||||||
|
out.print("'");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
out.print(car);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public void writeXMLHeader(final String... attributes) {
|
||||||
|
|
||||||
|
//
|
||||||
|
out.print("<?xml");
|
||||||
|
|
||||||
|
//
|
||||||
|
if (!ArrayUtils.contains(attributes, "version")) {
|
||||||
|
out.print(" version=\"1.0\"");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
if (!ArrayUtils.contains(attributes, "encoding")) {
|
||||||
|
out.print(" encoding=\"UTF-8\"");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
if (!ArrayUtils.contains(attributes, "encoding")) {
|
||||||
|
out.print(" standalone=\"no\"");
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
if (attributes != null) {
|
||||||
|
//
|
||||||
|
for (int count = 0; count < attributes.length; count += 2) {
|
||||||
|
out.print(" ");
|
||||||
|
out.print(attributes[count]);
|
||||||
|
out.print("=\"");
|
||||||
|
out.print(attributes[count + 1]);
|
||||||
|
out.print("\"");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
out.print(" ?>");
|
||||||
|
}
|
||||||
|
}
|
51
src/fr/devinsy/util/xml/XMLZipReader.java
Normal file
51
src/fr/devinsy/util/xml/XMLZipReader.java
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.zip.ZipInputStream;
|
||||||
|
|
||||||
|
import javax.xml.stream.XMLInputFactory;
|
||||||
|
import javax.xml.stream.XMLStreamException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
@author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLZipReader extends XMLReader {
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* @throws IOException
|
||||||
|
* @throws XMLStreamException
|
||||||
|
*/
|
||||||
|
public XMLZipReader(final File file) throws IOException, XMLStreamException {
|
||||||
|
super();
|
||||||
|
|
||||||
|
XMLInputFactory factory = XMLInputFactory.newInstance();
|
||||||
|
ZipInputStream zis = new ZipInputStream(new FileInputStream(file));
|
||||||
|
zis.getNextEntry();
|
||||||
|
this.in = factory.createXMLEventReader(zis, "UTF-8");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param target
|
||||||
|
* @throws IOException
|
||||||
|
* @throws XMLStreamException
|
||||||
|
*/
|
||||||
|
public XMLZipReader(final InputStream source) throws IOException, XMLStreamException {
|
||||||
|
super();
|
||||||
|
|
||||||
|
XMLInputFactory factory = XMLInputFactory.newInstance();
|
||||||
|
ZipInputStream zis = new ZipInputStream(source);
|
||||||
|
zis.getNextEntry();
|
||||||
|
this.in = factory.createXMLEventReader(zis, "UTF-8");
|
||||||
|
}
|
||||||
|
}
|
52
src/fr/devinsy/util/xml/XMLZipWriter.java
Normal file
52
src/fr/devinsy/util/xml/XMLZipWriter.java
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
package fr.devinsy.util.xml;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.OutputStreamWriter;
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.util.zip.Deflater;
|
||||||
|
import java.util.zip.ZipEntry;
|
||||||
|
import java.util.zip.ZipOutputStream;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
@author christian.momon@devinsy.fr, 2013, copyright.
|
||||||
|
*
|
||||||
|
* This file is free software under the terms of the GNU Library General
|
||||||
|
* Public License as published by the Free Software Foundation version 3
|
||||||
|
* or any later version.
|
||||||
|
*/
|
||||||
|
public class XMLZipWriter extends XMLWriter {
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param file
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public XMLZipWriter(final File file) throws IOException {
|
||||||
|
super();
|
||||||
|
|
||||||
|
ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(file));
|
||||||
|
zos.setLevel(Deflater.BEST_COMPRESSION);
|
||||||
|
zos.setMethod(ZipOutputStream.DEFLATED);
|
||||||
|
zos.setComment("Generated by PUCK");
|
||||||
|
zos.putNextEntry(new ZipEntry(file.getName() + ".xml"));
|
||||||
|
this.out = new PrintWriter(new OutputStreamWriter(zos, "UTF-8"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param target
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public XMLZipWriter(final OutputStream target) throws IOException {
|
||||||
|
super();
|
||||||
|
ZipOutputStream zos = new ZipOutputStream(target);
|
||||||
|
zos.setLevel(Deflater.BEST_COMPRESSION);
|
||||||
|
zos.setMethod(ZipOutputStream.DEFLATED);
|
||||||
|
zos.putNextEntry(new ZipEntry("noname"));
|
||||||
|
this.out = new PrintWriter(new OutputStreamWriter(zos, "UTF-8"));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue