optimize line breaks and value parsing
This commit is contained in:
parent
02d7d7d051
commit
045bb6ac94
@ -52,9 +52,8 @@ public class PropertiesParserStrategy extends ParserStrategy {
|
|||||||
PropertiesMapper.write(file.getLocale(), output, targetData, converter);
|
PropertiesMapper.write(file.getLocale(), output, targetData, converter);
|
||||||
|
|
||||||
try(StringWriter writer = new StringWriter()) {
|
try(StringWriter writer = new StringWriter()) {
|
||||||
output.store(writer, null);
|
output.store(writer);
|
||||||
// Current implementation only works with \n line separators (IntelliJ Document Formatting)
|
return writer.toString();
|
||||||
return writer.toString().replaceAll("\r\n", "\n");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,12 @@
|
|||||||
package de.marhali.easyi18n.io.parser.properties;
|
package de.marhali.easyi18n.io.parser.properties;
|
||||||
|
|
||||||
|
import de.marhali.easyi18n.util.IntelliJBufferedWriter;
|
||||||
|
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.Writer;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -38,6 +45,95 @@ public class SortableProperties extends Properties {
|
|||||||
return this.properties.put(key, value);
|
return this.properties.put(key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Deprecated
|
||||||
|
public void store(OutputStream out, @Nullable String comments) throws IOException {
|
||||||
|
throw new UnsupportedOperationException("Not implemented");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Deprecated
|
||||||
|
public void store(Writer writer, String comments) throws IOException {
|
||||||
|
throw new UnsupportedOperationException("Not implemented");
|
||||||
|
}
|
||||||
|
|
||||||
|
public void store(Writer writer) throws IOException {
|
||||||
|
IntelliJBufferedWriter bw = new IntelliJBufferedWriter(writer);
|
||||||
|
boolean escUnicode = false;
|
||||||
|
|
||||||
|
synchronized (this) {
|
||||||
|
for (Map.Entry<Object, Object> e : entrySet()) {
|
||||||
|
String key = String.valueOf(e.getKey());
|
||||||
|
String val = String.valueOf(e.getValue());
|
||||||
|
key = saveConvert(key, true, escUnicode);
|
||||||
|
/* No need to escape embedded and trailing spaces for value, hence
|
||||||
|
* pass false to flag.
|
||||||
|
*/
|
||||||
|
val = saveConvert(val, false, escUnicode);
|
||||||
|
bw.write(key + "=" + val);
|
||||||
|
bw.newLine();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
bw.flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Converts unicodes to encoded \uxxxx and escapes
|
||||||
|
* special characters with a preceding slash
|
||||||
|
*/
|
||||||
|
private String saveConvert(String theString,
|
||||||
|
boolean escapeSpace,
|
||||||
|
boolean escapeUnicode) {
|
||||||
|
int len = theString.length();
|
||||||
|
int bufLen = len * 2;
|
||||||
|
if (bufLen < 0) {
|
||||||
|
bufLen = Integer.MAX_VALUE;
|
||||||
|
}
|
||||||
|
StringBuilder outBuffer = new StringBuilder(bufLen);
|
||||||
|
for(int x=0; x<len; x++) {
|
||||||
|
char aChar = theString.charAt(x);
|
||||||
|
// Handle common case first, selecting largest block that
|
||||||
|
// avoids the specials below
|
||||||
|
if ((aChar > 61) && (aChar < 127)) {
|
||||||
|
if (aChar == '\\') {
|
||||||
|
outBuffer.append('\\'); outBuffer.append('\\');
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
outBuffer.append(aChar);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
switch(aChar) {
|
||||||
|
case ' ':
|
||||||
|
if (x == 0 || escapeSpace)
|
||||||
|
outBuffer.append('\\');
|
||||||
|
outBuffer.append(' ');
|
||||||
|
break;
|
||||||
|
case '\t':outBuffer.append('\\'); outBuffer.append('t');
|
||||||
|
break;
|
||||||
|
case '\n':outBuffer.append('\\'); outBuffer.append('n');
|
||||||
|
break;
|
||||||
|
case '\r':outBuffer.append('\\'); outBuffer.append('r');
|
||||||
|
break;
|
||||||
|
case '\f':outBuffer.append('\\'); outBuffer.append('f');
|
||||||
|
break;
|
||||||
|
case '=': // Fall through
|
||||||
|
case ':': // Fall through
|
||||||
|
case '#': // Fall through
|
||||||
|
case '!':
|
||||||
|
outBuffer.append('\\'); outBuffer.append(aChar);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if (((aChar < 0x0020) || (aChar > 0x007e)) & escapeUnicode ) {
|
||||||
|
outBuffer.append("\\u");
|
||||||
|
outBuffer.append(Integer.toHexString(aChar));
|
||||||
|
} else {
|
||||||
|
outBuffer.append(aChar);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return outBuffer.toString();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized String toString() {
|
public synchronized String toString() {
|
||||||
return this.properties.toString();
|
return this.properties.toString();
|
||||||
|
@ -0,0 +1,27 @@
|
|||||||
|
package de.marhali.easyi18n.util;
|
||||||
|
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.Writer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IntelliJ aware BufferedWriter implementation.
|
||||||
|
* (Document PSI uses \n as line separator)
|
||||||
|
* @author marhali
|
||||||
|
*/
|
||||||
|
public class IntelliJBufferedWriter extends BufferedWriter {
|
||||||
|
public IntelliJBufferedWriter(@NotNull Writer out) {
|
||||||
|
super(out);
|
||||||
|
}
|
||||||
|
|
||||||
|
public IntelliJBufferedWriter(@NotNull Writer out, int sz) {
|
||||||
|
super(out, sz);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void newLine() throws IOException {
|
||||||
|
write("\n");
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user