![]() |
AW: Probleme mit Datentypen bei einer DLL
Zitat:
Gruss McInternet |
AW: Probleme mit Datentypen bei einer DLL
Liegt dir nicht der Original export vor?
In dem Buch wird doch sicher irgendwie ein Beispiel oder sonstwas stehen, oder wenn sie von C++ kommt poste mal die Dekleration von dort. Das Ding ist nämlich, bei PAnsiChar's gibt es 2 Mögliche aufrufe. - Erstens du übergibst die Variable, wo der Pointer "gespeichert" bzw. hinterlegt wird. Die DLL legt ggf. den Speicher fest und übergibt dir den Pointer (Adresse); - Du musst einen Speicher festlegen. Dazu müsstest du die Größe wissen, also wie Lang der Text sein wird. Du legst den Speicher fest und übergibst die Variable an die Funktion. Diese schreibt in die Adresse die Daten. In deinem Fall würd ich auf das erste Tippen. Versuch mal folgendes:
Delphi-Quellcode:
So bei irgendeinem Wert muss er ja einen Text zurückgeben. Und alle Imports mal durchgehen mit diesem Code.
function xyzErrMsg(errorCode : Word): Pointer; stdcall; external xyzdll name 'ErrMsg';
//oder mal das function xyzErrMsg(errorCode : Word): Pointer; cdecl; external xyzdll name 'ErrMsg'; //oder mal einen von den Beiden function xyzErrMsg(const errorCode : Word): Pointer; stdcall; external xyzdll name 'ErrMsg'; function xyzErrMsg(const errorCode : Word): Pointer; cdecl; external xyzdll name 'ErrMsg'; //noch eine Möglich aber unwahrscheinlich function xyzErrMsg(var errorCode : Word): Pointer; stdcall; external xyzdll name 'ErrMsg'; function xyzErrMsg(var errorCode : Word): Pointer; cdecl; external xyzdll name 'ErrMsg'; //Bei allen Möglchkeiten lass das Pointer mal hintendran. var Meldung : PAnsiChar; P : Pointer; ErrorCode : Word; Begin for ErrorCode := 0 to High(Word) do begin P := xyzErrMsg(ErrorCode); If P <> nil then begin Meldung := P; //Setz mal hier ein Breakpoint ShowMessage(Meldung); end; end; EDIT: Sorry, überlesen, hast ja schon gesagt, dass es keine Doku oder sonstwas gibt. Das sie in C geschrieben ist, sollte einer der cdecl; oben vielleicht eher funken. Vielleicht Funkt dan irgendwas. Gruß NickelM |
AW: Probleme mit Datentypen bei einer DLL
CONST bringt bei Word nicht viel (ändert garnichts).
"ErrMsg" ... C++ baut gerne auch die Parametersignatur in den Exportnamen ein. Eventuell heißt es ja nicht "ErrMsg". ( ist das eigentlich CaseSensitiv? ) Statt Pointer kann man auch gleich PAnsiChar nehmen. PWideChar wird es mit großer Wahrscheinlichkeit nicht sein. Neben cdecl und stdcall gibt es noch ein paar Varianten mehr, aber Anderes hab ich hier auch noch nicht gesehn. (außer selten mal savecall und in Delphi natürlich pascal) |
AW: Probleme mit Datentypen bei einer DLL
@himitsu : Ich weis, wegen Pointer. Wollte nur mal gugen, ob sich der Pointer immer ändert, ob er ungleich nil ist und wenn der Pointer existiert, ich die Adresse dann erst übertrage.
Wenn es dan funkt mit irgendeinem Funktionsaufruf, kann man immernoch Pointer durch PAnsiChar ersetzten. Stimmt CONST bringt bei PWideChar,PAnsiChar oder sonstwo nur was, wenn sie als Paramter übergeben werden richtig? Was macht das dan eigentlich für einen Unterschied? Ich denke mal CONST bringt, das bei PAnsiChar,PWideChar z.b. der Text im Speicher der Funktion liegt und nicht die Adresse des Textes oder? @Thread : Was mir gerade einfällt, so beim schreiben grad, wegen dem Namen der Funktion. Ich kenn die Dll nicht vielleicht heist die Funktion ja "ErrMsgA". Zumindest ist es oft bei WinAPIs so. Neuere Dlls, so ab Win2000 haben dann eine "ErrMsgA" und eine "ErrMsgW". Das "A" steht für ANSI und das "W" für Wide also PWideChar. Das wären jetzt meine einizg letzen Ideen. Gruß NickelM |
AW: Probleme mit Datentypen bei einer DLL
Raten bringt hier nicht viel.
Entweder mit dem Debugger in die DLL-Funktion springen und sich den Code anschaun oder gleich die ganze DLL diassemblieren (Windasm o.ä.). |
AW: Probleme mit Datentypen bei einer DLL
Problem ist gelöst.
da ich in die dll definitiv nicht hereinschauen kann, habe ich eine eigene Fehlercodetable aufgebaut :oops: danke an alle für die Tipps. Gruss mc |
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:15 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz