본문 바로가기

프로그래밍/API

(32)
luaL_call() 함수 구현 - 파라메터를 넣어 호출하는 방법에 대해~ 스크립터를 embed시켜 사용하는 경우, 가장 많이 사용하는 함수가 바로, 스크립터에 존재하는 함수를 C/C++에서 호출하는 경우이다. 이때, 문제가 생겼을때 traceback이 기본적으로 필요하게 되고, 여기에 여러개의 arg를 넘겨줘야 하는 경우 함수를 호출하기 위해 개발자의 수고가 필요하다. 다음 함수는 이러한 처리를 간단히 만들어 주는 역활을 하는 함수이다~ int luaL_pcall( lua_State *L, int f, int nargs) /* f arg1 arg2 ... argn */ { int base = lua_gettop( L) - nargs; /* arg1 arg2 ... argn */ switch (f) { default: if (!lua_isfunction( L, f)) break..
luaL_newthread() - gc를 피하는 방법~ lua의 state를 분리하는 함수중에 lua_newthread()라는 함수가 있다. 처음 lua를 접하는 개발자라면 이름만 보고, thread를 만들어 주는 함수로 이해하는 경우가 많다. 그러나, 해당 함수는 lua의 state를 만들어 주는 역활을 하기 때문이다. 문제는 해당 함수를 통해 만드는 state는 상위(parent)의 메모리 영역에 존재하기 때문에 parent의 state에서 gc가 발생될 경우 만들어진 state가 메모리에서 제거되어 오동작 하는 경우를 만나게 된다. 이때 사용하면 좋은 방식으로, lua가 만들어진 state를 강제로 gc하지 못하도록 하는 역활을 한다. lua_State *luaL_newthread( lua_State *L, int *pSave) { lua_State *..
luaL_namespace() - 독립된 namespace 생성... lua로 개발하다 보면 기본 namespace와 독립적인 공간이 필요할때가 있다. 즉, _G와 분리된 공간.. 아래 소스는 이러한 처리를 해 주는 소스로, _G와 독립된 namespace를 갖도록 만들어 준다. void luaL_namespace( lua_State *L) { lua_newtable( L); { /* T1: global */ lua_newtable( L); { /* T2: metatable */ lua_pushliteral( L, "__index"); { lua_pushvalue( L, LUA_GLOBALSINDEX); } lua_settable( L, -3); /* T2에 __index 항목을 추가한다. */ } lua_setmetatable( L, -2); /* T1를 metatabl..
luaL_renewtable() - 테이블 복제 가끔 lua 스크립터를 사용할때 table을 복제할 필요가 있다. 이때 사용하면 좋은 방법을 소개한다. // ti: 복제한 table이 위치한 stack 위치 int luaL_renewtable( lua_State *L, int ti) { lua_newtable( L); { int ni = lua_gettop( L); for ( lua_pushnil( L); lua_next( L, ti); lua_pop( L, 1)) { lua_pushvalue( L, -2); { /* key */ switch (lua_type( L, -2)) { default : lua_pushvalue( L, -2); break; /* value */ case LUA_TTABLE: luaL_renewtable( L, lua_gett..
Java에서 한글(EUC-KR 또는 UTF-8)을 자동 판단 하는 방법~ 웹과 같은 환경에서 외부로 부터 전달받은 한글문자열이 EUC-KR인지 UTF-8인지 판단이 필요할때 사용될수 있는 소스 입니다. 해당 소스는 자동으로 LocalString으로 변경해 줍니다. public static String LocalString( String val) { if (val == null) return null; else { byte[] b; try { b = val.getBytes("8859_1"); CharsetDecoder decoder = Charset.forName("UTF-8").newDecoder(); try { CharBuffer r = decoder.decode( ByteBuffer.wrap( b)); return r.toString(); } catch (Character..
javax.swing의 HTMLEditorKit를 사용한 HTML 파싱~ Java로 HTML를 파싱해야 할때가 가끔 존재한다. 이럴때 사용하면 유용한 소스를 소개한다. 해당 소스는 SWING에 포함되어 있으며, 여타 공개된 파서 이상의 기능을 제공한다. final StringBuffer plain = new StringBuffer(); HTMLEditorKit.Parser parser; parser = new ParserDelegator(); try { parser.parse( new StringReader( stringData), new HTMLEditorKit.ParserCallback() { public void handleText(char[] data, int pos) { // Text가 존재할때 호출된다. plain.append( data); plain.append(..
Windows플랫폼에서 사용가능한 Minidump Windows 플랫폼에서 개발된 프로그램에 문제가 발생되었을때 어떻게 할까? UNIX(Linux) 에서는 core 파일이 생성되어 debug에 사용될수 있다. 그런데, Windows에서는 상대적으로 이런 부분에 대해서는 별도의 제어가 필요하다. 다음의 코드는 Exception이 발생되었을때 간단히 사용할수 있는 Source이다. #include #include #include #include /////////////////////////////////////////////////////////////////////////////// // Minidump creation function // typedef BOOL (WINAPI *MINIDUMPWRITEDUMP)( HANDLE hProcess, DWORD..
리눅스 - 동적라이브러리를 독립 메모리 공간에 적재하기 리눅스는 동적라이브러리(.so)를 메모리에 적재하는 API를 제공한다. void * dlopen(const char *pathname, int mode); void * dlmopen(Lmid_t lmid, const char *pathname, int mode); 해당 함수는 윈도우의 DLL과 같은 동적 라이브러리를 loading 하는 용도로 사용되어 진다. 이 방법은 다음과 같은 경우에 사용되어 질때 매우 유용하다. - 싱글 CPU기반으로 개발된 엔진(전역 변수가 많다.. ㅠ.ㅠ) : 쓰레드에 사용가능한 구조가 아닌 경우에 사용할때 유용하다. 그러나, 단점은 기존의 동적 로딩 방식에 비해 메모리 사용이 두배라는 점이다. void * dlmopen( LM_ID_NEWLM, const char *pathn..