197 lines
8.6 KiB
Plaintext
197 lines
8.6 KiB
Plaintext
1. 소개
|
|
|
|
Wine은 Microsoft Windows 프로그램(DOS, Windows 3.x, Win32 실행 파일
|
|
포함)을 유닉스 상에서 실행할 수 있게 해 주는 프로그램입니다. Wine은
|
|
Microsoft Windows 바이너리를 로드하고 실행하는 프로그램 로더와
|
|
Unix와 X11 API를 써서 Windows API를 구현한 라이브러리(Winelib)로
|
|
이루어져 있습니다. 이 라이브러리는 Win32 코드를 유닉스 실행 파일로
|
|
이식하는 용도로도 사용할 수 있습니다.
|
|
|
|
Wine은 자유 소프트웨어이며 GNU LGPL 하에 배포됩니다. 자세한 내용은
|
|
LICENSE 파일을 참조하십시오.
|
|
|
|
|
|
2. 간편 설치 및 실행
|
|
|
|
소스를 받아 컴파일하는 경우 Wine Installer를 이용하는 것이 좋습니다.
|
|
Wine 소스의 최상위 디렉토리에서 다음 명령을 실행합니다:
|
|
|
|
./tools/wineinstall
|
|
|
|
프로그램을 실행할 때는 "wine 프로그램명"처럼 합니다. 더 자세한 정보
|
|
및 문제 해결 방법은 이 파일의 나머지 부분과 Wine 맨페이지를 참조하십시오.
|
|
특히 https://www.winehq.org 사이트에 방대한 정보가 집약되어 있습니다.
|
|
|
|
|
|
3. 빌드에 필요한 조건
|
|
|
|
Wine을 컴파일하고 실행하려면 다음 중 하나가 필요합니다:
|
|
|
|
리눅스 2.0.36 또는 그 이상
|
|
FreeBSD 5.3 또는 그 이상
|
|
Solaris x86 2.5 또는 그 이상
|
|
NetBSD-current
|
|
Mac OS X 10.5 또는 그 이상
|
|
|
|
Wine을 실행하려면 커널 차원의 스레드 지원이 필요하기 때문에 현재는 여기
|
|
나열한 운영 체제만 지원합니다.
|
|
커널 스레드를 지원하는 기타 다른 운영 체제는 향후 지원할 예정입니다.
|
|
|
|
리눅스 정보:
|
|
리눅스 2.2.x에서는 잘 실행될 것이지만 리눅스 2.0.x에서는 실행될 수도
|
|
있고 그렇지 않을 수도 있습니다(초기 2.0.x 버전에서는 스레드 관련 문제로
|
|
프로그램이 죽음). 가급적 2.4.x와 2.6.x 같은 최근 커널을 사용하기
|
|
바랍니다.
|
|
|
|
FreeBSD 정보:
|
|
FreeBSD 4.x 및 5.x에서 빌드되지만 FreeBSD 5.3 이전 버전에선 제대로
|
|
동작하지 않습니다.
|
|
|
|
더 자세한 정보는
|
|
<ftp://ftp.freebsd.org/pub/FreeBSD/ports/ports/emulators/wine/>
|
|
에 있는 FreeBSD ports 페이지를 참조하십시오.
|
|
|
|
Solaris 정보:
|
|
거의 대부분의 경우 Wine을 빌드하려면 GNU 툴체인(gcc, gas 등)을 사용해야
|
|
합니다. 경고: gas를 단순히 설치하기만 하면 gcc에서 사용되지 않을 수도
|
|
있습니다. gas를 설치한 다음 gcc를 재컴파일하거나 cc, as, ld 명령을
|
|
GNU 바이너리로 심볼 링크를 걸어 주는 일이 필요하다고 합니다.
|
|
|
|
NetBSD 정보:
|
|
USER_LDT, SYSVSHM, SYSVSEM, SYSVMSG 옵션이 커널에 포함되어 있어야 합니다.
|
|
|
|
Mac OS X 정보:
|
|
x86 머신에서 빌드하려면 Xcode 2.4 또는 그 이상이 필요합니다.
|
|
|
|
|
|
지원되는 파일 시스템:
|
|
Wine은 대부분의 파일 시스템에서 문제없이 실행됩니다. 그렇지만 /tmp
|
|
디렉토리가 umsdos 타입으로 마운트된 경우에는 프로그램이 실행되지
|
|
않습니다. Samba를 이용해서 파일을 액세스하는 경우 몇 가지 호환성
|
|
문제가 보고되기도 했습니다. 또한 NTFS는 현재 디스크 기록시 안정성이
|
|
보장되어 있지 않습니다. Windows 프로그램은 대부분 디스크 어딘가에
|
|
데이터를 기록하므로 NTFS는 가급적 사용하지 않는 것이 좋습니다. NTFS
|
|
파일의 경우 쓰기 가능한 위치로 복사한 다음 사용하시기 바랍니다.
|
|
|
|
필수 구성 요소:
|
|
X11 개발용 헤더 파일이 설치되어 있어야 합니다(데비안에서는 xlib6g-dev,
|
|
레드햇에서는 XFree86-devel이란 패키지명으로 되어 있음).
|
|
|
|
필수 빌드 도구:
|
|
x86 시스템에서는 gcc 2.7.2 이상이 필요합니다.
|
|
2.7.2.3 이전 버전은 최적화 옵션을 켜고 컴파일하면 몇몇 파일에서 문제가
|
|
발생할 수 있는데, 대부분 헤더 파일 관리와 관련된 문제로 인한 것들입니다.
|
|
|
|
"make" 프로그램은 당연히 필수입니다(거의 대부분 GNU make 사용).
|
|
|
|
flex 버전 2.5 이상과 bison이 필요합니다.
|
|
|
|
선택적 라이브러리:
|
|
포함 여부의 선택이 가능한 라이브러리는 ./configure --verbose 명령으로
|
|
확인할 수 있습니다.
|
|
|
|
|
|
4. 컴파일하기
|
|
|
|
wineinstall을 사용하지 않는 경우 다음 명령을 써서 Wine을 빌드합니다:
|
|
|
|
./configure
|
|
make depend
|
|
make
|
|
|
|
이렇게 하면 "wine" 프로그램과 다수의 라이브러리/바이너리가 빌드됩니다.
|
|
"wine" 프로그램은 Windows 실행 파일을 로드하고 실행하는 데 사용됩니다.
|
|
"libwine" 라이브러리("Winelib")는 Windows 소스 코드를 유닉스 상에서
|
|
컴파일하고 링크하는 용도로 사용할 수 있습니다.
|
|
|
|
컴파일 설정 옵션을 보려면 ./configure --help 명령을 사용합니다.
|
|
|
|
패치 파일을 써서 새 릴리스로 업그레이드하려면 먼저 릴리스의 최상위
|
|
디렉토리(README 파일이 들어 있는 디렉토리)로 갑니다. 그런 다음
|
|
"make clean" 명령을 실행하고 아래 명령으로 소스를 패치합니다:
|
|
|
|
bunzip2 -c patch-file | patch -p1
|
|
|
|
"patch-file"은 패치 파일의 이름입니다(wine-0.9.x.diff.bz2 등의 형태).
|
|
패치한 다음에는 "./configure", "make depend && make"를 차례로
|
|
실행하면 됩니다.
|
|
|
|
|
|
5. 설정
|
|
|
|
Wine이 일단 정상적으로 빌드된 다음에는 "make install" 명령으로
|
|
실행 파일과 맨페이지, 기타 필요한 파일을 시스템에 설치할 수 있습니다.
|
|
|
|
설치하기 전 이전 버전의 Wine을 제거해야 한다는 점을 잊지 마시기
|
|
바랍니다. "dpkg -r wine" 또는 "rpm -e wine" 또는 "make uninstall" 등의
|
|
명령으로 이전 버전을 제거할 수 있습니다.
|
|
|
|
설정 관련 도움말은 https://www.winehq.org/의 Support 페이지에 있습니다.
|
|
|
|
라이브러리 로딩 에러("Error while loading shared libraries: libntdll.so")가
|
|
발생하는 경우 라이브러리 경로가 /etc/ld.so.conf 파일 안에 지정되어 있는지
|
|
확인한 다음 root 권한으로 ldconfig를 실행하십시오.
|
|
|
|
|
|
6. 프로그램 실행
|
|
|
|
Wine을 실행할 때 실행 파일의 전체 경로를 지정할 수도 있고 파일명만 지정할
|
|
수도 있습니다.
|
|
|
|
예를 들어 카드놀이를 실행하려면:
|
|
|
|
wine sol (파일을 찾기 위해 설정 파일에 지정된
|
|
wine sol.exe 검색 경로를 이용)
|
|
|
|
wine c:\\windows\\sol.exe (DOS 파일명 문법을 이용)
|
|
|
|
wine /usr/windows/sol.exe (유닉스 파일명 문법을 이용)
|
|
|
|
wine sol.exe /parameter1 -parameter2 parameter3
|
|
(프로그램을 호출할 때 파라미터를 넘겨줌)
|
|
|
|
Wine은 아직 완성 단계에 도달하지 못했기 때문에 프로그램이 제대로 실행되지
|
|
않을 수 있습니다. 프로그램이 죽는 경우 문제를 분석하고 수정할 수 있도록
|
|
디버그 모드로 자동 진입됩니다. 자세한 디버깅 방법은 Wine 개발자 가이드의
|
|
디버깅 섹션을 참조하시기 바랍니다.
|
|
|
|
|
|
7. 더 자세한 정보
|
|
|
|
WWW: 여러 종류의 Wine 가이드, 애플리케이션 데이터베이스, 버그 추적 등
|
|
https://www.winehq.org/ 에 있는 WineHQ 사이트에 가면 많은 정보를 얻을
|
|
수 있습니다. 정보를 찾을 때 대개 이 사이트가 출발점이 됩니다.
|
|
|
|
FAQ: Wine FAQ은 https://www.winehq.org/FAQ 에 있습니다.
|
|
|
|
Usenet: Wine 관련 주제를 논의하거나 도움을 받으려면 comp.emulators.ms-windows.wine
|
|
그룹을 이용하기 바랍니다.
|
|
|
|
Bugs: https://bugs.winehq.org 의 Wine Bugzilla에 버그를 보고하십시오.
|
|
버그 보고서를 제출하기 전 같은 문제가 이미 제출된 적이 있는지
|
|
데이터베이스 검색을 통해 확인하기 바랍니다.
|
|
comp.emulators.ms-windows.wine 그룹에 버그 보고서를 올려도 됩니다.
|
|
|
|
IRC: irc.freenode.net 의 #WineHQ 채널에서 도움을 받을 수 있습니다.
|
|
|
|
GIT: Wine 개발 트리는 현재 GIT로 관리되고 있습니다. 더 자세한 정보는
|
|
https://www.winehq.org/site/git 를 참조하기 바랍니다.
|
|
|
|
메일링 리스트:
|
|
Wine 사용자와 개발자를 위해 메일링 리스트가 운영되고 있습니다.
|
|
더 자세한 정보는 https://www.winehq.org/forums 를 참조하기 바랍니다.
|
|
|
|
위키: Wine 위키는 https://wiki.winehq.org 에 있습니다.
|
|
|
|
추가할 내용이나 수정할 버그가 있다면 다음번 릴리스에 포함될 수 있도록
|
|
wine-devel@winehq.org 메일링 리스트로 패치('diff -u' 형식으로 된)를 보내
|
|
주시기 바랍니다.
|
|
|
|
--
|
|
Alexandre Julliard
|
|
julliard@winehq.org
|
|
|
|
Translated into Korean by
|
|
Bang Jun-Young
|
|
junyoung@mogua.com
|