Ich musste neulich mein Projekt plantumlinterfaceproxy aktualisieren
Als ich mit den Planungen für das neue Feature der sQLshell begann, das es erlauben sollte die Syntax von Prepared Statements im SQL-Editor zu benutzen wälzte ich zuvor einige Ideen zur Umsetzung.
Eine war, mittels des in der sQLshell verbauten SQL-Parsers die Stellen der Platzhalter für Parameter zu ermitteln und darauf aufbauend entsprechende Formulare zu erstellen, die der Anwender für die Definition der Parameterwerte benutzen können sollte.
Ich entschied mich letztlich gegen diese Idee der Umsetzung, entdeckte aber dadurch etwas für mich interessantes und Nützliches: Ich versuchte, einen regulären Ausdruck zu erstellen, der die Parameter in einem SQL-Statement findet. Diese sind dort durch Fragezeichen markiert. Natürlich durfte dieser reguläre Ausdruck keine Fragezeichen finden, die zu einem Stringliteral gehören und daher innerhalb von Anführungszeichen stehen.
Ich entdeckte relativ schnell einen passenden regulären Ausdruck im Internet: (str)(?=(?:[^'"]|["'][^'"]*["'])*$) - man kann diesen zum Beispiel hier ausprobieren.
Ich hatte mit dem Projekt plantumlproxy ja unter anderem eine Gitlab-Integration zur Darstellung von regulären Ausdrücken mittels Rails-Diagrammen geschaffen - so würde der oben angegebene Ausdruck etwa folgendes Diagramm ergeben:
Beispiel für ein Rails-Diagramm für einen regulären Ausdruck
Ich stellte jedoch fest, dass das von mir eingesetzte Projekt regexper nicht mit lookbehind umgehen konnte.
Als ich daraufhin die Issues des Projektes nach einem Tipp durchforstete fand ich eines, das dasselbe Problem ansprach und in diesem Issue fand ich einen Verweis auf einen Fork des Projektes, das auch diese Elemente verdauen konnte.
Daraufhin passte ich mein Projekt entsprechend an und nutze ebenfalls den Fork.
08.06.2024
Es gibt eine neue Version des Projektes plantumlinterfaceproxy - Codename napkin look.
Links - Verschiedenes
03.11.2020
Hier einmal einige Links, die einfach in keine Kategorie passen...
WeiterlesenAndroid Basteln C und C++ Chaos Datenbanken Docker dWb+ ESP Wifi Garten Geo Go GUI Gui Hardware Java Java. Komponenten Jupyter JupyterBinder Komponenten Links Linux Markdown Markup Music Numerik OpenSource PKI-X.509-CA Präsentationen Python QBrowser Rants Raspi Revisited Security Software-Test sQLshell TeleGrafana Verschiedenes Video Virtualisierung Windows Upcoming...
Ich habe längere Zeit keine Erweiterung meines Docker-Zoos vorgenommen - auch weil ich mir einige konzeptionelle Gedanken dazu gemacht habe. Aber ich habe auch Ideen gesammelt, was in meinem @homelab noch fehlt und was dringend ergänzt werden sollte.
WeiterlesenEine Diskussion brachte mich neulich auf eine Idee - und im Urlaub hatte ich an einem regnerischen Tag genug Zeit, die entsprechenden Experimente zu machen...
WeiterlesenNachdem die Öffentlichkeit letzte Woche wieder mal mitgekriegt haben sollte, dass die Konzentration in der Cloud Schwachsinn ist und - vielleicht nicht - die ganze Öffentlichkeit vor zwei Wochen wieder einmal herzlich gelacht hat über die, die dennoch alles in die Cloud auslagern, aber offensichtlich nicht verstehen, wie sie funktioniert - hier einige Gedanken von mir dazu...
WeiterlesenManche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.
Wer daran teilhaben und eventuell sogar davon profitieren möchte, muss damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.
Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...
PS: Meine öffentlichen Codeberg-Repositories findet man hier.