Heiner KückerLineNumbers |
|||||||||
Home Java-Seite Bit Packed Array ASM Improved heterogene Map, HMap Constraint Code Generator JSP WorkFlow PageFlow FlowControl Page Flow Engine Web Flow Engine Control_and_Command JSP_Spreadsheet Code-Generator für Option-Either-Stil in Java verbesserter Comparator Fluent-Interface Code-Generator auf Basis einer Grammatik Visitor mit Multidispatch for-Schleife mit yield-return Kognitions-Maschine semantisches Netz Domain Parser Codegenerator_für hierarchische Datenstrukturen Expression_Engine Formula_Parser Thread Preprocessor State Transition Engine AspectJ Java_Explorer DBF_Library Kalender_Applet SetGetGen BeanSetGet CheckPackage LineNumbers GradDms Excel-Export StringTokenizer JspDoc JspCheck JSP-Schulung Java Server Pages Struts Ascii-Tabellen- Layouter Ascii-Baum- Layouter Ascii-Art-Fluss- Diagramm- Parser AsciiArt AssignmentMatrix Layouter StringSerial Silbentrennung JDBC_Schlüssel- Generierung bidirektional/ unidirektional gelinkte Liste Java_Sitemap Generator XmlBuilder RangeMap StringFormatter VersionSafe XCopy JTextField CommandLine- ParamReader Bitmap-Grafik MultiMarkable- Buffered- InputStream JavaCache JdomUtil CollectionUtil XML Really Pull Parser Log-Filter Remote-Protokoll Sudoku-Generator Delegation statt Mehrfachvererbung Disjunct Interval Set WebCam_Demo Weiterentwicklung_Java Alaska-XBase++-Seite Projekte Philosophien Techniken Konzepte Sudoku Kontakt / Impressum Links SiteMap Letzte Aktualisierung: 14.02.2005 |
LineNumbers
Java-Programm zum Einfügen und Aktualisieren von Zeilen-Nummern, Datei-, Package-, Klassen- und Methoden-Namen sowie TimeStamps in Java-Source-Files (Code-Instrumentierung). Dient als Hilfsprogramm zum Debugging per println-Anweisungen. Es durchläuft rekursiv das aktuelle Verzeichnis und alle Unterverzeichnisse und prüft alle enthaltenen *.java- und *.jsp-Dateien. In den *.java- und *.jsp-Dateien wird die Escape-Sequence $LineNr: gesucht und unmittelbar nach diesen Stellen die Zeilen-Nummer eingefügt. Schon vorhandene Zeilen-Nummern werden aktualisiert. Beispiel: System.out.println("$LineNr: 1"); | diese Zeilen-Nummer wird aktualisiert --+Weiterhin ist es möglich Datei-, Package-, Klassen- und Methoden-Namen sowie TimeStamps zu setzen. System.out.println( "$FileName<G:\\java\\Test.java>" ) ; System.out.println( "$PackageName: test" ); System.out.println( "$ClassName: Test" ); System.out.println( "$MethodName: testMethod" ); System.out.println( "$DateTime<13.02.2005 14:18:46>" );Datei-Namen ($FileName) und der TimeStamp ($DateTime) müssen in spitze Klammern < > eingeschlossen werden. Das Einfügen des TimeStamps ermöglicht eine Art touch auf die entsprechende Datei, das heisst das Erzwingen von ständigem Kompilieren, Deployen oder ähnlichem. Das Parsen der Klassen- und Methoden-Namen ist nicht 100-prozentig korrekt implementiert. Zum Beispiel könnte es Probleme mit inneren Klassen, mit auskommentiertem Code und bei ungewöhnlichen Zeilenumbrüchen geben. Für die allgemeinen Fälle sollte es aber reichen. Falls sich die Zeilen-Nummern oder die anderen Informationen nicht geändert haben, wird die Datei unverändert gelassen, um unnötige Kompilierläufe und Ähnliches zu vermeiden. Von veränderten Dateien wird eine Bakup-Datei *.bak angelegt. Dies kann mit dem Parameter -nobackup unterdrückt werden. Aufruf: java -cp <pfad_zu_LineNumbers.class> LineNumbers <start_directory> ohne Erstellen von *.bak-Dateien: java -cp <pfad_zu_LineNumbers.class> LineNumbers -nobackup <start_directory>Dieses Programm sollte über den Parameter <start_directory> in dem Verzeichnis gestartet werden, welches die Root der zu instrumentierenden Java-Dateien darstellt. Download der Quelldateien LineNumbers.zip Mitgelieferte Dateien:
Installation: Entpacken in Verzeichnis Ihrer Wahl (z.B. G:\LineNumbers) Start mit LineNumbers.bat .
Achtung: Erweiterungen und Fixes stelle ich ohne Historie
und ohne Ankündigung hier bereit. Lizenzbedingungen:
Die Programme, Quelltexte und Dokumentationen können ohne
irgendwelche Bedingungen kostenlos verwendet werden. |