AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein lpfnHook absturz als eigenständige exe
Thema durchsuchen
Ansicht
Themen-Optionen

lpfnHook absturz als eigenständige exe

Ein Thema von EWeiss · begonnen am 29. Sep 2016 · letzter Beitrag vom 2. Okt 2016
Antwort Antwort
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.869 Beiträge
 
Delphi 12 Athens
 
#1

AW: lpfnHook absturz als eigenständige exe

  Alt 29. Sep 2016, 08:58
MadExcept und Eurekalog können gute Fehlerlogs dazu erzeugen. Ein solches Log kannst du natürlich gerne hier anhängen, wenn du dort nichts sehen solltest.

Außerdem kannst du FastMM einbinden, denn wenn es wirklich ein Problem bei der Freigabe eines Objekts gibt, sollte das dort gemeldet werden.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#2

AW: lpfnHook absturz als eigenständige exe

  Alt 29. Sep 2016, 20:24
Zitat:
Eurekalog können gute Fehlerlogs dazu erzeugen
Das schon mal nicht
Kommt anscheinend mit Nonvcl nicht zurecht.

Die Anwendung stürzt ab keine Meldung die Anwendung hängt keine Meldung nichts.
MadExcept das gleiche keine Meldung nix.

Die einzige Meldung die ich bekomme ist diese im Anhang.
Damit kann ich aber im Moment mal leben.

gruss

Geändert von EWeiss (11. Jul 2019 um 16:45 Uhr)
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: lpfnHook absturz als eigenständige exe

  Alt 29. Sep 2016, 23:02
Hallo,
tja, doof

Hast du Units mit finalization-Code ?

Wenn ja, muss du das halt per
- MessageBox
- Log-File debuggen
Heiko
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#4

AW: lpfnHook absturz als eigenständige exe

  Alt 30. Sep 2016, 08:08
Hast du Units mit finalization-Code ? yep eine.
Das Problem ist nur wenn ich debugge beim beenden der Anwendung geht er nicht
in die finalization dieser Unit hinein.

gruss
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#5

AW: lpfnHook absturz als eigenständige exe

  Alt 30. Sep 2016, 22:59
Hmmm habe das Problem gefunden zumindest schon mal eins.

An die Leute die es vielleicht wissen.
Ich habe zu meiner OpenSaveFileDialog function die variable SkinConfig noch mit eingebaut so kann man von außen den Pfad zum aktuellen Skin übergeben.

Delphi-Quellcode:
function OpenSaveFileDialog(SkinConfig: string; ParentHandle: THandle; const DefExt, Filter, InitialDir,
  Title: WideString; var FileName: WideString; IsOpenDialog: Boolean): Boolean;
var
  ofn: TOpenFilename;
  szFile: array [0 .. MAX_PATH] of Char;
begin
  Result := False;
  //SkinConfigFile := SkinConfig;

  FillChar(ofn, SizeOf(TOpenFilename), 0);
  with ofn do
  begin..

Sobald ich jetzt

//SkinConfigFile := SkinConfig;

aktiviere. Also aus kommentiere stürzt die Anwendung als eigenständige EXE ab.

Warum ?
Habe ich noch nie erlebt.
Wohlbemerkt der NORMALE Dialog ohne irgendeine Veränderung mit und ohne Hook.

Die Funktion "OpenSaveFileDialog" kann ich doch benennen und ändern wie ich will da diese keinen Bezug zu TOpenFilename hat
also dementsprechend auch den Sitz davon nicht verändert.
Trotzdem kracht es. Hab jetzt 2 Tage gebraucht um den Mist zu finden.
Keiner der Fehlerreport Tools konnte das ausmachen.

gruss

Geändert von EWeiss (30. Sep 2016 um 23:07 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#6

AW: lpfnHook absturz als eigenständige exe

  Alt 1. Okt 2016, 03:26
Wird irgendeine Heap/Stack-Corruption sein. Irgendwo eventuell die stdcall Calling-Convention vergessen?
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
EWeiss
(Gast)

n/a Beiträge
 
#7

AW: lpfnHook absturz als eigenständige exe

  Alt 1. Okt 2016, 06:24
Wird irgendeine Heap/Stack-Corruption sein. Irgendwo eventuell die stdcall Calling-Convention vergessen?
Ahhh wäre eine alternative werde das nochmal prüfen.

Danke.

EDIT:
Geprüft und tatsächlich ja.
Löst aber nicht mein Problem.

Öffentliche API. "SKAeroAPI" (Stellt den Eingang über den Ausgang der DLL bereit.)
Delphi-Quellcode:
function SKAERO_OpenSaveFileDialog(SkinConfig: string; ParentHandle: THandle;
  const DefExt, Filter, InitialDir, Title: WideString; var FileName: WideString;
  IsOpenDialog: boolean): boolean; stdcall; external dllfile;
Aufruf.
Delphi-Quellcode:
              
if SKAERO_OpenSaveFileDialog(DefSkin, WinHandle, '.mp3',
  'Mp3 Files (*.MP3|*.mp3', ParamStr(0),
  ' Open Media File', MainApp.Newfile, True) then
begin
  if MainApp.Newfile <> 'then
    MainApp.SampleAudioStream(MainApp.Newfile);
end;
Weiterleitung über meine Master Unit in der alle Exports verwaltet werden.
Die Rückgabe erfolgt dann von hier.
Delphi-Quellcode:
function SKAERO_OpenSaveFileDialog(SkinConfig: string; ParentHandle: THandle; const DefExt, Filter, InitialDir,
  Title: WideString; var FileName: WideString; IsOpenDialog: Boolean): Boolean; stdcall;
begin

  result := OpenSaveFileDialog(SkinConfig, ParentHandle, DefExt, Filter, InitialDir,
    Title, FileName, IsOpenDialog);
end;
unit OpenFileDlg Verarbeitung der Funktionen
Global Im Header hier hatte ich stdcall vergessen.
Delphi-Quellcode:
function OpenSaveFileDialog(SkinConfig: string; ParentHandle: THandle; const DefExt, Filter,
  InitialDir, Title: WideString; var FileName: WideString; IsOpenDialog: Boolean): Boolean; stdcall;
Das eigentliche Arbeitspferd
Auch hier stdcall vergessen
Delphi-Quellcode:
function OpenSaveFileDialog(SkinConfig: string; ParentHandle: THandle; const DefExt, Filter,
  InitialDir, Title: WideString; var FileName: WideString; IsOpenDialog: Boolean): Boolean; stdcall;
var
  ofn: TOpenFilename;
  szFile: array [0 .. MAX_PATH] of Char;
begin
  Result := False;
  SkinConfigFile := SkinConfig; // Hier Krachts sobald aktiviert.
Der Aufruf in meiner OpenSaveFileNameHook function
Delphi-Quellcode:
CDN_INITDONE:
  begin
  //......
  OpenDialog.PrepareWindow(DlgHandle, SkinConfigFile);
  //.....
  end;
Das war's

Auch mit stdcall es kracht als eigenständige EXE.
Ich muss mich verstecken das kann niemand mehr hören.

Lege ich anstelle von "SkinConfigFile" den Pfad Hardcoded an kein Absturz als EXE.
Ich hätte eine Lösung aber das behebt nicht das ursprüngliche Problem.
Ich möchte wissen warum ein einfacher String die Anwendung außerhalb der IDE abstürzen lässt.

gruss

Geändert von EWeiss ( 1. Okt 2016 um 07:26 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:11 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 by Thomas Breitkreuz