2009/12/09

SQLite3.dll 만들기 (Win32 & x64 with VC++ 2005)

얼마전에도 SQLite3.dll 을 만드는 방법에 대한 글을 올린적이 있었는데 그 글을 토대로 만들어진 64 비트용 dll 파일을 사용해 보려 했는데 동작을 하지 않아서 다른 방법을 찾아서 다리 정리를 해 보았다.


이 방법은 이전 방법과 유사하지만 보다 간단하고 정상 독작하는 64비트용 dll 을 만들 수 있다. ^^*


우선 필요한 파일은 아래와 같다.

sqlite-amalgamation-3_6_21.zip

     - sqlite3.c

     - sqlite3.h

     - sqlite3ext.h


sqlitedll-3_6_21.zip

     - sqlite3.def


이 작업은 Visual C++ 2005 에서 작업을 하였다.


먼저 Win32 콘솔 프로젝트를 sqlite3 이름으로 생성한다.



프로젝트 생성시 아래와 같이 설정을 한다.



생성된 프로젝트 폴더에 sqlite-amalgamation-3_6_21.zip에 압축된 파일들 과 sqlitedll-3_6_21.zip에 압축된 파일 중 sqlite3.def 파일을 풀어 놓고 프로로젝트에 소스 파일들을 추가 한다.



그리고 전처리기 정의에 아래의 세가지를 추가한다.

SQLITE_ENABLE_FTS3

SQLITE_ENABLE_RTREE

SQLITE_ENABLE_COLUMN_METADATA



이를 추가 하지 않으면 아래와 같은 링크 에러가 발생한다.

1>fts3_tokenizer.obj : error LNK2005: _sqlite3_api이(가) fts3.obj에 이미 정의되어 있습니다.

1>rtree.obj : error LNK2005: _sqlite3_extension_init이(가) fts3.obj에 이미 정의되어 있습니다.

1>rtree.obj : error LNK2005: _sqlite3_api이(가) fts3.obj에 이미 정의되어 있습니다.

1>sqlite3.def : error LNK2001: sqlite3_column_database_name 외부 기호를 확인할 수 없습니다.

1>sqlite3.def : error LNK2001: sqlite3_column_database_name16 외부 기호를 확인할 수 없습니다.

1>sqlite3.def : error LNK2001: sqlite3_column_origin_name 외부 기호를 확인할 수 없습니다.

1>sqlite3.def : error LNK2001: sqlite3_column_origin_name16 외부 기호를 확인할 수 없습니다.

1>sqlite3.def : error LNK2001: sqlite3_column_table_name 외부 기호를 확인할 수 없습니다.

1>sqlite3.def : error LNK2001: sqlite3_column_table_name16 외부 기호를 확인할 수 없습니다.

1>sqlite3.def : error LNK2001: sqlite3_table_column_metadata 외부 기호를 확인할 수 없습니다.

1>D:\MyProject\VS\sqlite3\Debug\sqlite3.lib : fatal error LNK1120: 7개의 확인할 수 없는 외부 참조입니다.


마지막으로 sqlite3.lib 파일을 생성하기 위해 링크옵션의 모듈 정의 파일(Module Definition File)에 sqlite3.def 를 추가한다.



위와 같은 설정을 Debug 와 Release에 동일하게 해 주고 프로젝트를 빌드하면 Debug 및 Release 폴더에 dll 과 lib 파일을 볼 수 있다.


다음으로 64비트용을 작업한다.

먼저 64비트를 위핸 Configuration 을 추가한다.(Win32 설정으로부터 복사)







생성된 x64 Configuration 에서 전처리기 설정에서 WIN32를 WIN64로 변경한다. (Debug/Release 공통)



이제 빌드만 하면 된다

Original Post : http://neodreamer-dev.tistory.com/344

No comments :

Post a Comment