Java und (Neo)Vim - der letzte Strohhalm

vorhergehende Artikel in: Java Linux
10.08.2025

Ich habe bereits mehrmals über Rückschläge und Fortschritte bei meinem Umstieg von "traditionellen" IDEs auf (Neo)Vim berichtet - eine Anforderung meinerseits an ein System zur Entwicklung von Software war dabei bisher unerfüllt geblieben - bisher...

Ich hatte zunächst davon geträumt, in Vim eine Erfahrung nachzustellen, die der aus IDEs gleichkommt - alles Clicky-bunty in Fenstern und so.

Aber ich habe mich in den letzten Tagen - wahrscheinlich, wiel ich wieder einmal auf einen meiner Geburtstage zusteuerte - daran erinnert, dass für mich Debugging das allerletzte Mittel ist. Ich sehe heutzutage Entwickler, die beim ersten Zeichen, dass das Programm nicht tut, was es soll den Debugger starten und dann den Anblick liefern, der mich sofort an einen dressierten Affen anseiner Schreibmaschine erinnert: es wird stakkato-artig auf "Step over" rumgehämmert und das Gesicht zeigt derweil keine Regung.

Forensik benötigt aber Zeit und Nachdenken.

Es gibt im Internet Berichte darüber, dass man mit Vim und Language Servern mit Debug Adaptern tatsächlich das Gefühl einer Debug-Session in jeder x-beliebigen IDE nachstellen kann.

Ich gebe auch zu, dass ich das bereits versucht habe, aber meine intellektuellen Fähigkeiten nicht ausreichten, die vorgeschlagenen Setups mit meinem zu vereinen.

Also kam ich auf die Idee, dass eventuell bereits jemand auf die Idee gekommen war, gdb mit Vim zu verheiraten? Oder - in meinem Fall - jdb?

Natürlich gab es mehrere alternative Lösungen, die genau das getan hatten.

Ich probierte die drei genannten aus - davon funktionierte lediglich VeBugger leidlich, allerdings hatte diese Lösung zwei große Mankos: Das Togglen von Breakpoints funktionierte nur in Klassen - nicht in inneren Klassen (das ist aber - ich muss es zugeben - ein Feature, das ich sehr häufig nutze). Und das Setup wird nicht gespeichert - nach einem Neustart von Vim sind alle Breakpoints verloren und man beginnt erneut.

Ich begann allerdings nicht mit den Plugins - zunächst sah ich mir jdb genauer an - ich gestehe, dass ich Java nun seit fast 30 Jahren nutze, dieses Werkzeug aber bisher ignorierte. Ich muss sagen: Ich war fasziniert: Dieses Werkzeug kann alles, was ein Debugger können muss (es gibt ein Feature - das ich bisher nie vermisst habe, das nicht unterstützt wird: bedingte Breakpoints). Es lassen sich Breakpoints verwalten, beliebige Felder inspizieren, man kann den Call-Stack rauf und runter wandern, es lassen sich Watches definieren und, und, und...

Und was die Breakpoints angeht, die nach jeder Sitzung wieder neu erstellt werden müssen: Die Anwendung kann Kommandodateien einlesen - damit ist das Wiederholen eines Debug-Setup einfach - ein simples Einlesen der entsprechenden Datei und alle Breakpoints und Watches sind wieder aktiv!

Ganz wichtig aber für die ultimative Debug Experience mit JDB ist rlwrap - man sollte jdb immer damit starten - also nicht

jdb -sourcepath <SOURCEPATH> -attach <PORT>

sondern:

rlwrap jdb -sourcepath <SOURCEPATH> -attach <PORT>

Artikel, die hierher verlinken

NeoVim und ausrangierte Plugins

24.08.2025

Ich habe nun seit geraumer Zeit NeoVim im Einsatz im Produktivbetrieb zum Entwickeln - nicht nur - von Software. Dabei hat sich gezeigt, dass ich meinem Ziel, der Philosophie des Einsatzes möglichst weniger Plugins immer näher komme:

Alle Artikel rss Wochenübersicht Monatsübersicht Codeberg Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Demonstration und Beispiele für die Nutzung eines RFC3161-Servers aus Java heraus

    15.05.2021

    Ich habe ein Begleitprojekt zu meiner Implementierung meines Timestamping Server Projekts erstellt: eine Demonstration und ein Beispiel dafür, wie man einen solchen Timestamping-Server von Java aus nutzen kann.

    Weiterlesen

Neueste Artikel

  • Asymmetrische Kryptographie

    Ich habe mich mit der Idee schon länger getragen: Nochmal einen Rundumschlag zu asymmetrischer Kryptographie zu machen. Dabei werde ich mich auf Demonstrationen der einzelnen Konzepte und Operationen mit Beispielcode konzentrieren und zu jedem der vorgestellten Konzepte mehr oder weniger ausführlich bezüglich der Einsatzszenarien und Vor- und Nachteile Stellung beziehen

    Weiterlesen
  • Absichern von Truststores und Keystores

    Hin und wieder erlebe ich es persönlich oder lese davon, dass jemand die Frage stellt, wie kryptographische Geheimnisse gesichert werden können. Ich gebe hier mal einen Anstoß, darüber aus der Sicht der Software-Architektur auf Systemebene nachzudenken...

    Weiterlesen
  • Futro-Thin-Clients und PCI Express Mini Cards

    Ich habe mich von einigen Artikeln anderer Besitzer und Upcycler von Futro-Thin-Clients inspirieren lassen - das hat dazu geführt, dass ich von meinem eigentlichen Projekt (Bauen eines kleinen Clusters) abgekommen bin und die Hardware ein wenig genauer unter die Lupe genommen habe...

    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.