AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein ProtocolBuffers für BLE-Schnittstelle
Thema durchsuchen
Ansicht
Themen-Optionen

ProtocolBuffers für BLE-Schnittstelle

Ein Thema von philipp.hofmann · begonnen am 14. Mär 2025 · letzter Beitrag vom 23. Mär 2025
Antwort Antwort
msohn

Registriert seit: 2. Mai 2013
Ort: Leipzig
7 Beiträge
 
Delphi 11 Alexandria
 
#1

AW: ProtocolBuffers für BLE-Schnittstelle

  Alt 19. Mär 2025, 09:28
Falls die ProtoBuf Schnittstelle mal komplexer wird, schau doch mal auf meine Weiterentwicklung des ProtoBuf Generators - über 2 Umwege basiert das auf dem Code von Marat Shaymardanov:

https://github.com/modersohn/ProtoBufGenerator
  Mit Zitat antworten Zitat
philipp.hofmann

Registriert seit: 21. Mär 2012
Ort: Hannover
942 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: ProtocolBuffers für BLE-Schnittstelle

  Alt 19. Mär 2025, 16:56
Der Unterschied war jetzt noch, dass ein optionales Element mit 0 trotzdem bei dem dokumentierten Beispiel übertragen wurde. Beide Varianten ergeben https://www.protobufpal.com/ hier das gleiche. Also meine Implementierung stimmt jetzt schon mal, das sie nichts tut, ist nun noch eine andere Sache.
  Mit Zitat antworten Zitat
philipp.hofmann

Registriert seit: 21. Mär 2012
Ort: Hannover
942 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: ProtocolBuffers für BLE-Schnittstelle

  Alt 21. Mär 2025, 15:29
Ok, die Marat Shaymardanov-Implementierung war jetzt unter Windows für mich erfolgreich. Unter Android kachelt sie in
procedure TProtoBufOutput.writeUInt32(fieldNumber: integer; value: cardinal);
leider ab. Ist deine (@msohn) Implementierung Cross-Platform-fähig. Würde ich mir dann später einmal anschauen.
  Mit Zitat antworten Zitat
philipp.hofmann

Registriert seit: 21. Mär 2012
Ort: Hannover
942 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: ProtocolBuffers für BLE-Schnittstelle

  Alt 21. Mär 2025, 18:46
Deine Implementierung geht in die richtige Richtung, du kannst folgendes aber allgemein gültig machen, damit auch Android unterstützt wird und unter Windows tut es auch nicht weh:

procedure TProtoBufOutput.writeRawData(const buf; size: integer);
begin
FBuffer.Add(@buf, size);
//writeRawData(@buf, size); //endless loop for some OS
end;

Geändert von philipp.hofmann (21. Mär 2025 um 20:05 Uhr)
  Mit Zitat antworten Zitat
msohn

Registriert seit: 2. Mai 2013
Ort: Leipzig
7 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: ProtocolBuffers für BLE-Schnittstelle

  Alt 22. Mär 2025, 14:42
Das klingt, als ob der Compiler das falsche Overload aufruft und damit eine Endlosschleife und irgendwann einen stack overflow erzeugt.

Das Problem hatte ich mit macOS, s.a. hier https://github.com/modersohn/ProtoBu...ator/issues/38 - und habe es dort etwas hemdsärmlich mit einem IFDEF gelöst.

Welche Compilerversion setzt Du ein?
  Mit Zitat antworten Zitat
msohn

Registriert seit: 2. Mai 2013
Ort: Leipzig
7 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: ProtocolBuffers für BLE-Schnittstelle

  Alt 23. Mär 2025, 16:53
Ich hab das jetzt konsequenterweise für alle Plattformen und Compiler gelöst, indem ich das overload mit dem const untyped entfernt habe; das war ja nur für die Bequemlichkeit.

Details in https://github.com/modersohn/ProtoBu...ator/issues/42
  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 22:49 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