소프트웨어를 국제화해야 하기 위해서는 고려해야 할 것이 한두가지가 아니다. 그런데 많은 회사들은 메시지나 번역하면 되는 것으로 안다. 그렇게 쉽게 접근하다가는 해외 진출을 하면할 수록 문제가 커지고 비용이 늘어서 점점 어려워진다.
실제 만나본 거의 대부분의 회사가 국제화를 제대로 적용하지 못해서 낭패를 보고나 해외에서 크게 실패를 하였다. 비효율성이 높고 문제가 많아도 제품의 크기가 작거나 고객수가 적다면 그럭저럭 버티지만 큰 제품이나 대규모 서비스는 타격이 엄청나다. 심지어는 회사가 휘청할 정도의 문제를 야기 시키기도 한다.
국제화 기술은 알아야 할 지식도 많고 경험도 많이 필요하다.
기본적으로 국제화(i18n)과 지역화(L10N)으로 나뉜다. 국제화(i18n)은 소프트웨어가 여러 Locale을 지원할 수 있는 기본 기술이고 지역화(L10N)은 각 Locale을 지원하는 것이다.
이 과정에서 고려해야 할 것은 수백가지가 넘는다. 그 중에서 49가지만 알아보자. 만약에 국제화된 소프트웨어를 개발하고 있는 개발자라면 이중에서 몇가지나 알고 있는지 세어보자. 어떤 항목은 그 하나가 엄청나게 큰 것도 있다. 특별하게 순서를 가지고 정리한 것은 아니지만 하나씩 살펴보자.
번호
|
항목
|
설명
|
1
| 언어 구분 |
한 국가에도 언어가 여러가지이기도 하고 하나의 언어가 여러 나라에서 서로 다르게 쓰이기도 한다.
|
2
|
지역 구분
|
지역과 국가가 완전히 일치하지는 않는다. 언어와 지역 정보가 합쳐져서 Locale이 된다. 소프트웨어는 Locale 단위로 지역화(L10N)를 한다.
|
3
|
소프트웨어의 인코딩 전략
|
소프트웨어가 지원해야 할 인코딩은 매우 복잡하다. Multibyte를 지원하냐 Unicode를 지원하냐에 따라서 인코딩이 다르고 Software, File, Database, Network 별로 다른 인코딩 전략을 사용해야 한다.
|
4
|
현지 로케일의 인코딩으로 Export
|
지역에 따라서 특정 인코딩을 선호하기도 하고 Software의 인코딩과 다른 인코딩으로 Export를 하기도 한다.
|
5
|
시스템에 따른 인코딩 차이
|
거의 대부분의 OS는 Unicode를 지원하지만 OS에 따라서 Unicode이 인코딩이 다르다. UTF-16(UCS2) 또는 UTF-32이 그 예이다.
|
6
|
로칼 요구사항의 차이
|
지역화(L10N)시 현재의 요구사항을 반영한다. 하나의 소스코드와 하나의 팩키지로 지역 요구사항을 반영할 수 있도록 한다.
|
7
|
메시지 번역
|
Locale별로 번역을 한다.
|
8
|
메시지 번역 프로세스
|
소스코드에서 메시지를 추출하고 번역하고 제품에 반영한다. 소스코드가 수정되면 수정된 메시지를 쉽게 반영할 수 있는 프로세스가 필요하다. 번역을 제외한 모든 부분은 자동화가 되어야 한다.
|
9
|
메시징 기술
|
메시징 기술은 수도 없이 많지만 여기서 언급한 모든 것을 지원하는 메시징 기술은 별로 없다. 거의 대부분의 회사는 개발툴에서 번들로 제공하는 간단한 메시징 기술을 사용하는데 이 정도로는 아주 간단한 소프트웨어 밖에 제대로 지원하지 못한다.
|
10
|
문자 인코딩 변환
|
소프트웨에서는 여러가지 인코딩을 사용하기 때문에 수시로 변환을 해야 한다.
|
11
|
번역에 따른 문자열 길이 변화
|
메시지를 번역하면 메시지의 길이가 변한다.
|
12
|
국제화를 고려한 UI 디자인
|
메시지의 길이는 지역에 따라서 바뀌기 때문에 이를 고려하여 UI를 디자인 해야 한다.
|
13
|
단수, 복수 표현의 차이
|
단수, 복수가 없는 언어도 있고 영어보다 훨씬 복잡한 단수, 복수를 사용하는 언어도 있다. 대표적인 것이 폴란드어이다. 메시징 기술은 이것을 지원해야 한다.
|
14
|
쓰기 방향의 차이
(오른쪽, 왼쪽)
|
언어 별로 쓰는 방향이 다르다.
|
15
|
커서의 이동 방향
(오른쪽, 왼쪽)
|
오른쪽 화살표를 눌러도 커서가 왼쪽으로 이동하는 언어도 있다.
|
16
|
키보드 글자 배치
|
언어별로 키보드의 글자배치가 다르다.
|
17
|
키보드의 단축키 차이
|
키보드에 따라서 단축키가 서로 다르다.
|
18
|
문자입력기(IME)차이
|
언어별로 문자입력기가 다르다.
|
19
|
폰트의 차이
|
언어별로 사용하는 폰트가 다르다. 서로 다른 폰트를 고려해야 한다.
|
20
|
글자의 크기 차이
|
언어별로 기본 글자의 크기가 다르다. 특히 중국어는 영어보다 크기가 크다.
|
21
|
숫자 표기 방법
|
나라별로 숫자의 표기가 다르다. 콤마(,)와 점(.)를 표시하는 방법이 다르다. 심지어는 콤마(,)대신 공백을 사용하는 나라도 있다.
|
22
|
띄어쓰기 사용의 차이
|
영어와 한글에 띄어쓰기가 있기 때문에 모든 언어에 띄어쓰기가 있을 것 같지만, 띄어쓰기가 아예 없는 언어도 많아서 띄어쓰기를 기준으로 단어를 분리하면 안된다.
|
23
|
쉼표, 마침표 사용의 차이
|
쉼표와 마침표의 사용도 언어마다 다르다.
|
24
|
날짜 표기법의 차이
|
01/02/03을 읽는 방법은 나라마다 다르다. 미국, 한국, 호주가 각각 다르다.
|
25
|
타임존 고려
|
국제화된 소프트웨어를 만들려면 타임존을 고려해야 한다.
|
26
|
썸머타임 고려
|
썸머타임을 고려해야 하는 나라가 있다.
|
27
|
대소문자 구분의 차이
|
언어마다 대소문자가 다르다. 대소문자가 없는 언어도 있다.
|
28
|
관사 사용법 차이
|
언어마다 관사가 다르다. 관사가 없는 나라도 있다.
|
29
|
맞춤법 검사 모듈
|
맞춤법 검사 기능이 있다면 국제화를 고려해야 한다.
|
30
|
사전 제공
|
사전을 제공한다면 국제화를 고려해야 한다.
|
31
|
정렬 방법의 차이
|
문자열의 순서가 언어마다 다르다. 대부분의 소프트웨어는 목록을 정렬해야 한다. 이때 국제화 기술을 적용해야 한다.
|
32
|
화폐 단위의 차이
|
지역별로 화폐의 단위 및 그 표기법이 다르다.
|
33
|
길이, 무게, 부피 단위 차이
|
지역별로 측정 단위가 다르다.
|
34
|
종이 크기의 차이
|
지역별로 인쇄에서 사용하는 용지의 명칭이 다르다.
|
35
|
온도 단위 차이
|
지역별로 사용하는 온도의 단위가 다르다.
|
36
|
주소 형식의 차이
|
지역별로 주소 표시 형식이 다르다.
|
37
|
전화번호 등의 현지화
|
소프트웨어에서 전화번호를 사용한다면 지역별로 다른 형식을 지원해야 한다.
|
38
|
이름 표기법의 차이
|
지역별로 이름 표기법이 다르다. 이름의 구성, 순서가 다르다.
|
39
|
현지 법률 및 제도 적용
|
현지 법률이나 제도와 표준을 지원해야 한다.
|
40
|
문화에 따른 아이콘의 차이
|
동일한 아이콘이라고 하더라도 문화에 따라서 완전히 다르게 인식할 수 있고 금기시 되는 이미지들도 있다.
|
41
|
알파벳을 형상화한 아이콘
|
아이콘 중에는 알파벳을 형상화 한 것들이 있는데 이는 언어에 따라서 바뀌어야 한다. 대표적인 것이 Bold 아이콘인 "B"이다. 언어에 따라서 Bold가 "B"로 시작하지 않는다.
|
42
|
텍스트를 포함한 아이콘
|
아이콘에 텍스트가 포함된 경우가 있다. 이때 텍스트의 길이 폰트의 크기 등을 고려해야 한다.
|
43
|
이모티콘 차이
|
나라별로 이모티콘이 다르고 지역화된 이모티콘도 있다.
|
44
|
색상의 의미 차이
|
나라별로 색상의 의미가 완전히 다르다. 선호 색상도 다르다.
|
45
|
O, X 등 기호의 차이
|
언어별로 기호의 의미는 천차만별이다. 우리에게 X는 틀렸다는 의미지만 영어에서는 Check라는 의미가 있다.
|
46
|
유니코드 처리
|
국제화된 소프트웨어를 개발하려면 유니코드는 기본이다. 누구나 다 아는 것도 유니코드이지만 유니코드를 제대로 알려면 1,2년 가지고는 모자르다.
|
47
|
외부 라이브러리의 유니코드 지원 고려
|
외부라이브러리들이 유니코드를 지원하지 않는 경우가 있다. 이를 고려해야 한다.
|
48
|
파일 시스템의 지원 인코딩
|
OS별로 파일 시스템의 인코딩이 서로 다르다. 이를 고려해야 한다.
|
49
|
멀티 Lingual 고려
|
하나의 소프트웨어로 수많은 언어를 동시에 지원하고 바꿀 수 있어야 한다.
|
여기에 모든 것을 다 나열한 것은 아니다. 하지만 이중에서 필요한 일부를 고려하지 않고 소프트웨어를 개발한다면 이것은 버그가 될 것이고 또는 해당 국가에서 보면 어색하고 기분 나뿐 소프트웨어가 될 수도 있다. 물론 소프트웨어의 종류에 따라서 국제화시 고려해야 하는 항목이 다르다. 따라서 위의 모든 것을 모든 프로젝트에서 고려해야 하는 것은 아니다. 한번씩은 생각해봐야 할 항목들이다.
좋은 소프트웨어를 가지고 비즈니스를 아무리 잘해도 국제화가 잘 안된 소프트웨어는 현지에서 성공하기 어렵다.
1~49번까지의 항목들이 제목만 본다고 쉽게 해결할 수 있는 것은 아니다. 하나의 항목을 가지고 10년 넘게 연구하고 개발하고 있는 것도 있을 정도로 크고 복잡한 것도 있다. 제대로 국제화를 적용하고 싶다면 국제화 전문가의 도움을 받는 것도 한 방법이다. 이것을 처음부터 제대로 하지 않고 시행착오를 거쳐서 고객이 버그를 찾을 때마다 하나씩 고쳐주는 것은 끝도 없고 제품의 이미지는 처음부터 추락할 것이다.
확실한 것은 국제화를 스스로 생각해서 직접 개발하면 잘못될 가능성이 99%이다. 대부분은 이미 국제 표준이나 기술이 있으므로 직접 개발하기보다는 제대로 완성된 기술을 이용해야 한다.
국제화 기술이 소프트웨어 해외 진출 필수임을 잊지 말자.
번역만 제대로 하는 것도 만만한 일이 아니던데, 저 목록은 "으악!"소리가 나올법하게 많은 내용을 담고 있군요...
답글삭제솔직히 여기서 나오는 용어의 대다수는 단순 역사전공자에겐 외계어입니다만
답글삭제하나의 프로세스를 수행하기 위해서,
또 내 홈그라운드가 아닌 곳에서 무엇을 생각해야 하나를 고민하게 해줍니다.
이런 기술적인 문제에 약하다보니 그저 황제 폐하께서 가라~! 하시니
백만대군이 갔다는 이야기 이상을 할 수가 없죠.
요 글은 좀 더 진득하게 읽어봐겠습니다.
15번에서, 오른쪽 화살표를 눌렀는데 왼쪽으로 가는 언어가 정말 있나요? osx에서 트랙패드의 스크롤 방향은 화면을 민다는 메타포라도 있지만, 키보드에서 물리적으로도 오른쪽에 위치한 오른쪽 화살표 키를 누르는데 커서가 왼쪽으로 간다는게 언뜻 이해가 가지 않습니다. 혹시 다른 종류의 키보드가 있을지도 모르고, 화살표의 의미가 반대인 문화권이 있을지도 모른다는 생각에 여러가지로 검색을 해봤는데, 그런 내용을 찾기가 힘들더군요.
답글삭제RGM-79님 안녕하세요.
답글삭제그래서 소프트웨어가 인류가 만든 지식 산업 중에서 가장 어렵다고 하나봅니다.
안녕하세요. kil9님
답글삭제아랍어는 오른쪽에서 왼쪽으로 쓰는 것은 아시지요? 그런데 영어나 대부분의 다른 언어는 왼쪽에서 오른쪽으로 씁니다. 그런데 아랍어와 영어를 혼합해서 쓸 수 있으므로 문제가 발생합니다.
그럴 때 아랍어에서는 커서가 거꾸로 진행합니다. 모든 Application이 이것을 지원하는 것은 아니고 MS Office는 지원합니다. 일반 텍스트 에디터는 지원하지 않습니다.
궁금하시면 파워포인트에 Helloمرحبا 를 입력한 후에 커서를 옮겨보세요. 재미 있는 현상이 벌어집니다. ^^
호환을 위해 많은 고민을 한 흔적이 보입니다.
주의사신님 안녕하세요.
답글삭제그래서 대충하거나 스스로 개발해서 적용해본다는 등의 시도는 거의 실패합니다.
언어 번역만 해서 될게 아니였군요. 여러가지 고려해야할 것들이 굉장히 많네요.
답글삭제좋은정보 주셔서 고맙습니다.
게중에는 쉬운것도 있지만 하나하나가 익히거나 해결하는데 시간이 꽤 걸립니다. 특히 번역 하나만 해도 기술, 프로세스 등 제대로하기는 매우 어렵습니다. 그래서 표준 기술을 써야하고 표준을 익혀야 합니다. 이 표준 기술을 제대로 익히는데는 몇년의 시간이 걸립니다. 그래서 국제화 전문가가 있는 것이지요.
답글삭제많은 스타트업들에게 도움이 될 것 같습니다. 잘 읽었습니다~
답글삭제