Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2005.01.23;
Скачать: [xml.tar.bz2];

Вниз

UDF для Firebird со строчными параметрами   Найти похожие ветки 

 
DSKalugin ©   (2004-12-17 19:49) [0]


library my_udf;

uses StrUtils,SysUtils;

function ClearSkladCod(var vsCod: PChar):PChar; stdcall; export;
const ClearChars=["0".."9","A".."Z"];
var ns:pchar;
   t:ShortString;
   i,j:Byte;
begin
 t:="";
 getmem(ns,30);
 StrCopy(ns,AnsiStrUpper(vsCod));
 j:=Length(ns);
 for i:=0 to j-1 do
   if (ns[i] in ClearChars)
     then t:=t+ns[i];
 freemem(ns);
 StrPCopy(Result,t);
end;

exports
 ClearSkladCod;

begin
 IsMultiThread:=True;
end.
-----------------------------------
DECLARE EXTERNAL FUNCTION ClearSkladCod
   CSTRING(30)
   RETURNS CSTRING(30) FREE_IT
   ENTRY_POINT "ClearSkladCod"  MODULE_NAME "my_udf";

при вызове в IBExpert выдает ошибку AV и разрывает соединение
В чем ошибка?


 
Johnmen ©   (2004-12-17 23:08) [1]

Глянь здесь
http://www.realcoding.net/part.php?id=1579
и см. на ibase.ru, там много материала...


 
jack128 ©   (2004-12-18 00:21) [2]

предирка к статье. Вообще говоря malloc нужно импортировать из ib_util.dll/функция ib_util_malloc


 
DSKalugin ©   (2004-12-18 16:58) [3]

2 Johnmen
Спасибо за линк, я интуитивно сам понимал, что надо как-то выделять память под результат. Но не знал как. На "ибасе" все перерыл перед тем как сюда написать

2 jack128
ок буду пробовать ib_util_malloc
а синтаксис какой ?


 
DrPass ©   (2004-12-18 20:44) [4]

А почему stdcall? IB вроде как использует соглашение cdecl



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2005.01.23;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.063 c
1-1104406951
den303
2004-12-30 14:42
2005.01.23
TButton+Glyph


1-1104981919
-[ HAWK ]-
2005-01-06 06:25
2005.01.23
как заморозить значение


11-1086458896
DillerXX
2004-06-05 22:08
2005.01.23
Почему в конечном файле не работает хот кей?


4-1102348467
Sirus
2004-12-06 18:54
2005.01.23
Возможно ли отловить сохранение изменений в реестре Windows?


1-1105050080
Colonel
2005-01-07 01:21
2005.01.23
Фокус формы, события OnMouseEnter, Leave





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский