org.teamapps.universaldb.index.translation.TranslatableText Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of universal-db Show documentation
Show all versions of universal-db Show documentation
Ultra fast TeamApps database
/*-
* ========================LICENSE_START=================================
* UniversalDB
* ---
* Copyright (C) 2014 - 2021 TeamApps.org
* ---
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* =========================LICENSE_END==================================
*/
package org.teamapps.universaldb.index.translation;
import org.teamapps.universaldb.util.DataStreamUtil;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.util.*;
public class TranslatableText {
private final static String DELIMITER = "\n<=@#!=>\n";
public static boolean REPAIR_ENCODED_TEXTS = false;
private String originalText;
private String originalLanguage;
private String encodedValue;
private Map translationMap;
public static boolean isTranslatableText(String encodedValue) {
if (encodedValue == null || (encodedValue.startsWith(DELIMITER) && encodedValue.endsWith(DELIMITER))) {
return true;
} else {
return false;
}
}
public static TranslatableText create(String originalText, String originalLanguage) {
return new TranslatableText(originalText, originalLanguage);
}
public TranslatableText() {
}
public TranslatableText(String originalText, String originalLanguage) {
this.originalText = originalText;
this.originalLanguage = originalLanguage;
this.translationMap = new HashMap<>();
translationMap.put(originalLanguage, originalText);
}
public TranslatableText(String encodedValue) {
if (!isTranslatableText(encodedValue)) {
if (REPAIR_ENCODED_TEXTS) {
StringBuilder sb = new StringBuilder();
sb.append(DELIMITER).append("en").append(":").append(encodedValue).append(DELIMITER);;
encodedValue = sb.toString();
} else {
throw new RuntimeException("Error: invalid translation encoding:" + encodedValue);
}
}
this.encodedValue = encodedValue;
}
public TranslatableText(DataInputStream dataInputStream) throws IOException {
encodedValue = DataStreamUtil.readStringWithLengthHeader(dataInputStream);
}
public TranslatableText(String originalText, String originalLanguage, Map translationMap) {
if (translationMap.keySet().stream().anyMatch(s -> s.length() != 2)) {
throw new RuntimeException("Error: invalid translation map");
}
this.originalText = originalText;
this.originalLanguage = originalLanguage;
this.translationMap = translationMap;
}
public String getText() {
if (originalText == null) {
parseOriginalValue();
}
return originalText;
}
@Override
public String toString() {
return getText();
}
public String getOriginalLanguage() {
if (originalLanguage == null) {
parseOriginalValue();
}
return originalLanguage;
}
public String getText(String language) {
String translation = getTranslation(language);
return translation != null ? translation : getText();
}
public String getText(List rankedLanguages) {
String translation = getTranslation(rankedLanguages);
return translation != null ? translation : getText();
}
public String getTranslation(String language) {
if (translationMap != null) {
if (language.equals(originalLanguage)) {
return originalText;
}
return translationMap.get(language);
} else {
return translationLookup(language);
}
}
public String getTranslation(List rankedLanguages) {
for (String language : rankedLanguages) {
String translation = getTranslation(language);
if (translation != null) {
return translation;
}
}
return null;
}
public TranslatableText setTranslation(String translation, String language) {
if (translation == null || translation.isEmpty() || language == null || language.length() != 2) {
return this;
}
getTranslationMap().put(language, translation);
return this;
}
public String translationLookup(String language) {
return findTranslation(language);
}
public String getEncodedValue() {
if (translationMap != null || originalText != null) {
return createTranslationValue(originalText, originalLanguage, translationMap);
} else {
return encodedValue;
}
}
private void parseOriginalValue() {
if (encodedValue == null) {
return;
}
int pos = -1;
if((pos = encodedValue.indexOf(DELIMITER, pos + 1)) >= 0 && pos < encodedValue.length() - DELIMITER.length()) {
int end = encodedValue.indexOf(DELIMITER, pos + 1);
if (end > pos) {
originalLanguage = encodedValue.substring(pos + DELIMITER.length(), pos + DELIMITER.length() + 2);
originalText = encodedValue.substring(pos + DELIMITER.length() + 3, end);
}
}
}
private String findTranslation( String language) {
if (encodedValue == null || language == null || language.length() != 2) {
return null;
}
if (language.equalsIgnoreCase(originalLanguage)) {
return originalText;
}
int pos = -1;
char a = language.charAt(0);
char b = language.charAt(1);
while((pos = encodedValue.indexOf(DELIMITER, pos + 1)) >= 0 && pos < encodedValue.length() - DELIMITER.length()) {
if (encodedValue.charAt(pos + DELIMITER.length()) == a && encodedValue.charAt(pos + DELIMITER.length() + 1) == b) {
int end = encodedValue.indexOf(DELIMITER, pos + 1);
if (end > pos) {
return encodedValue.substring(pos + DELIMITER.length() + 3, end);
}
}
}
return null;
}
public void writeValues(DataOutputStream dataOutputStream) throws IOException {
String encodedValue = getEncodedValue();
DataStreamUtil.writeStringWithLengthHeader(dataOutputStream, encodedValue);
}
public Map getTranslationMap() {
if (translationMap != null) {
return translationMap;
} else {
translationMap = encodedValue != null ? parseEncodedTranslation(encodedValue) : new HashMap<>();
return translationMap;
}
}
private Map parseEncodedTranslation(String text) {
Map map = new HashMap<>();
int pos = -1;
while((pos = text.indexOf(DELIMITER, pos + 1)) >= 0 && pos < text.length() - DELIMITER.length()) {
int end = text.indexOf(DELIMITER, pos + 1);
if (end > pos) {
String language = text.substring(pos + DELIMITER.length(), pos + DELIMITER.length() + 2);
String value = text.substring(pos + DELIMITER.length() + 3, end);
map.put(language, value);
pos = end - 1;
}
}
return map;
}
private static String createTranslationValue(String originalText, String originalLanguage, Map translationsByLanguage) {
StringBuilder sb = new StringBuilder();
if (originalText != null && originalLanguage != null) {
sb.append(DELIMITER).append(originalLanguage).append(":").append(originalText);
}
if (translationsByLanguage != null) {
for (Map.Entry entry : translationsByLanguage.entrySet()) {
sb.append(DELIMITER).append(entry.getKey()).append(":").append(entry.getValue());
}
}
sb.append(DELIMITER);
return sb.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy