What is XLIFF?
XLIFF is the XML Localization Interchange File Format designed by a group of software providers, localization service providers, and localization tools providers. It is intended to give any software provider a single interchange file format that can be understood by any localization provider. Xliff Editor provides the easiest way of editing your XLIFF files.No more messing around with the XML format, or worrying about file corruption. Xliff Editor Free Download mac includes full search support, handy keyboard shortcuts, and even basic read support for sdlxliff files! ImgSXliff Editor 2.7.3 macOS 4.7 mb Xliff Editor - its fast to load, easy to use, and has a low memory.
Basically, xliff is simply an xml file structured specifically for localization. This can be exported from Xcode in a chosen language, e.g en.xliff and then translated to another required language, say fr.xliff and then imported back into Xcode. Simple eh? Apple seem pretty confident that this is now ‘industry standard' so it's worth developers paying attention.
But where to edit XLIFF files?
Here at Brightec we were thrilled with this new development, localisation should now be a much simpler process, but we quickly discovered a small problem. We couldn't find a free online tool we could utilise to edit the new XLIFF files. Many of the big online translation software services don't yet support it and may not for a while yet.
There are a number of companies that will happily translate your files for you but, of course, in exchange for a quick buck.
Our solution
Never to be easily put off, we got our heads together and came up with a solution. ‘Boys, let's just build our own yeah?' So, without further ado, that's exactly what we did.
Introducing our very own online XLIFF editor: http://xliff.brightec.co.uk/
Our approach
Our free XLIFF editor is a simple online tool that will take a file with the .xliff or .xlf extension and make it into an online form with the text strings laid out and a text field for the translations to be added.
The tool doesn't have any database built in. So, users can just upload, edit and download again. Re-uploading a file will populate all of the form inputs so that a user can see which test is left to translate.
Of course every line is numbered and a handy button shows only the lines still needing translation so you can navigate the file easily.
What else is there?
Now, it would be remiss of us to not mention some of the other tools out there. We won't pretend this is the only editor you'll find.
There are a number of companies that will happily translate your files for you but, of course, in exchange for a quick buck.
Our solution
Never to be easily put off, we got our heads together and came up with a solution. ‘Boys, let's just build our own yeah?' So, without further ado, that's exactly what we did.
Introducing our very own online XLIFF editor: http://xliff.brightec.co.uk/
Our approach
Our free XLIFF editor is a simple online tool that will take a file with the .xliff or .xlf extension and make it into an online form with the text strings laid out and a text field for the translations to be added.
The tool doesn't have any database built in. So, users can just upload, edit and download again. Re-uploading a file will populate all of the form inputs so that a user can see which test is left to translate.
Of course every line is numbered and a handy button shows only the lines still needing translation so you can navigate the file easily.
What else is there?
Now, it would be remiss of us to not mention some of the other tools out there. We won't pretend this is the only editor you'll find.
Pootle
This is probably the most popular out there at present. A few of our observations:
- Needs to be installed onto your own web server
- Hasn't been updated in a long time
- Installation is really hard, it's built in Python using the Django framework
- We couldn't get any .xliff file to load into it, although others report they have had some success
Translution
- Needs downloading and using locally
- Doesn't work on iOS
OmegaT
- Apparently works on iOS, but we couldn't get it to work
Weblate
- Seems reasonably powerful
- Needs to be installed onto your own web server
- Appears to be quite ‘buggy'
- Far to complicated for most translators to comfortably use
Brightec's free online XLIFF editor
Hopefully our tool will be what you're looking for. Let us know of any improvements or changes you think it needs.
A VSCode extension to keep XLIFF translation files in sync with a specified, automatically generated base-XLIFF file.
Update: There is now also an 'XLIFF Sync' PowerShell module! Dirt 4 1 0 12 download.
This project originated from the need for a tool to automatically merge/synchronize XLIFF translation files that are in the OASIS specification.This extension is based on the Angular Localization Helper developed by manux54, which has been extended so that it can also be used to synchronize files from other XLIFF generators.It is specifically targeted at synchronizing trans-units from an .g.xlf
file automatically generated by the AL Language extension that can be used to develop extensions for Microsoft Dynamics 365 Business Central.Apart from synchronizing trans-units from a base-XLIFF file, this extension contributes various other features, including commands to check for missing translations, detect problems in translations and import translations from external XLIFF files.
More information: XLIFF Sync: Time for a complete overview
- Contributions
- Usage
Features
- Merge new translations from a generated, base-XLIFF file into existing XLIFF files.
- Merge from the base-XLIFF file into a manually specified target XLIFF file.
- Merge from the base-XLIFF file into all XLIFF files in the open workspace.
- Search and highlight missing translations in an open XLIFF file.
- Run technical validations to check for problems in the translations of target XLIFF files.
- Import/Copy translations for matching sources from external XLIFF files to target XLIFF files.
- Support for XLIFF 1.2 and 2.0
- Convert between XLIFF 1.2 and 2.0 format.
Contributions
Commands
Command | Explanation |
---|---|
XLIFF: Create New Target File(s) | Create one or more new target XLIFF files from the base-XLIFF file. |
XLIFF: Synchronize to Single File | Merge new trans-units from base-XLIFF file into a manually specified target XLIFF file. |
XLIFF: Synchronize Translation Units | Merge new trans-units from base-XLIFF file into all other XLIFF files in the open project folder. |
XLIFF: Check for Missing Translations | Checks if there are any missing translations in the target XLIFF files in the open project folder. For each file with missing translations, an informational message will be shown (with a button to open the file externally). |
XLIFF: Check for Need Work Translations | Checks if there are translations that need work in the target XLIFF files in the open project folder. For example, the source text contains placeholders (e.g., '%1' or '{0}') while the translation does not. Translations with problems will be tagged with needs-adaptation and an 'XLIFF Sync' note will be added to the trans-unit node. For each file with translations that need work, an informational message will be shown (with a button to open the file externally). |
XLIFF: Next Missing Translation | In an XLIFF file that is currently opened in the active editor, search for the next missing translation. |
XLIFF: Next Needs Work Translation | In an XLIFF file that is currently opened in the active editor, search for the next translation tagged as needs-adaptation . |
XLIFF: Import Translations from File(s) | Import/Copy translations from external XLIFF files to trans-units with matching sources of target XLIFF files with the same target-language. |
Settings
Setting | Default | Explanation |
---|---|---|
xliffSync.baseFile | .g.xlf | Specifies which XLIFF file to use as the base (e.g., the generated XLIFF). If the file does not exist, you will be prompted to specify the file to use as base-XLIFF file the first time you use the Synchronize command. |
xliffSync.fileType | xlf | The file type (xlf or xlf2 ). |
xliffSync.syncCrossWorkspaceFolders | false | Specifies whether the extension will sync from a base file to the translation files in all workspace folders. By default, the extension will always sync. per workspace folder. If you enable this setting, then you can have the base file in one workspace folder and target translation files in other workspace folders. |
xliffSync.matchingOriginalOnly | true | Specifies whether the extension will sync only to files where the original-attribute is matching. |
xliffSync.unitMaps | All | Specifies for which search purposes this command should create in-memory maps in preparation of syncing. |
xliffSync.missingTranslation | %EMPTY% | The placeholder for missing translations for trans-units that were synced/merged into target XLIFF files. You can use %EMPTY% if you want to use an empty string for missing translations. |
xliffSync.needsWorkTranslationSubstate | xliffSync:needsWork | Specifies the substate to use for translations that need work in xlf2 files. Tip: If you use Poedit, then you could also set this to poedit:fuzzy . |
xliffSync.findByXliffGeneratorNoteAndSource | true | Specifies whether or not the extension will try to find trans-units by XLIFF generator note and source. |
xliffSync.findByXliffGeneratorAndDeveloperNote | true | Specifies whether or not the extension will try to find trans-units by XLIFF generator note and developer note. |
xliffSync.findByXliffGeneratorNote | true | Specifies whether or not the extension will try to find trans-units by XLIFF generator note. |
xliffSync.findBySourceAndDeveloperNote | false | Specifies whether or not the extension will try to find translations by the combination of source and developer note. |
xliffSync.findBySource | false | Specifies whether or not the extension will try to find translations by source. If there are multiple trans-units with the same source, then the translation of the first translation unit is used for all units. |
xliffSync.parseFromDeveloperNote | false | Specifies whether translations should be parsed from the developer note. Translations can be retrieved from a Developer note in the following format: en-US=My translation|nl-NL=Mijn vertaling . |
xliffSync.parseFromDeveloperNoteOverwrite | false | Specifies whether translations parsed from the developer note should always overwrite existing translations. |
xliffSync.parseFromDeveloperNoteSeparator | | | Specifies the separator that is used when translations are parsed from the developer note. |
xliffSync.equivalentLanguages | { 'de-DE': 'de-.*', 'en-US': 'en-.*', 'es-ES': 'es-.*', 'fr-FR': 'fr-.*', 'nl-NL': 'nl-.*' } | Specifies master and slave languages that should be treated as equivalent, i.e., translations are copied from the master language. |
xliffSync.equivalentLanguagesEnabled | false | Specifies whether languages should be treated as equivalent as specified in the xliffSync.equivalentLanguages setting. |
xliffSync.copyFromSourceForLanguages | [] | Specifies the languages for which translations should be copied from the source text of trans-units. |
xliffSync.copyFromSourceForSameLanguage | false | Specifies whether translations should be copied from the source text if source-language = target-language. This will not overwrite existing translations of trans-units in target files. |
xliffSync.copyFromSourceOverwrite | false | Specifies whether translations copied from the source text should overwrite existing translations. |
xliffSync.detectSourceTextChanges | true | Specifies whether changes in the source text of a trans-unit should be detected. If a change is detected, the target state is changed to needs-adaptation and a note is added to indicate the translation should be reviewed. |
xliffSync.ignoreLineEndingTypeChanges | false | Specifies whether changes in line ending type (CRLF vs. LF) should not be considered as changes to the source text of a trans-unit. |
xliffSync.clearTranslationAfterSourceTextChange | false | Specifies whether translations should be cleared when the source text of a trans-unit changed. |
xliffSync.addNeedsWorkTranslationNote | true | Specifies whether an XLIFF Sync note should be added to explain why a trans-unit was marked as needs-work. |
xliffSync.keepEditorOpenAfterSync | true | Specifies whether XLIFF files should be opened in the editor after syncing. |
xliffSync.openExternallyAfterEvent | [] | Specifies after which event translation files should be opened automatically with the default XLIFF editor. Options: 'Check', 'ProblemDetected', 'Sync' |
xliffSync.developerNoteDesignation | Developer | Specifies the name that is used to designate a developer note. |
xliffSync.xliffGeneratorNoteDesignation | Xliff Generator | Specifies the name that is used to designate a XLIFF generator note. |
xliffSync.autoCheckMissingTranslations | false | Specifies whether or not the extension should automatically check for missing translations after syncing. |
xliffSync.autoCheckNeedWorkTranslations | false | Specifies whether or not the extension should automatically run a technical validation on translations after syncing |
xliffSync.needWorkTranslationRules | ['OptionMemberCount', 'OptionLeadingSpaces', 'Placeholders'] | Specifies which technical validation rules should be used. |
xliffSync.needWorkTranslationRulesEnableAll | false | Specifies whether or not all available technical validation rules should be used. Enabling this setting makes xliffSync.needWorkTranslationRules redundant. |
xliffSync.preserveTargetAttributes | false | Specifies whether or not syncing should use the attributes from the target files for the trans-unit nodes while syncing. |
xliffSync.preserveTargetAttributesOrder | false | Specifies whether the attributes of trans-unit nodes should use the order found in the target files while syncing. |
xliffSync.preserveTargetChildNodes | false | Specifies whether child nodes of trans-unit nodes specific to the target files should be preserved. This will preserve alt-trans nodes and custom nodes in XLIFF 1.2 target files. |
xliffSync.replaceTranslationsDuringImport | false | Specifies whether existing translations will be replaced when the XLIFF: Import Translations from File(s) command is run. |
xliffSync.decoration | {'backgroundColor': 'rgba(240, 210, 105, 0.35)', 'overviewRulerColor': 'rgba(240, 210, 105, 0.35)', 'border': '1px solid white', 'borderRadius': '4px'} | Specifies how to highlight missing translations or translations that need work in an XLIFF file opened in the editor. |
xliffSync.decorationEnabled | true | Specifies whether decorations for missing translations and translations that need work should be applied. |
xliffSync.decorationTargetTextOnly | false | Specifies whether decorations for missing translations and translations that need work should only be applied to the target text. |
xliffSync.enableSnippetsForLanguages | [] | Specifies the programming languages for which the XLIFF Sync snippets should be enabled. Currently supported: al . |
xliffSync.snippetTargetLanguage | TargetLanguageCode | Specifies which target language to use by default in the XLIFF Sync snippets (e.g., nl-NL ). |
Usage
The extension will try to find corresponding trans-units and translations within an existing file as follows:
- Finding trans-units:
- By Id
- By XLIFF Generator Note & Source (enabled by default, configurable with
xliffSync.findByXliffGeneratorNoteAndSource
) - By XLIFF Generator Note & Developer Note (enabled by default, configurable with
xliffSync.findByXliffGeneratorAndDeveloperNote
) - By XLIFF Generator Note (enabled by default, configurable with
xliffSync.findByXliffGeneratorNote
)
- Finding translations:
- By Source & Developer Note (disabled by default, configurable with
xliffSync.findBySourceAndDeveloperNote
) - By Source (disabled by default, configurable with
xliffSync.findBySource
)
- Initial translation:
- Parse from Developer Note (disabled by default, configurable with
xliffSync.parseFromDeveloperNote
) - Copy from Source, if applicable/configured for target language (disabled by default, configurable with
xliffSync.copyFromSourceFor..
)
If no trans-unit or translation is found, the unit is added and its target node is tagged with state='needs-translation'
.
Create New Target File(s)
Using the Command Palette
- F1 or Ctrl/Cmd + Shift + P to open the command palette
- XLIFF: Create New Target File(s)
Super refocus 1 5 1. This command will let you create one or more new target files, letting you choose from a set of RFC 4646 or RFC 5646 language tags depending on the XLIFF file type (i.e., xlf
or xlf2
).The new file is automatically synced with the base file; if it is not known you will be prompted to specify the file to use as the base file first.
Synchronize to Single File
Using the Command Palette
- F1 or Ctrl/Cmd + Shift + P to open the command palette
- XLIFF: Synchronize to Single File
Using keyboard shortcut
- Alt + X, S (default shortcut)
By default, the extension expects the base-XLIFF file to be named application.g.xlf
.If no matching file is found, you are prompted to identify the base file.This setting will be saved for future use.If the extension is invoked from a localization file, that file will be updated, otherwise the extension will prompt you for the file to update.
You can also use this command to create a new XLIFF file for a language.For this, choose the 'New File..' option and choose the language tag for the new target language.
Synchronize Translation Units
Using the Command Palette
- F1 or Ctrl/Cmd + Shift + P to open the command palette
- XLIFF: Synchronize Translation Units
NOTE: This command will merge new translations into all XLIFF files in your workspace folder (with, obviously, excluding the base-XLIFF file itself).
Using keyboard shortcut
- Alt + X, M (default shortcut)
From the Explorer
- Right-click on a file with the .xlf extension.
- Select: Synchronize Translation Units
If you select the base-XLIFF file, then translation units will be synced to all other XLIFF files in the workspace.If you select any other XLIFF file, then translation units will be synced from the base-XLIFF file to the selected file.
Here's a small demo:
Check for Missing Translations
Using the Command Palette
- F1 or Ctrl/Cmd + Shift + P to open the command palette
- XLIFF: Check for Missing Translations
This will check all XLIFF files in the workspace and notify about any missing translations in the files.You also have the option to open files with missing translations with your default XLIFF editor using the Open Externally button from the informational message.
Check for Need Work Translations
Using the Command Palette
- F1 or Ctrl/Cmd + Shift + P to open the command palette
- XLIFF: Check for Need Work Translations
This will run technical validation/checks for all XLIFF files in the workspace and notify about any translations that need work in the files.You also have the option to open files containing problems with your default XLIFF editor using the Open Externally button from the informational message.
The target node of the trans-units containing problems will be tagged with state='needs-adaptation'
.Additionally, a note
will be added to the trans-unit to explain which problem was detected.When you run the command again after resolving the issue, then this note will be automatically removed. Hdr light studio 5 0 download free.
You can configure the checks that need to be run with the xliffSync.needWorkTranslationRules
setting.The currently implemented checks are the following:
Rule ID | Check | Trigger | Example |
---|---|---|---|
ConsecutiveSpacesConsistent | 'Consecutive space'-occurrences are not matching. | N.A. | The source text includes 3 consecutive spaces, the translation text includes 2 consecutive spaces. |
ConsecutiveSpacesExist | Source or translation text contain consecutive spaces. | N.A. | The source text includes 2 consecutive spaces, e.g., |
OptionMemberCount | Number of options in caption are not matching. | Xliff Generator note with Property OptionCaption or Property PromotedActionCategories . | The source text includes 3 options, A,B,C , but the translation text includes 4 options, A,B,C,D . |
OptionLeadingSpaces | Number of leading spaces in options are not matching. | Xliff Generator note with Property OptionCaption or Property PromotedActionCategories . | The source text includes a space, A, B , but the translation text does not, A,B . |
Placeholders | Placeholders of source and translation are not matching. | Source/Translation text includes placeholders of the form {0} or %1 or #1 . | The source text includes placeholders %1 %2 , but the translation text only includes %1 . |
PlaceholdersDevNote | Placeholders are not explained in the Developer note. | Source text includes placeholders of the form {0} or %1 or #1 . | The source text includes placeholders %1 %2 , but the Developer note is empty and so does not contain the placeholders. |
SourceEqualsTarget | Source and translation are not the same, even though source-language = target-language for the .xlf file. | The source-language is the same as the target-language for the .xlf file. | The source text is 'A', but the translation text is 'B'. The source-language and target-language are both 'en-US'. |
Note: You may want to use rule SourceEqualsTarget
in combination with setting xliffSync.copyFromSourceForSameLanguage
set to true
.
Find Next Missing Translation in XLIFF File
Using the Command Palette
- F1 or CMD + Shift + P to open the command palette
- XLIFF: Next Missing Translation
Using keyboard shortcut
- Alt + X, N (default shortcut)
Missing translations are tagged and highlighted.You can use the extension to navigate between missing translations.On a Macbook Pro, this command appears on the touchbar within XLIFF files.
Find Next Needs Work Translation in XLIFF File
Xliff File Editor
Using the Command Palette
- F1 or CMD + Shift + P to open the command palette
- XLIFF: Next Needs Work Translation
Using keyboard shortcut
- Alt + X, W (default shortcut)
2.7 Dragon Ball
Translations that need work are tagged and highlighted.You can use this command to navigate between translations that need work.On a Macbook Pro, this command appears on the touchbar within XLIFF files.
Import Translations from File(s)
Using the Command Palette
- F1 or Ctrl/Cmd + Shift + P to open the command palette
- XLIFF: Import Translations from File(s)
This will open a file dialog in which you can select one or more XLIFF files (.xlf or .xlf2).The command will copy translations from the selected files to trans-units in the XLIFF files in your project folder with the same target-language for matching sources.It will try first to merge translations for trans-units with a matching combination of source-text and Developer note, and only after that try to merge translations to trans-units with matching source-text.That way you could utilize the Developer note to have the import perform a more precise merge of the translations (e.g., based on tags in the Developer notes).
Known Issues
- Automatically inserting new groups into target files is not implemented.
- The NAV2018 XLIFF generator creates Xliff Generator Notes without any identifiers, therefore it is recommended to change the
xliffSync.findBy..
settings to not synchronize trans-units based on Xliff Generator notes. - Files larger than 50 MB cannot be processed at the moment. For now, please use the 'XLIFF Sync' PowerShell module instead.