The three JobScheduler user interfaces (JOC, JOE and JID) have been internationalized (i18n) to allow the support of languages such as Japanese and Russian. There is a separate file for each language, which means localisation (L10n) of these interfaces is relatively straightforward:

  • JOC: you have to create an additional language file for your language. This is described in the Language section of our OperationsGUI Wiki page. We recommend you just copy and rename the English file and change the texts to your language.
  • JOE: for every language there is a properties file in the .jar file as show in the screen shot below. You simply copy the English file and rename it to, for example, JOEMessages_ja.properties (for Japanese) following the pattern shown in the screen shot. Then you translate the English texts to your language.

  • JID: same as for JOE. The properties file is located in the jar as shown below:

Please use the IETF language codes when you are naming your language properties file and underscores ("_") as separators. For example, you would name a Japanese language file either "JOEMessages_ja.properties" or "JOEMessages_ja_JP.properties".

Conversion Notes

You have to take into account that take Java is not able to process .property files which are not encoded in ISO-8859-1. If you do not do this, it is likely that you will get an error when starting, for example, {{dashboard.com }}:

 [root@JobScheduler ~]#
 /opt/sos-berlin.com/jobscheduler/scheduler/bin/dashboard.sh
 Exception in thread "main" java.util.MissingResourceException: Can't
 find bundle for base name
 com.sos.dailyschedule.SOSSchedulerDashboardMain, locale en
 at
 java.util.ResourceBundle.throwMissingResourceException(ResourceBundle.java:1427)
 at java.util.ResourceBundle.getBundleImpl(ResourceBundle.java:1250)
 at java.util.ResourceBundle.getBundle(ResourceBundle.java:777)
 at com.sos.localization.Messages.getBundle(Messages.java:81)
 at com.sos.localization.Messages.<init>(Messages.java:65)
 at
 com.sos.JSHelper.Basics.JSToolBox.setMessageResource(JSToolBox.java:69)
 at com.sos.JSHelper.Basics.JSToolBox.<init>(JSToolBox.java:55)
 at com.sos.i18n.I18NBase.<init>(I18NBase.java:63)
 at
 com.sos.dailyschedule.SosSchedulerDashboardMain.<init>(SosSchedulerDashboardMain.java:55)
 at
 com.sos.dailyschedule.SosSchedulerDashboardMain.main(SosSchedulerDashboardMain.java:50)

Here you have to carry out an intermediate step to convert from UTF-8 to ISO-8859-1, using the native2ascii program, which is part of the Java JDK:

 native2ascii -encoding utf-8 SOSSchedulerDashboardMain_ja.orig SOSSchedulerDashboardMain_ja.properties

The content of the file may look a little bit strange after conversion (smile))

 SOSDashB_Reset = \u30ea\u30bb\u30c3\u30c8
 SOSDashB_Today = \u672c\u65e5\u5206\u8868\u793a
 SOSDashB_only_executed = \u5b9f\u884c\u6e08\u306e\u307f\u8868\u793a
 SOSDashB_show_log_in_new_tab = \u30ed\u30b0\u3092\u65b0\u3057\u3044\u30bf\u30d6\u3067\u8868\u793a
 SOSDashB_open_scheduler = JobScheduler\u3092\u958b\u304f
 SOSDashB_only_stand_alone_jobs = \u30b8\u30e7\u30d6\u306e\u307f\u8868\u793a
 SOSDashB_only_job_chains = \u30b8\u30e7\u30d6\u30c1\u30a7\u30fc\u30f3\u306e\u307f\u8868\u793a
 SOSDashB_only_with_error = \u30a8\u30e9\u30fc\u306e\u307f\u8868\u793a
 SOSDashB_only_running = \u5b9f\u884c\u4e2d\u306e\u307f\u8868\u793a
 SOSDashB_only_successfull = \u6210\u529f\u306e\u307f\u8868\u793a
 SOSDashB_only_late = \u9045\u5ef6\u306e\u307f\u8868\u793a
 SOSDashB_only_waiting = \u5f85\u6a5f\u306e\u307f\u8868\u793a
 SOSDashB_start_now = \u5373\u6642\u5b9f\u884c
 SOSDashB_close = \u9589\u3058\u308b
 SOSDashB_new_log = \u65b0\u898f\u30ed\u30b0
 SOSDashB_NAME_TAB_HISTORY = \u5b9f\u884c\u5c65\u6b74
 SOSDashB_NAME_TAB_PLANNED = \u5b9f\u884c\u8a08\u753b
 SOSDashB_NAME_TAB_JOBNET = JobNet
 
 SOSDashB_FROM = \u81ea

Now include the ISO property file in the jar-file.
Use the "update" function of the jar-utility, don't create a new jar:

 C:\temp\jars>jar -uvf com.sos.dailyschedule.jar com/sos/dailyschedule/SOSSchedulerDashboardMain_ja.properties
 Add: com/sos/dailyschedule/SOSSchedulerDashboardMain_ja.properties

Finally, do not forget that the new language file must be located at the same place as the other language files. If not, it is possible that you will get an error message if the program tries to read an english message every time a message in your new language is not found.

When all goes well, your interface should look something like this (JID Interface in Japanese):

See also: Support of Unicode with UTF-8 encoding for languages such as Japanese in addition to English

Get in touch with us if you have any problems not covered by the above or wish to check if your language is already being localised.

If it is possible for you to send your language files to us, we will incorporate these files into future releases, with, if you wish, an acknowledgement of your contribution.