Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.11.19;
Скачать: CL | DM;

Вниз

Несрабатывает передача параметра с 1-го раза , почему?   Найти похожие ветки 

 
YOjik   (2006-10-11 15:49) [0]

В dll:
procedure Run_filter_inv_as_main_filter(App: HWnd ;OraSession: TOraSession; KeyField, Psevdonim: shortString; var SQLText: PChar); STDCALL;
begin
 Application.Handle := App;
 FrmMain_Filter_Investor := TFrmMain_Filter_Investor.Create(Application);
 try
   FrmMain_Filter_Investor.OraSession.AssignConnect(OraSession);
   FrmMain_Filter_Investor.FilterMode := fmMainFilter;
   FrmMain_Filter_Investor.Psevdonim := Psevdonim;
   FrmMain_Filter_Investor.SourceSQL := StrPas(SQLText);
   FrmMain_Filter_Investor.ShowModal;

   SQLText := PChar(FrmMain_Filter_Investor.SourceSQL + #0);
 finally
   FrmMain_Filter_Investor.Free;
 end;
end;


То есть возвращаю SQLText
В программе:
var
 sqlt: PChar;
 s: string;
begin
 s := OraQuery2.SQL.Text;
 sqlt :=  PChar(s + #0);
 Run_filter_inv_as_main_filter(Application.Handle, OraSession1, "SIK", "INV", sqlt);
 s := String(sqlt);
 Form1.OraQuery2.Close;
 Form1.OraQuery2.SQL.Text := s;
 Form1.OraQuery2.Open;
end;

В строчке   s := String(sqlt); возникает exception , а вот второй раз вызова всё нормально, пробовал StrPCopy, StrPas - не помогает, как лечить?


 
Desdechado ©   (2006-10-11 16:03) [1]

1. зачем var для SQLText: PChar ? это же и так указатель
2. не надо никаких нулей дописывать в конец, преобразование String - PChar - String и так нули вполне обрабатывает
3. зачем пытаться возвращать SQL ?
4. если уж пытаешься возвращать SQL, выдели память под него
5. в программе как описан прототип вызываемой из DLL функции?


 
Stanislav ©   (2006-10-11 16:04) [2]

Нужно SQLT задать размер.


 
YOjik   (2006-10-12 07:21) [3]

Спасибо ВАМ, дейстивительно надо было выделить память, а var и #0 в конце я писал так уже от безисходности ).



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

Текущий архив: 2006.11.19;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.036 c
15-1162262217
Mozart
2006-10-31 05:36
2006.11.19
Подскажите начинающему железячнику :)


15-1162403333
Ketmar
2006-11-01 20:48
2006.11.19
как молиться?


2-1162203111
Still Swamp
2006-10-30 13:11
2006.11.19
Как получиьт разницу времени локального и GMT


15-1162062209
lookin
2006-10-28 23:03
2006.11.19
Думаю, вы знаете, что когда () - меня немножко прет...


3-1158662881
SergP
2006-09-19 14:48
2006.11.19
Oracle и Port Mapping. Не могу подключиться...