기본 콘텐츠로 건너뛰기

iOS: 오픈소스 라이브러리를 iOS에서 활용하기

Linux 개발자라면 누구나 오픈소스 라이브러리를 활용하여 S/W를 개발하게 된다. 훌륭한 라이브러리가 많으므로 이를 iOS 프로그램 개발에도 이용할 수 있다면 좋을 것이다.

Apple이 제공하는 문서 중 Unix 개발 환경에서 Mac OS X으로 전향 시 도움을 주기 위한 가이드는 존재하는데 GNU Build를 사용한 오픈소스 라이브러리를 iOS용으로 사용하는 방법에 대한 문서는 없다.

그래서, 구글에서 관련 자료를 검색하여 실행한 방법을 블로그에 정리해두고자 한다. 참고로 개발 환경은 iOS SDK v5.1과 Xcode 4.3.1을 사용하였다. 이전 버전이나 추후 버전에서는 문제가 있을 수도 있음을 미리 공지한다.

1. Open Source 라이브러리 얻기
XML 파싱을 위해 expat 라이브러리를 iOS 프로그램에 사용하고 싶다고 가정하자. (물론, iOS SDK에 이미 XML 라이브러리가 존재하므로 굳이 왜 이걸 쓸 필요가 있을까 싶지만 다른 오픈소스를 활용 시 expat에 의존하고 있다면 그대로 이 라이브러리를 사용하는 것이 편리할 것이다.)
우선, expat 라이브러리의 소스 코드를 Mac 컴퓨터에 다운로드 받아야 한다. 웹 페이지에서 가능하지만 wget을 쓰면 terminal에서 다운로드 받을 수 있다. (Mac OS X에 wget을 설치하는 방법에 대해서는 내가 작성한 기존 블로그 글 참고)
  • wget http://downloads.sourceforge.net/expat/expat-2.0.1.tar.gz

다운로드 받은 소스는 tar로 압축을 푼다.
  • tar xvf expat-2.0.1.tar.gz

현재 폴더에 expat-2.0.1 이라는 폴더가 생성되었을 것이다.

2. iOS 개발 환경에 맞게 configuration 하기
GNU Build를 사용한 오픈소스 라이브러리를 빌드하는 방법은 아주 쉽다. 다음과 같은 순서로 명령을 실행해주면 대부분 문제 없이 빌드되고 설치된다.
  • ./configure
  • make
  • sudo make install
위 절차가 어떤 방식으로 이루어지는지에 대한 내용은 GNU의 Automake 문서를 참고하기 바란다.
./configure를 실행 시 iOS 환경에 맞춤 설정을 하기 위해서 적절한 인자값을 지정해 주어야 한다. 예를 들면, iOS를 위한 컴파일러를 지정해 주는 등의 설정 값을 알려주어야 할 것이다. 이를 위해 아래와 같은 shell script를 사용한다. 

----
unset CPATH
unset C_INCLUDE_PATH
unset CPLUS_INCLUDE_PATH
unset OBJC_INCLUDE_PATH
unset LIBS
unset DYLD_FALLBACK_LIBRARY_PATH
unset DYLD_FALLBACK_FRAMEWORK_PATH

TARGET=arm-apple-darwin10
HOST=i386-apple-darwin11.3.0
PLATFORM=iPhoneOS
ARCH=armv7
# For iOS Simulator Configuration
# PLATFORM=iPhoneSimulator
# ARCH=i386

export XCODE_ROOT="/Applications/Xcode.app/Contents"
export BUILD_DARWIN_VER=`uname -r`
export SDKVER="5.1"
export DEVROOT="$XCODE_ROOT/Developer/Platforms/$PLATFORM.platform/Developer"
export SDKROOT="$DEVROOT/SDKs/$PLATFORM$SDKVER.sdk"
export PKG_CONFIG_PATH=$DEVROOT/SDKs/$PLATFORM$SDKVER.sdk/usr/lib/pkgconfig:$DEVROOT/usr/lib/pkgconfig:/opt/iphone-$SDKVER/lib/pkgconfig:/usr/local/iphone-$SDKVER/lib/pkgconfig
export PREFIX="/opt/iphone-$SDKVER"
export AS="$DEVROOT/usr/bin/as"
export ASCPP="$DEVROOT/usr/bin/as"
export AR="$DEVROOT/usr/bin/ar"
export RANLIB="$DEVROOT/usr/bin/ranlib"
export CPPFLAGS="-pipe -no-cpp-precomp -I$SDKROOT/usr/lib/gcc/$TARGET/4.2.1/include/ -I$SDKROOT/usr/include -I$DEVROOT/usr/include -I/opt/iphone-$SDKVER/include -I/usr/local/iphone-$SDKVER/include"
export CFLAGS="-std=c99 -arch $ARCH -pipe -no-cpp-precomp --sysroot='$SDKROOT' -isystem $SDKROOT/usr/lib/gcc/$TARGET/4.2.1/include/ -isystem $SDKROOT/usr/include -isystem $DEVROOT/usr/include -isystem /opt/iphone-$SDKVER/include -isystem /usr/local/iphone-$SDKVER/include"
export CXXFLAGS="-std=c99 -arch $ARCH -pipe -no-cpp-precomp --sysroot='$SDKROOT' -isystem $SDKROOT/usr/lib/gcc/$TARGET/4.2.1/include/ -isystem $SDKROOT/usr/include -isystem $DEVROOT/usr/include -isystem /opt/iphone-$SDKVER/include -isystem /usr/local/iphone-$SDKVER/include"
export LDFLAGS="-arch $ARCH --sysroot='$SDKROOT' -L$SDKROOT/usr/lib -L$DEVROOT/usr/lib -L$SDKROOT/usr/lib/system"
export CPP="$DEVROOT/usr/bin/llvm-cpp-4.2"
export CXXCPP="$DEVROOT/usr/bin/llvm-cpp-4.2"
export CC="$DEVROOT/usr/bin/gcc"
export CXX="$DEVROOT/usr/bin/g++"
export LD="$DEVROOT/usr/bin/ld"
export STRIP="$DEVROOT/usr/bin/strip"

if [ ! \( -d "$DEVROOT" \) ] ; then
   echo "The iPhone SDK could not be found. Folder \"$DEVROOT\" does not exist."
   exit 1
fi
----

위 Shell Script를 expat 소스 폴더 안에 ios_configure.sh와 같은 파일로 만들어 준다. (물론 shell script로 실행이 가능해야 하므로 chmod +x ios_configure.sh를 해주어야 할 것이다.)

이 Shell Script를 실행한다. (iPhone Simulator를 사용하는 경우에는 위 코드에서 PLATFORM과 ARCH 변수를 주석 처리된 부분을 살려서 사용하고 iPhoneOS, armv7 부분을 주석으로 막아준다.)
  • ./ios_configure.sh
정상적으로 실행이 끝나면 Makefile이 생성되어진다. (혹시 에러가 발생하는 경우는 config.log를 보고 문제를 해결해주어야 한다.)

3. 빌드하기
이제 configuration이 끝난 소스를 빌드해보도록 한다.
  • make
정상적으로 빌드가 완료되면 개발에 필요한 library 및 header를 추리기 위해 설치를 해보자.
  • make DESTDIR=./dist install
위와 같이 실행하면 현재 폴더에 dist 폴더가 생성되고 그 안에 개발에 필요한 library 및 header 파일들이 모두 복사된다.

4. Xcode에서 Library 사용하기
개발할 iOS 프로그램에서 expat 라이브러리를 사용하는 방법에 대해 살펴보자. Xcode를 실행 한 후 iPhone용 Single View Application을 생성한다.

Target의 Summary에서 expat 라이브러리를 추가해준다. 아래 그림을 보면 Linked Frameworks and Libraries 섹션 아래 쪽에 + 기호가 보인다. 이를 선택하면 화면 그림과 같이 추가할 프레임워크 혹은 라이브러리를 선택하는 팝업창이 뜬다. 이 창에서 Add Other... 버튼을 선택하여 우리가 빌드한 expat 라이브러리를 선택한다. (참고로 위 경우는 ./dist/opt/iphone-5.1/lib/libexpat.a 파일)


코드 작성 시 필요한 헤더 파일의 경로도 지정해주어야 한다. Target의 Build Settings에서 search로 검색하면 User Header Search Paths라는 항목이 나온다. 여기에 /workspace/expat-2.0.1/build_ios_simul/dist/opt/iphone-5.1/include 와 같이 expat 라이브러리의 헤더 파일이 위치한 경로를 입력한다.

5. Test Code 작성 및 실행

#import "ViewController.h"
#include "expat.h"

@interface ViewController ()

@end

static char* sample_xml = "<note> \
<to>Tove</to> \
<from>Jani</from> \
<heading>Reminder</heading> \
<body>Dont forget me this weekend!</body> \
</note>";

static void
start(void *data, const char *el, const char **attr)
{
    NSLog(@"elem = %s", el);
}  /* End of start handler */

static void
end(void *data, const char *el) 
{
}  /* End of end handler */

@implementation ViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    
    XML_Parser p = XML_ParserCreate(NULL);    
    XML_SetElementHandler(p, start, end);
    XML_Parse(p, sample_xml, strlen(sample_xml), 1);
}

- (void)viewDidUnload
{
    [super viewDidUnload];
    // Release any retained subviews of the main view.
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return (interfaceOrientation != UIInterfaceOrientationPortraitUpsideDown);
}

@end


위와 같이 ViewController.m 파일에 코드를 작성해서 expat 라이브러리를 이용한 어플리케이션을 간단히 만들어보자. 위 코드가 실행되면 output에 로그로 XML element들이 출력될 것이다.

References:


댓글

  1. 감사합니다. 덕분에 좋은 정보 얻어갑니다.

    답글삭제
  2. 덕분에 좋은 정보 얻어갑니다. 정말 고맙습니다.

    답글삭제

댓글 쓰기

이 블로그의 인기 게시물

Wireless: HotSpot 2.0 이란?

스마트폰 사용자가 HotSpot 2.0을 지원하는 Wi-Fi 망을 사용하는 경우라면 기존 Wi-Fi 망과 달리 이동통신 망에서 Wi-Fi 망으로의 네트워크 연결 전환이 자연스럽게 이루어진다. 예를 들면, 3G 네트워크를 이용하여 영화를 보고 있다가 HotSpot 2.0 네트워크에 연결이 가능하게 되면 영화 시청 중단 없이 Wi-Fi 망으로 자연스럽게 네트워크 연결이 이동하여 3G 망의 부하도 줄이고 사용자의 네트워크 비용도 절약할 수 있다. 시스코에서 제공한 White Paper 를 참고.

Java: Java for Game? Java가 Game 개발에 어울릴까?

