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.
Vorhaben 2020
03.01.2020
Genau wie letztes Jahr habe ich auch dieses Jahr wieder ein "Listche" verfasst, um mir all die interessanten Vorhaben zu notieren, die ich mit mittlerem zeitlichen Horizont anzugehen gedenke.
Weiterlesen...Android Basteln C und C++ Chaos Datenbanken Docker dWb+ ESP Wifi Garten Geo Go GUI Gui Hardware Java Jupyter Komponenten Links Linux Markdown Markup Music Numerik OpenSource PKI-X.509-CA Python QBrowser Rants Raspi Revisited Security Software-Test sQLshell TeleGrafana Verschiedenes Video Virtualisierung Windows Upcoming...
In eigener Sache...
Weiterlesen...Nach dem ersten Teil von mir als interessant eingestufter Vorträge des Chaos Communication Congress 2024 hier nun die Nachlese
Weiterlesen...Nach dem So - wie auch im letzten Jahr: Meine Empfehlungen für Vorträge vom Chaos Communication Congress 2024 - vulgo: 38c3:
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, 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.