mirror of
https://github.com/revanced/Apktool.git
synced 2025-05-01 06:34:25 +02:00
AndrolibResources: cut escapeForResXml() to escapeCharsForResXml() and escapeTextForResXml().
StringBlock.getHTML() now properly escapes strings.
This commit is contained in:
parent
c781281e1c
commit
2ef8d48d96
@ -470,11 +470,20 @@ final public class AndrolibResources {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String escapeForResXml(String value) {
|
public static String escapeTextForResXml(String value) {
|
||||||
|
return escapeTextForResXml(value, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String escapeTextForResXml(String value,
|
||||||
|
boolean escapeChars) {
|
||||||
if (value.isEmpty()) {
|
if (value.isEmpty()) {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (escapeChars) {
|
||||||
|
value = escapeCharsForResXml(value);
|
||||||
|
}
|
||||||
|
|
||||||
StringBuilder out = new StringBuilder(value.length() + 10);
|
StringBuilder out = new StringBuilder(value.length() + 10);
|
||||||
char[] chars = value.toCharArray();
|
char[] chars = value.toCharArray();
|
||||||
|
|
||||||
@ -486,9 +495,7 @@ final public class AndrolibResources {
|
|||||||
}
|
}
|
||||||
|
|
||||||
boolean space = true;
|
boolean space = true;
|
||||||
for (int i = 0; i < chars.length; i++) {
|
for (char c : chars) {
|
||||||
char c = chars[i];
|
|
||||||
|
|
||||||
if (c == ' ') {
|
if (c == ' ') {
|
||||||
if (space) {
|
if (space) {
|
||||||
out.append("\\u0020");
|
out.append("\\u0020");
|
||||||
@ -500,16 +507,6 @@ final public class AndrolibResources {
|
|||||||
}
|
}
|
||||||
|
|
||||||
space = false;
|
space = false;
|
||||||
switch (c) {
|
|
||||||
case '\\':
|
|
||||||
case '\'':
|
|
||||||
case '"':
|
|
||||||
out.append('\\');
|
|
||||||
break;
|
|
||||||
case '\n':
|
|
||||||
out.append("\\n");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
out.append(c);
|
out.append(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -521,6 +518,35 @@ final public class AndrolibResources {
|
|||||||
return out.toString();
|
return out.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static String escapeCharsForResXml(String value) {
|
||||||
|
if (value.isEmpty()) {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
StringBuilder out = new StringBuilder(value.length() + 10);
|
||||||
|
for (char c : value.toCharArray()) {
|
||||||
|
switch (c) {
|
||||||
|
case '\\':
|
||||||
|
case '\'':
|
||||||
|
case '"':
|
||||||
|
out.append('\\');
|
||||||
|
break;
|
||||||
|
case '\n':
|
||||||
|
out.append("\\n");
|
||||||
|
continue;
|
||||||
|
case '&':
|
||||||
|
out.append("&");
|
||||||
|
continue;
|
||||||
|
case '<':
|
||||||
|
out.append("<");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
out.append(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
return out.toString();
|
||||||
|
}
|
||||||
|
|
||||||
private final static Logger LOGGER =
|
private final static Logger LOGGER =
|
||||||
Logger.getLogger(AndrolibResources.class.getName());
|
Logger.getLogger(AndrolibResources.class.getName());
|
||||||
}
|
}
|
||||||
|
@ -301,7 +301,7 @@ public class AXmlResourceParser implements XmlResourceParser {
|
|||||||
int valueType = m_attributes[offset + ATTRIBUTE_IX_VALUE_TYPE];
|
int valueType = m_attributes[offset + ATTRIBUTE_IX_VALUE_TYPE];
|
||||||
if (valueType == TypedValue.TYPE_STRING) {
|
if (valueType == TypedValue.TYPE_STRING) {
|
||||||
int valueString = m_attributes[offset + ATTRIBUTE_IX_VALUE_STRING];
|
int valueString = m_attributes[offset + ATTRIBUTE_IX_VALUE_STRING];
|
||||||
return AndrolibResources.escapeForResXml(
|
return AndrolibResources.escapeTextForResXml(
|
||||||
m_strings.getString(valueString));
|
m_strings.getString(valueString));
|
||||||
}
|
}
|
||||||
int valueData = m_attributes[offset + ATTRIBUTE_IX_VALUE_DATA];
|
int valueData = m_attributes[offset + ATTRIBUTE_IX_VALUE_DATA];
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
*/
|
*/
|
||||||
package brut.androlib.res.decoder;
|
package brut.androlib.res.decoder;
|
||||||
|
|
||||||
|
import brut.androlib.res.AndrolibResources;
|
||||||
import brut.util.ExtDataInput;
|
import brut.util.ExtDataInput;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
@ -125,7 +126,7 @@ public class StringBlock {
|
|||||||
}
|
}
|
||||||
int[] style = getStyle(index);
|
int[] style = getStyle(index);
|
||||||
if (style == null) {
|
if (style == null) {
|
||||||
return escapeForXml(raw);
|
return AndrolibResources.escapeTextForResXml(raw);
|
||||||
}
|
}
|
||||||
StringBuilder html = new StringBuilder(raw.length() + 32);
|
StringBuilder html = new StringBuilder(raw.length() + 32);
|
||||||
int[] opened = new int[style.length / 3];
|
int[] opened = new int[style.length / 3];
|
||||||
@ -148,7 +149,8 @@ public class StringBlock {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (offset <= end) {
|
if (offset <= end) {
|
||||||
html.append(escapeForXml(raw.substring(offset, end + 1)));
|
html.append(AndrolibResources.escapeCharsForResXml(
|
||||||
|
raw.substring(offset, end + 1)));
|
||||||
offset = end + 1;
|
offset = end + 1;
|
||||||
}
|
}
|
||||||
html.append('<');
|
html.append('<');
|
||||||
@ -158,7 +160,8 @@ public class StringBlock {
|
|||||||
}
|
}
|
||||||
depth = j + 1;
|
depth = j + 1;
|
||||||
if (offset < start) {
|
if (offset < start) {
|
||||||
html.append(escapeForXml(raw.substring(offset, start)));
|
html.append(AndrolibResources.escapeCharsForResXml(
|
||||||
|
raw.substring(offset, start)));
|
||||||
offset = start;
|
offset = start;
|
||||||
}
|
}
|
||||||
if (i == -1) {
|
if (i == -1) {
|
||||||
@ -170,11 +173,7 @@ public class StringBlock {
|
|||||||
style[i + 1] = -1;
|
style[i + 1] = -1;
|
||||||
opened[depth++] = i;
|
opened[depth++] = i;
|
||||||
}
|
}
|
||||||
return html.toString();
|
return AndrolibResources.escapeTextForResXml(html.toString(), false);
|
||||||
}
|
|
||||||
|
|
||||||
private String escapeForXml(String txt) {
|
|
||||||
return txt.replace("&", "&").replace("<", "<");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user