![]() |
Named Pipes - mitlesen
Hallo,
ich hab hier ein Programm, das kommuniziert über RS232, gibt diese Daten dann per Named Pipes an andere Prozesse weiter. Mittlerweile habe ich es geschafft die Named Pipe mitzulesen, ich erhalte jedoch immer nur unvollständige Informationen. ich vermute es liegt an dem eingesetzten Timer, der nach Ablauf den Buffer neu füllt und nichtaufgezeichnete Daten überschreibt. Aber wie macht man das denn ??? Folgenden Code verwende ich zur Zeit:
Delphi-Quellcode:
Jemand eine Idee wie ich die Pipe komplett mitschneiden kann ?procedure TForm2.FormCreate(Sender: TObject); var FSA : SECURITY_ATTRIBUTES; FSD : SECURITY_DESCRIPTOR; begin Timer1.Enabled:=false; Memo1.Clear; InitializeSecurityDescriptor(@FSD, SECURITY_DESCRIPTOR_REVISION); SetSecurityDescriptorDacl(@FSD, True, nil, False); FSA.lpSecurityDescriptor := @FSD; FSA.nLength := sizeof(SECURITY_ATTRIBUTES); FSA.bInheritHandle := True; Pipe:= CreateFile(PChar('\\.\pipe\Output'), GENERIC_READ or GENERIC_WRITE, 0, @FSA, OPEN_EXISTING, 0, 0); end; procedure TForm2.Timer1Timer(Sender: TObject); begin Button1Click(self); end; procedure TForm2.Button1Click(Sender: TObject); var buffer: shortstring; dw : dword; begin Timer1.enabled:=true; ReadFile(Pipe, buffer, sizeof(buffer), dw, nil); Memo1.Lines.Add(buffer); end; KUBA |
Re: Named Pipes - mitlesen
Du überschreibst das Längenbyte des Shortstrings, wodurch der String abgeschnitten wird. Du darfst buffer[0] nicht überschreiben. Du kannst dann buffer[0] := dw setzen.
Übrigens kannst du dir das Herumgetüftele mit den Security Attributes sparen. Setze einfach nil für den Parameter ein; nur beim Ersteller wird die Information überhaupt ausgewertet. |
Re: Named Pipes - mitlesen
Das verstehe ich nicht wirklich, wie soll das denn aussehen ?
etwa so ?
Delphi-Quellcode:
kuba
buffer[0] := dw;
ReadFile(Pipe, buffer[0], sizeof(buffer), dw, nil); |
Re: Named Pipes - mitlesen
Nachdenken! Welchen Wert hat dw vor dem Aufruf von ReadFile? Warum überschreibst du noch immer buffer[0]?
|
Re: Named Pipes - mitlesen
welchen Wert dw vor ReadFile hat ? Undefiniert, oder ?
Wieso überschreibe ich den buffer ? Ich fange doch bei 0 an (buffer[0]) und will dann die Länge ausgeben (sizeof(buffer)). Verstehe nicht :pale: kubaa |
Re: Named Pipes - mitlesen
Undefiniert, eben. buffer[0] := dw also nach dem ReadFile.
Zitat:
|
Re: Named Pipes - mitlesen
moment mal, habe ich nach READFILE nicht die Anzahl der gelesenen Bytes in dw ??
Bei buffer[0] := dw; sagt der Compiler [Fehler] client.pas(45): E2010 Inkompatible Typen: 'Char' und 'Cardinal' Müsste es nicht dw:=0 sein ? kuba |
Re: Named Pipes - mitlesen
Zitat:
Fein erkannt. Daher soll ja das Längenbyte des Shortstrings überhaupt erst den Wert dw erhalten. Du kannst übrigens ganz unbesorgt nach Char casten. |
Re: Named Pipes - mitlesen
ein ShortString hat an erster Stelle ein LängenByte, welches die Länge des Strings innerhalb dessen Speichers angibt.
Das ist auch ein/der Grund, warum der Delphi-String, wegen der Abwärtskompatibilität und aus Gewohnheitsgründen (wenn man das jetzt auf 0 ändert, müßten bestimmt 95% der Delphi-Anwendungen überabeitet werden), ebenfalls mit 1 beginnt, obwohl es dort dieses Längenbyte nicht mehr in dieser Form gibt.
Delphi-Quellcode:
ReadFile(Pipe, buffer[1], 255, dw, nil);
buffer[0] := AnsiChar(dw); // aka SetLength(buffer, dw); |
Re: Named Pipes - mitlesen
Supi, ich habs jetzt:
Delphi-Quellcode:
Jetzt hab ich nur gelegentlich Zeilen mit Zeichen die nicht in der Pipe sind. Vermutlich genau dann, wenn die Pipe gerade bedient wird und mein Timer eine Abfrage startet.
procedure TForm2.Button1Click(Sender: TObject);
var buffer: shortstring; dw : dword; begin Timer1.enabled:=true; ReadFile(Pipe, buffer[0], sizeof(buffer), dw, nil); buffer[0] := Char(dw); Memo1.Lines.Add(buffer); end; kuba |
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:40 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