This description relates generally to software localization.
Software products, such as applications and operating systems, are often provided in many different human language versions. The process of converting a software product from the initial human language it was provided in to other natural languages is known as ‘localisation’. Typically the localisation is done by translating all the string elements within the user interface (UI) of the product and any other language specific parts (e.g. hotkeys, coordinates, sizes) from a first language, referred to as the source language (e.g. English) into another language (e.g. Italian), referred to as the target language. Once all the language specific parts have been translated, the product is re-built to produce the language specific version for the target language and then tested extensively before it can be shipped to a customer.
This process is time consuming and costly for the software provider. In addition it is disadvantageous from the end user perspective, because end users are required to obtain different language specific versions of a software application for each language that they wish to work in. For example, an end user who is bilingual in French and Italian would need to obtain different copies of the software application localized in either French or Italian.
Typically the translation of strings is performed by a translator who is provided with a table of all the strings in the UI that require translation with empty cells for insertion of the translated strings. Having inserted the translated strings in the target language, the resultant table is reviewed by a linguistic reviewer, who may be a natural speaker of the target language. However, even after such a review, linguistic errors may still remain because both the translation and review have been done in isolation from the real use of the strings in the software product itself. This may be particularly significant for some languages where the correct translation of a word or phrase for use on a button may be different to the correct translation for use in a title or in a body of text.
In addition, the change in natural language can cause software to ‘break’; to fail in some way. This can occur due to a number of technical reasons which can range from a simple dialog needing to be stretched, to software actually crashing. This requires very substantial costs in terms of test and developer engineers.
The following presents a simplified summary of the disclosure in order to provide a basic understanding to the reader. This summary is not an extensive overview of the disclosure and it does not identify key/critical elements of the invention or delineate the scope of the invention. Its sole purpose is to present some concepts disclosed herein in a simplified form as a prelude to the more detailed description that is presented later.
Localizing software applications into target natural languages such as French, Italian, Chinese, etc. is time consuming, expensive and error prone. End users often need to install and operate multiple copies of the same software applications localized into different languages if they need to work in multiple languages. By providing a localization engine with access to information about resources used in a user interface and translations of those resources, on the fly localization of software applications is possible. Context information is stored in the localization database and used to identify appropriate translations of the resources. Run-time context information is obtained from the user interface and/or software application and optionally a context information store. In some examples, target language resource results are presented in tooltip like displays. The translation information is stored in a localization database which in some examples comprises language-pair information whereby source language resources are stored in association with their translations. Methods of forming language pairs are described.
In an example, we provide a method of localizing a software application during use of that software application, comprising:
receiving a user input at a user interface of the software application;
identifying a source resource associated with the user input and accessing context information associated with the source resource;
using the context information to access a localisation database to obtain one or more translations of the resource into a target human language, those translations being target resources;
displaying the one or more target resources at the user interface.
An example of an apparatus for localising a software application during use of that software application is also given, comprising:
an input arranged to receive a user input from a user interface of the software application;
a processor arranged to identify a source resource associated with the user input and to access context information associated with the source resource;
an interface arranged to access a localisation database using the context information to obtain one or more translations of the resource into a target human language, those translations being target resources;
an output arranged to output the one or more target resources to the user interface for display.
Preferably the step of using the context information comprises selecting between a plurality of translations of the source resource on the basis of the context information.
Advantageously the context information is accessed from one or more of the software application and pre-specified context information.
Preferably the method further comprises identifying a unique identifier embedded in the source resource and using that unique identifier to obtain a target resource.
For example, the context information comprises one or more of: a class name, a category, a role and an identifier of a member of a suite of software applications.
In some examples the software application is a member of a suite of related software applications where at least some resources are common to each member of the suite.
Preferably the step of accessing the localisation database comprises searching for one or more translations of the same resource in the localisation database using all the accessed context information and, if no translations are found, repeating the search using less of the context information.
Preferably the method comprises using the source resource to obtain the one or more translations and wherein the localisation database is for a language pair such that it comprises stored information about source resources and their associated translations to target resources.
In some examples the localisation database is created using two other localisation databases each for a language pair between the same master source language and a different target language.
In an example the target resources are presented in a pop-up display region for a limited duration.
Furthermore, the method may comprise receiving user input and modifying any of the following features of the pop-up display on the basis of the user input: colour, transparency, borders, size, delay time, kill time, font size, presentation conditional on use of user defined control keys.
In addition, the method may comprise copying contents of the pop-up display onto an electronic clipboard.
In some examples the processor is arranged to use the context information to enable selection between a plurality of translations of the source resource.
For example, the processor is arranged to access the context information from one or more of the software application and pre-specified context information.
In some cases the processor is arranged to identify a unique identifier embedded in the source resource and the user interface is arranged to use the unique identifier to obtain a target resource.
Preferably the processor and interface are arranged to search for one or more translations of the source resource in the localisation database using all the context information and, if no translations are found, to repeat the search using less of the context information.
In some examples the apparatus comprises one or more localisation databases, each being for a language pair comprising stored information about source resources and their associated translations to target resources.
Another example provides a computer program comprising computer program code means adapted to perform all the steps of any of the methods described above when said program is run on a computer. For example, the computer program is embodied on a computer readable medium.
This acknowledges that software can be a valuable, separately tradable commodity. It is intended to encompass software, which runs on or controls “dumb” or standard hardware, to carry out the desired functions, (and therefore the software essentially defines the functions of the localisation system, and can therefore be termed a localisation system, even before it is combined with its standard hardware). For similar reasons, it is also intended to encompass software which “describes” or defines the configuration of hardware, such as HDL (hardware description language) software, as is used for designing silicon chips, or for configuring universal programmable chips, to carry out desired functions.
Many of the attendant features will be more readily appreciated as the same becomes better understood by reference to the following detailed description considered in connection with the accompanying drawings.
The present description will be better understood from the following detailed description read in light of the accompanying drawings, wherein:
Like reference numerals are used to designate like parts in the accompanying drawings.
The detailed description provided below in connection with the appended drawings is intended as a description of the present examples and is not intended to represent the only forms in which the present example may be constructed or utilized. The description sets forth the functions of the example and the sequence of steps for constructing and operating the example. However, the same or equivalent functions and sequences may be accomplished by different examples.
The software application of
The localization engine finds a target language resource associated with the source language resource, from the localization database (see step 22). In some embodiments the localization database comprises language pair information. This comprises details of a target language resource for each listed source language resource in the localization database. However, this is not essential. In other embodiments, the localization database comprises target language resources each having a unique identifier, such that language-pair information is not essential. In that case, the localization engine is arranged to use the unique identifiers to access the appropriate target language resources. The localization database additionally comprises context information associated with the target and/or source language resources in the localization database. This is described in more detail below with reference to
From
Linguistic errors sometimes occur when software products are localized because the translation of resources may be done in isolation of the real use of the resources in the software product itself. For example, a particular string (e.g. ‘File’) in English may be used in several places in a software product's user interface (e.g. on a menu, a button and a tooltip) and another language may require one or more different translations dependent upon the particular use of the string. Thus we use context information to appropriately identify a target resource from the localization database 13.
The localization database comprises a target language resource for all or at least most of the source language resources. There may be several entries for the string “File” according to the different contexts in which that string is used in the user interface. In some examples context information is also stored in the localization database and is associated with the target language resources. By using context information it is then possible to access appropriate target language resources from the database in the case that two or more translations exist for a particular resource. In other example, the context information is not explicity stored; rather a unique ID is associated with each target language resource and this unique ID captures context information.
The apparatus of
In one example, the retrieval mechanism comprises first using all the available “run time” context information to query the localization database (see box 41). The term “run time context information” is used here to refer to that context information obtained from the context information sources 30 and/or the software application during the localization process. In contrast, the context information in the localization database is pre-configured. If, one or more translations are found (see box 42) then the target language resources are presented to the user (see box 43). If no translations (target language resources) are found then the search is repeated using one less item of context information (see box 44). This process repeats until either a search is successful (see box 43) or until there is no possibility of any results in the localization database (see box 44). In the latter case, it is then optionally possible to continue the search using localization data of other providers (see box 45).
The process of presenting the target language resources to the user (box 43) may optionally be linked with a user feedback process.
In the case that user feedback is requested this can be (but not the only option) via a hyperlink in a pop-up display showing the target resources. Clicking on the hyperlink is arranged to send an event to the localization engine to enable the feedback information to be taken into account in future. The feedback information may comprise weightings applied to particular target resources, those weightings being stored in any suitable location, such as the localization database.
In another example, the system presents additional information in conjunction with the identified target language resource(s). For example, the additional information comprises an indication of a confidence level for the target resource and/or information about a provider of the target resource. This is illustrated in
If the translation is obtained from an external provider then interfaces to the provider are arranged such that the provider is able to give translation confidence information with its translations. Information as to the type of provider can also be given.
The additional information (such as translation confidence and provider type) is presented to the user in any suitable way. For example, using colour, symbols, percentages, numbers, graphics, etc.
The localization database 13 can be arranged to store the target resources and context information in a variety of different ways. Also, in some examples it stores source language resources as well.
The category information indicated in
Pre-Processing of Source Resource and/or Target Resource
As mentioned above with reference to
In the case that pre-processing is carried out, the run-time source language resources input to the localization process are also pre-processed in the same manner as the source language resources stored in the localization database.
In some examples a tooltip display or pop-up display is used for presenting the target language resources. In that case, the display may have properties that may be configured by the user via the user interface. For example, colours used in the display, transparency, borders and default size of the display. Other user configurable properties optionally comprise a delay time between user selection of a user interface item and presentation of the tooltip or pop-up display; a kill time or duration for which tooltip or pop-up displays are to be presented; ability to only show localization tooltips when using user-defined control keys; and ability to enlarge the font used in localization tooltips. The kill time setting is useful to enable a user to specify how long a tooltip displays for before hiding. It is especially useful for users who need to take some time to read a tooltip. The ability to only show localization tooltips when using user-defined control keys is advantageous when users become familiar with many of the translations shown and require to only show translations in some cases. For example, the CTRL key (or any other defined key) could be used to identify those cases where translations are required. Users may hold down the CTRL key (for example) and then select the resource to be translated. This is useful for resources the user does not use regularly but still requires to have translated occasionally. In another example, the contents of the tooltip or pop-up display are arranged such that they may be copied onto an electronic clipboard.
In order to enable a user to configure features of the pop-up display or other display of the target resources, the localization engine optionally has its own user interface. It is also possible for this user interface to be provided as part of the user interface of the software application.
In another embodiment, the software application 11 (see
A method of authorized software application list verification is optionally used to ensure that the localization engine 12 only carries out localization for authorized software. The localization engine is arranged to check a list of authorised software before proceeding to operate with a given software applicatio n 11.
Those skilled in the art will realize that storage devices utilized to store program instructions can be distributed across a network. For example, a remote computer may store an example of the process described as software. A local or terminal computer may access the remote computer and download a part or all of the software to run the program. Alternatively, the local computer may download pieces of the software as needed, or execute some software instructions at the local terminal and some at the remote computer (or computer network). Those skilled in the art will also realize that by utilizing conventional techniques known to those skilled in the art that all, or a portion of the software instructions may be carried out by a dedicated circuit, such as a DSP, programmable logic array, or the like.
Any range or device value given herein may be extended or altered without losing the effect sought, as will be apparent to the skilled person.
The steps of the methods described herein may be carried out in any suitable order, or simultaneously where appropriate.
It will be understood that the above description of a preferred embodiment is given by way of example only and that various modifications may be made by those skilled in the art.
Number | Date | Country | Kind |
---|---|---|---|
06115906.7 | Jun 2006 | EP | regional |
This application is a continuation of and claims priority to U.S. patent application Ser. No. 12/306,104, filed on Dec. 22, 2008, and entitled “DYNAMIC SOFTWARE LOCALIZATION”, which is a National Stage of International Application PCT/US2007/010916, filed May 4, 2007, which claims priority from European Patent Application No. 06115906.7, filed Jun. 22, 2006. This application claims the benefit of each of the above-identified applications, and the disclosure of the above-identified application are hereby incorporated by reference in their entirety as if set forth herein in full.
Number | Date | Country | |
---|---|---|---|
Parent | 12306104 | Dec 2008 | US |
Child | 14550849 | US |