파이어버드용 UDF는 cdecl로 선언해야하는 걸로 알고 있어요
letsgolee 님이 쓰신 글 :
:
http://www.firebirdsql.org/en/writing-udfs-for-interbase/ 를 참조해보면 파라미터 값에 정수가 바로 오는 것이 아니라 포인터를 이용하고 있습니다. 고수분들이 다 어디가셨나? 답변이 왜 없데...
:
: NeoDreamer 님이 쓰신 글 :
: : UDF 작성을 테스트 해 보고 있는데 아주 간단하게 만들어서 동작을 테스트 하고 있습니다.
: : UDF 등록과 실행은 문제가 없는데 반환값이 이상입니다.
: :
: : UDF 는 아래와 같이 간단하게 만들고
: : extern "C" __declspec(dllexport) int i_mul( int a, int b )
: : {
: : return (a * b);
: : }
: :
: : extern "C" __declspec(dllexport) double pi()
: : {
: : return 3.141592;
: : }
: :
: : Firebird 서버에 등록을 하였습니다.
: : DECLARE EXTERNAL FUNCTION i_mul
: : INTEGER, INTEGER
: : RETURNS INTEGER BY VALUE
: : ENTRY_POINT 'i_mul' MODULE_NAME 'MyUDF';
: :
: : DECLARE EXTERNAL FUNCTION pi
: : RETURNS DOUBLE PRECISION BY VALUE
: : ENTRY_POINT 'pi' MODULE_NAME 'MyUDF';
: :
: : 그리고 실행을 해 보았는데.
: : select i_mul(10, 4) from rdb$database;
: :
: : 결과가 원하는 값이 나오지 않고 엉뚱 한 값(870368256)이 반환 됩니다.
: : 매개변수가 없는 경우는 정상적인 반환값을 전달 하여 줍니다.
: :
: : UDF를 위한 DLL 작성이나 등록을 하기위한 특별한 방법(필수 요건, 제약조건 등등)이 있나요?
: :
: :