9 Best Practices for Internationalization

It’s easier now to reach customers all over the world than it ever has been, which makes internationalization an important part of developing new software. Internationalization matters even for companies that aren’t yet looking to expand into new countries and regions, or to support additional languages. Planning ahead for that growth will save money and time, and following some internationalization best practices can make the process smoother, too.

Internationalization, or i18n, is the process of designing software so it can be localized for users in different locales and who speak different languages. When done correctly, coding for i18n makes localization, also known as l10n, and translation for multiple countries much easier.

Internationalization Best Practices

Internationalization involves more than just including Unicode support in software. Knowing how the coding language that’s going to be used supports locale is important, as is using development tools that continuously monitor code for i18n-related issues. These nine best practices can help make internationalization a success.

Start Early

Planning for internationalization and localization at the beginning of a project makes the process much easier than jumping in later. Coding with i18n in mind should always be part of development — from initial concept through adding new features and bug fixes.

Always Support Unicode

In simple terms, Unicode is a type format that lets fonts support over 149,000 glyphs such as letters, punctuation, and other symbols. Supporting Unicode helps make localization possible because the characters needed for translating text for different locales are available in a single font set. Chinese, Japanese, and some other languages require double-byte fonts, so verify Unicode fonts included in the project support double-byte.

Include i18n in Your Development Environment

Internationalization-related bugs lead to localization issues, so developers need a way to know where those bugs are. Tools such as Globalyzer lets developers see i18n bugs directly in their IDE, pull requests, and scans code repositories for internationalization issues, too.

Externalize Strings

Hard coding text for menus, alerts, and other dialog items makes them impractical for localization teams to manage. All of the text that’s going to be translated for specific locales needs to be managed outside of the software’s code, otherwise it can’t be tracked for translation.

Don’t Concatenate

Writing code that builds phrases on the fly, or concatenation, may seem efficient, but it makes localization extremely difficult. Grammar and meaning can be lost in word-for-word translations, which gives users a poor experience, leaves software looking unprofessional, and may leave some features unusable.

Formatting Counts

International Components for Unicode, or ICU, is a set of libraries providing Unicode and Globalization support for software applications. ICU includes elements for displaying locale-based content with correct formatting for dates, times, numbers, currencies, and more. Since it supports locales around the world, it’s an important part in helping software display information correctly in the user’s native locale and language.

Test for Localization Issues

Pseudo-localization simulates language translation to help confirm software is ready for localization, and helps find potential l10n issues as developers are writing code. Automating pseudo-localization with Localyzer, for example, lets developers test their code for localization problems without having to wait for actual translations.

Don’t Stop Testing

Testing to catch bugs ahead of a software launch isn’t an isolated process. i18n and l10n scanning and testing needs to be an ongoing part of the development process, even after the product launch as new features are added and bugs are patched. That helps minimize the risk of new localization-related bugs slipping through in update releases. Automating bug tracking and flagging with Globalyzer, Localyzer, and pseudo-localization lifts that burden from developers so they can focus on coding.

Include Localization with Internationalization

Internationalization and localization aren’t isolated processes. By checking for i18n with Globalyzer, as part of regular development sprints, and including l10n testing (via automated/always-on pseudo and even machine translation and review, internationalization and localization bugs can be caught before they become expensive problems. The cost to fix i18n-related bugs can be over 600 times higher after a product launch compared to addressing them while coding.

Internationalization is Good Business

Considering the current state of technologies, it’s a smart business move to develop with internationalization requirements. That gives businesses the ability to efficiently localize software and offer users a first-class experience. Users and customers don’t want to deal with interfaces in languages they don’t understand, that don’t correctly format numbers, dates and addresses, or use local currencies. They’re more likely to take their business to competitors that give them content translated and formatted for their locale. Ultimately, that leads to lost sales and damaged reputations for businesses coding software for a single locale.

Thanks to the popularity of smartphones, tablets, and laptop computers, users are increasingly more mobile. Software developed with i18n and l10n support give users an experience in the language they choose, making it easier to understand and also increase customer loyalty.

Companies developing their software with i18n support — even if they aren’t localizing yet — have an advantage over competitors who don’t. The cost to internationalize before releasing is significantly lower, and localization support is already in place so adding support for additional locales is faster, too. Even if you don’t localize (you should!), chances are good that your users may need internationalized support for their data support, like names, dates, addresses and even currencies. That’s just part of the global reality of today’s customers.

Resources to Learn More

Internationalization Tips for Successful Globalization

What is i18n?

Managing the Cost of Software Internationalization

Launching an i18n Initiative

Reach Globalization Objectives with Expert Services

Internationalization ROI

Unicode Primer

Globalyzer

Localyzer

Coding to support i18n builds a foundation for faster and easier localization. Following best practices sets the stage for an overall better product, and helps prevent bugs and other issues that lead to development delays and unplanned expenses. For companies, that leads to happier customers, brand loyalty, and more sales.

Related Posts

Globalization Resources