International Components for Unicode

From Wikipedia, the free encyclopedia
Jump to: navigation, search
International Components for Unicode
Developer(s) IBM and many other companies.
Initial release 1999
Stable release 51.1 / 20 March 2013; 15 months ago (2013-03-20)
Written in C/C++ and Java
Operating system Cross-platform
Type libraries for Unicode and internationalization
License ICU License
Website www.icu-project.org

International Components for Unicode (ICU) is an open source project of mature C/C++ and Java libraries for Unicode support, software internationalization, and software globalization. ICU is widely portable to many operating systems and environments. It gives applications the same results on all platforms and between C, C++, and Java software. The ICU project is sponsored, supported, and used by IBM and many other companies.[1]

ICU provides the following services: Unicode text handling, full character properties, and character set conversions; Unicode regular expressions; full Unicode sets; character, word, and line boundaries; Language sensitive collation and searching; normalization, upper and lowercase conversion, and script transliterations; comprehensive locale data and resource bundle architecture via the Common Locale Data Repository (CLDR); complex text layout for Arabic, Hebrew, Indic, and Thai; multi-calendar and time zones; and rule-based formatting and parsing of dates, times, numbers, currencies, and messages.

ICU provides more extensive internationalization facilities than the standard libraries for C and C++.

Origin and development[edit]

ICU is descended from C++ frameworks produced by Taligent in the mid 1990s. After Taligent became part of IBM in early 1996, Sun Microsystems decided that the new Java language "was missing international support. Taligent had great international technology, talented engineers, and a location about 100 meters from Sun's JavaSoft division in Cupertino, California. IBM arranged for Taligent's Text and International group to contribute international classes to Sun's Java Development Kit."[2] Some of the code for ICU's text processing, date formatting, and other features was rewritten in Java and became the JDK 1.1 internationalization APIs. A large portion of this code still exists in the java.text and java.util packages. Further internationalization features were added with each later release of Java.

IBM programmers rewrote the Java internationalization classes in C++ and ported some classes to C functions. The C++/C version of ICU is known as ICU4C. The ICU project also provides ICU4J ("ICU for Java"), which adds features not present in the standard Java libraries. ICU4C and ICU4J are very similar, though not identical; for example, ICU4C includes a Regular Expression API, while ICU4J does not. Both frameworks have been enhanced over time to support new facilities and new features of Unicode and Common Locale Data Repository (CLDR).

ICU was released as an open source project in 1999 under the name IBM Classes for Unicode. It was later renamed to International Components For Unicode.[3] Since release 1.8.1 (June 14, 2001), ICU has used the MIT-X11 license, which was previously used in X11R6.[4]

See also[edit]

References[edit]

  1. ^ ICU homepage - What is ICU?
  2. ^ Laura Werner (1999). "Getting Java ready for the world: A brief history of IBM and Sun's internationalization efforts". 
  3. ^ "ICU Project Management Committee". 
  4. ^ Thomas E. Dickey. "NCURSES – Licensing". Retrieved February 5, 2014. 

External links[edit]