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.
Fährnisse des Buildprozesses unter Windows
17.07.2019
Nachdem ich begonnen hatte, mich mit der Beschleunigung der Berechnung des Mandelbrot-Fraktals unter Zuhilfenahme der Shadereinheiten in Graphikkarten zu beschäftigen und erste Erfolge feiern konnte, wollte ich das mal auf einer richtigen Graphikkarte ausprobieren...
Weiterlesen...Android Basteln C und C++ Chaos Datenbanken Docker dWb+ ESP Wifi Garten Geo Git(lab|hub) Go GUI Gui Hardware Java Jupyter Komponenten Links Linux Markdown Markup Music Numerik PKI-X.509-CA Python QBrowser Rants Raspi Revisited Security Software-Test sQLshell TeleGrafana Verschiedenes Video Virtualisierung Windows Upcoming...
Ich bin heute nochmal inspiriert worden, weiter über die Trojan Source Vulnerability nachzudenken. Meiner Meinung nach bestehen hier noch Probleme - speziell bei Nutzereingaben oder Daten, die über externe Schnittstellen ampfangen werden.
Weiterlesen...Ich habe die auf OpenStreetMap basierende OpenSource Navigationslösung Graphhopper in einen Docker-Container gepackt und als neuestes Mitglied in meinem Docker-Zoo willkommen geheißen.
Weiterlesen...Ich habe neulich über eine Möglichkeit berichtet, SQLite mittels der sQLshell und Beanshell-Skripten um SQL-Funktionen zu erweitern. In diesem Artikel versprach ich auch, über eine solche Möglichkeit für Aggregatfunktionen zu berichten.
Weiterlesen...Manche 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, muß 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 GitHub-Repositories findet man hier - meine öffentlichen GitLab-Repositories finden sich dagegen hier.