Java가 기업용 서버 소프트웨어 개발에 활발하게 쓰이는 것과 달리 일반 응용프로그램 분야에서는 별로 대접을 받지 못하는 현실을 개선하려면 어떤 분야부터 손보면 좋을까? 로딩타임, 성능, 사용자 인터페이스 등 Java를 이용한 클라이언트 프로그램을 개발하지 않는 이유들은 개발자 별로 서로 다를 것이다. 하지만, 이런 단점에도 불구하고 점점 복잡해지는 소프트웨어를 더 쉽게 다양한 환경에서 동작하도록 만들기 위해서는 Java만큼 이미 성숙한 해결책도 없지 않은가? 클라이언트 개발을 활성화하기 위해 Java를 게임 개발에 활용할 수 있도록 지원하면 어떨까? 역시, 사용자가 직접 쓰는 응용프로그램 중에는 게임이 가장 시장이 큰 분야이니 말이다. 그렇다면, 현재 게임 개발에 Java가 어느 정도 사용되고 있고 미래에 더 활성화 될 가능성은 있을 것인가? 이런 의문점을 가지고 "Java + Game"에 대해 조사해보기로 했다. 1. Java로 개발한 게임들 우선, Java로 개발한 게임들에 대해 살펴보자. Oracle의  Java in Action 웹페이지 를 보면 Java를 이용한 3D MMORPG RuneScape 에 대한 설명이 있다. 가입자가 1억 3000만명이 넘는다고 하다. 실제 게임을 설치해서 실행해보니 WOW같은 화려한 그래픽에는 못미치치만 잘만든 Role Playing 게임이다 Puppy Games 에서 개발한  Revenge of the Titans 게임도 눈여겨 볼 만하다. 이 회사는 작고 손쉽게 즐길 수 있는 게임을 개발하는데 모든 게임을 Java로 만든다. Revenge of the Titans는 Starcraft와 같은 전략 게임으로 너무 머리쓰지 않고 즐길 수 있는 게임이며 그래픽도 신선하다. 개발이 진행 중인 것으로 보이는 Urban Galaxy 라는 게임도 재미있을 것 같다. SF 영화를 보면 자주 등장하는 미래의 빌딩 숲을 날아다니는 자동차로 전투도 치르고 무역도 하며 캐릭터를 키우는 게임으로

Apple M1 Mac Mini에서 이더리움 (Ethereum) 채굴하기

 돈을 벌 목적은 아니고 이더리움 기술에 대한 호기심에 직접 채굴(마이닝)에 나서 보기로 했다. 머신은 Apple M1 Mac Mini. 스팩을 살펴보니 8 Core GPU에 16GB 메모리를 공유하고 있어 가능은 해보인다. 큰 흐름은 다음과 같다. 채굴한 이더리움을 저장할 지갑을 만든다 만든 지갑의 정보를 잘 보관해둔다 (Secret Recovery Phrase, 지갑의 주소 값) Apple M1용 채굴 프로그램 설치 내 지갑 정보를 이용해서 채굴 프로그램 실행 일단, 채굴한 이더리움을 저장할 지갑(wallet)을 만들어야 한다.  크롬 브라우저 익스텐션 설치로 비교적 간단하게 지갑을 만들 수 있는  https://metamask.io/ 를 이용하기로 했다. 크롬 익스텐션을 설치 후 기존에 만든 지갑이 없으므로 "Create a Wallet"을 선택한다. 패스워드 입력하고 등등의 절차를 거치면 아래와 같은 Secret Recovery Phrase가 나온다. 이 값을 잘 보관해두기 바란다. 나중에 지갑을 복구할 때 필요한 값이다. 이 값이 유출되면 지갑에 모아둔 이더리움을 다 털릴 수 있으므로 안전한 곳에 보관한다. Confirm Your Secret Phrase에서 확인 과정을 거친다. 직접 입력하는 것이 아니라 단어 별 버튼을 일일이 클릭해서 확인해주어야 한다. (좀 번거롭지만 그만큼 Secret Recovery Phrase가 중요함을 인지시키기 위한 과정이다.) 이제 지갑은 준비 완료. 생성된 Account 화면에서 지갑의 주소갑을 얻을 수 있다.  Apple M1용 채굴 프로그램을 설치해보자. Ethminer M1 Github 프로젝트 에서 미리 컴파일된 바이너리를 다운로드 받는다. (Assets를 펼치고 ethminer-m1을 클릭해서 다운 받으면 된다) 원하는 폴더에 파일을 옮겨 놓고 Terminal에서 chmod +x로 실행가능하게 만든다. % mv ~/Downloads/ethminer-m1 .             %   % c