Ich habe eine Inkompatibilität in Java gefunden, für die ich gerne eine Lösung hätte...
Das grundlegende Framework für die Erstellung von graphischen Benutzerschnittstellen in java ist AWT. Seit inzwischen einigen Jahrzehnten baut eine Vielzahl von JavaSE-Desktop-Anwendungen direkt oder darauf auf.
Eine so lange Zeit geht an keinem Framework vorüber ohne Spuren zu hinterlassen und so ist es auch mit AWT: Über die Zeit entwickelt sich das API weiter - neue Aspekte kommen hinzu, alte Zöpfe werden abgeschnitten.
AWT war allerdinge der erste Bereich, in dem ich bei Java entdeckt habe, dass dabei Inkonsistenzen entstehen - also zumindest eine; und das kam so...
Ich habe im I18NEditor eine TreeTable benutzt. Das ist eine Komponente, die einen Baum und eine Tabelle kombiniert. Das ist keine offizielle Komponente des Java-Frameworks - ich habe sie damals bei SUN gefunden, doch nicht als einziger: inzwischen ist sie in viele andere Projekte hineingewandert.
Innerhalb dieser Komponente wird ein neuer AWT-Event - genauer gesagt ein MouseEvent erzeugt. Das ist die Stelle, an der ich auf die Nase gefallen bin: Es begab sich, dass ich meinen Code aufräumen wollte und dazu alle Aufrufe von deprecated Elementen entfernen wollte - ich ersetzte sie gegen die empfohlenen neuen Varianten. Die Methode getModifiers ist ebenfalls als deprecated markiert (seit Java 9) - man soll statt dessen die Methode getModifiersEx.
Diese beiden Methoden sind aber inkompatibel zueinander: die Bitmaske, die der Konstruktor eines MouseEvent (und anderer AWT-Events) erwartet ist genau die Bitmaske, die MouseEvent liefert. Will ich also - wie es zum Beispiel im Code der JTreeTable geschieht - aus einem AWT-Event einen neuen erzeugen, muss ich die deprecated`-Methode benutzen, denn es existiert - meines Wissens nach - keine Mapping Methode um die beiden Varianten der Bitmasken ineinander zu überführen.
Man müsste eine Mapping-Methode schreiben, die ungefähr so aussehen würde:
private int translateIntoGetModifiersResult(java.awt.event.InputEvent evt)
{
int newMask=evt.getModifiersEx();
int rv=0;
if((newMask&InputEvent.ALT_DOWN_MASK)!=0)
rv|= InputEvent.ALT_MASK;
//die oberen zwei Zeilen wiederholen sich an dieser Stelle
//für alle Bits in der Maske...
return rv;
}
Allerdings wäre auch diese Methode auf deprecated Elemente angewiesen - dieses Mal auf die symbolischen Konstanten wie zum Beispiel ALT_MASK.
Als deprecated kann und sollte man aber nur Elemente kennzeichnen, für die es einen vollwertigen und gleichwertigen Ersatz gibt - das ist hier ganz klar nicht der Fall: sobald die deprecated Elemente in InputEvent entfernt werden, hören einige Java-Anwendungen auf zu funktionieren...
Android 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 notListed Numerik OpenSource PKI-X.509-CA Präsentationen Python QBrowser Rants Raspi Revisited Security Software-Test sQLshell TeleGrafana Verschiedenes Video Virtualisierung Windows Upcoming...
Eine Präsentation zum besseren Verständnis einiger Konzepte sicherer Softwareentwicklung
WeiterlesenIch habe ja bereits eine kleine Präsentation zum Thema PKI und OpenSSH verfasst - hier folgt nun - mit einigen Links zu externen Ressourcen zu diesem Thema angereichert - eine strukturierte Zusammenfassung diverser Use Cases und deren Lösung mit einer OpenSSH PKI
WeiterlesenUnd wieder habe ich mich mit einem System beschäftigt, das sich in die Themen Chaos und Fraktale oder Strange Attractors einordnen lässt.
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.