Package com.iizix.translate
Class TranslationEngine
java.lang.Object
com.iizix.translate.TranslationEngine
- All Implemented Interfaces:
ITranslationEngine
- Direct Known Subclasses:
EditorTranslationEngine
,TestEngine
The translation engine: two current translators are provided: Google and Microsoft, but the interface allows others. This engine is built to provide support to use multiple translators in parallel, with its own language capabilities and this engine would select the most suitable one to use.
- Author:
- Christopher Mindus
Field Summary
Modifier and TypeFieldDescriptionstatic boolean
Debug mode.static final Charset
Always UTF-8 encoded.static final String
The "UTF-8" string.Fields inherited from interface com.iizix.translate.ITranslationEngine
REQTYPE_POST, REQTYPE_POST_OVERRIDES_GET
Constructor Summary
ModifierConstructorDescriptionprotected
Constructor.protected
TranslationEngine
(boolean recreate) Constructor.Method Summary
Modifier and TypeMethodDescriptionvoid
cancel()
Cancels pending or running translation job.boolean
canTranslate
(String sourceLanguageCode, String targetLanguageCode) Checks if a translation is handled between two language codes.protected void
Clears the language queue after reconfiguration.static ITranslationEngine
Gets the translation engine instance.Gets the translation queues.protected abstract TranslationQueue
newTranslationQueue
(String sourceLanguageCode, String targetLanguageCode, ITranslator translator) Creates a new TranslationQueue instance.Requests a function using HTTPS POST, configured for proxy as specified in Eclipse or the Server.Requests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.requestJSON
(String httpRequest, Map<String, String> params, Map<String, String> headers, int type, int sizeLimit) Requests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.requestString
(String httpRequest, String params, Map<String, String> headers, int type, int sizeLimit) Requests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.requestString
(String httpRequest, Map<String, String> params, Map<String, String> headers, int type, int sizeLimit) Requests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.boolean
translate
(KString sourceText, String sourceLanguageCode, String targetLanguageCode, ITranslationReply replyCallback) Translates a text in plain text or HTML.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.iizix.translate.ITranslationEngine
configureProxy, getProxy, getReadyState, getTranslator, isLanguageHandled
Field Details
ENCODING
Always UTF-8 encoded.ENCODING_NAME
The "UTF-8" string.DEBUG
public static boolean DEBUGDebug mode.
Constructor Details
TranslationEngine
protected TranslationEngine()Constructor.- Throws:
InternalError
- if the engine is already instantiated.
TranslationEngine
protected TranslationEngine(boolean recreate) Constructor.- Throws:
InternalError
- if the engine is already instantiated.
Method Details
getInstance
Gets the translation engine instance.- Returns:
- The engine.
- Throws:
NullPointerException
- If the engine is not created yet.
getQueues
Gets the translation queues.- Specified by:
getQueues
in interfaceITranslationEngine
- Returns:
- The array of translation queues.
clearLanguageQueue
protected void clearLanguageQueue()Clears the language queue after reconfiguration.canTranslate
Checks if a translation is handled between two language codes.- Specified by:
canTranslate
in interfaceITranslationEngine
- Parameters:
sourceLanguageCode
- The source language code, null for automatic detection.targetLanguageCode
- The target language code.- Returns:
- true if supported, false if not.
cancel
public void cancel()Cancels pending or running translation job.- Specified by:
cancel
in interfaceITranslationEngine
translate
public boolean translate(KString sourceText, String sourceLanguageCode, String targetLanguageCode, ITranslationReply replyCallback) Translates a text in plain text or HTML.- Specified by:
translate
in interfaceITranslationEngine
- Parameters:
sourceText
- The source text to translate.sourceLanguageCode
- The source language code, null for automatic detection.targetLanguageCode
- The target language code.replyCallback
- Callback when translation completes.- Returns:
- true for success, false for failure (error is logged).
- Throws:
NullPointerException
- If sourceText, targetLanguageCode or replyCallback is null.
newTranslationQueue
protected abstract TranslationQueue newTranslationQueue(String sourceLanguageCode, String targetLanguageCode, ITranslator translator) Creates a new TranslationQueue instance.- Parameters:
sourceLanguageCode
- The source language code, null for auto-detect.targetLanguageCode
- The target language code.translator
- The translator.
requestJSON
public JSONObject requestJSON(String httpRequest, Map<String, String> params, Map<String, throws IOException, JSONExceptionString> headers, int type, int sizeLimit) Requests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.- Specified by:
requestJSON
in interfaceITranslationEngine
- Parameters:
httpRequest
- The request string.params
- The parameters, null for none.headers
- The HTTP headers, null for none.type
- Type of request: REQTYPE_* value.sizeLimit
- The size limit imposed, 5120 for Google, 10K for Microsoft.- Returns:
- The parsed JSON object.
- Throws:
IOException
- For I/O errors.JSONException
- For JSON exceptions.
requestJSON
public JSONObject requestJSON(String httpRequest, String params, Map<String, String> headers, int type, int sizeLimit) throws IOException, JSONExceptionRequests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.- Specified by:
requestJSON
in interfaceITranslationEngine
- Parameters:
httpRequest
- The request string.params
- The parameters, null for none.headers
- The HTTP headers, null for none.type
- Type of request: REQTYPE_* value.sizeLimit
- The size limit imposed, 5120 for Google, 10K for Microsoft.- Returns:
- The parsed JSON object.
- Throws:
IOException
- For I/O errors.JSONException
- For JSON exceptions.
requestString
public String requestString(String httpRequest, Map<String, String> params, Map<String, throws IOExceptionString> headers, int type, int sizeLimit) Requests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.- Specified by:
requestString
in interfaceITranslationEngine
- Parameters:
httpRequest
- The request string.params
- The parameters, null for none.headers
- The HTTP headers, null for none.type
- Type of request: REQTYPE_* value.sizeLimit
- The size limit imposed, 5120 for Google, 10K for Microsoft.- Returns:
- The reply string.
- Throws:
IOException
- For I/O errors.
requestString
public String requestString(String httpRequest, String params, Map<String, String> headers, int type, int sizeLimit) throws IOExceptionRequests a function using HTTPS GET or POST with "X-HTTP-Method-Override: GET", configured for proxy as specified in Eclipse or the Server.- Specified by:
requestString
in interfaceITranslationEngine
- Parameters:
httpRequest
- The request string.params
- The parameters, null for none.headers
- The HTTP headers, null for none.type
- Type of request: REQTYPE_* value.sizeLimit
- The size limit imposed, 5120 for Google, 10K for Microsoft.- Returns:
- The reply string.
- Throws:
IOException
- For I/O errors.
postRequestJSON
public String postRequestJSON(String httpRequest, Map<String, String> headers, String data) throws IOExceptionRequests a function using HTTPS POST, configured for proxy as specified in Eclipse or the Server.- Specified by:
postRequestJSON
in interfaceITranslationEngine
- Parameters:
httpRequest
- The request string.headers
- The HTTP headers, never null.data
- The data string.- Returns:
- The reply string.
- Throws:
IOException
- For I/O errors.