#!/usr/bin/env --split-string=${JDK_HOME}/bin/java @Makeshift/java_arguments @Makeshift/java_javac_arguments
import Breccia.parser.*;
import Breccia.parser.plain.BrecciaCursor;
import Breccia.parser.plain.IllegalParseState;
import java.io.IOException;
import java.io.Reader;
import java.nio.file.Path;
import static Breccia.parser.plain.Project.newSourceReader;
import static java.lang.System.out;
/** A shell command to smoke test the plain Breccia parser.
*
* @see
* Usage instructions
*/
public final class SmokeTestCommand { // [AFN]
private SmokeTestCommand() {}
public static void main( final String[] arguments ) throws IOException {
final Path sourceFile = Path.of( arguments[0] );
final BrecciaCursor in = new BrecciaCursor();
try( final Reader sourceReader = newSourceReader( sourceFile )) {
in.source( sourceReader );
for( ;; ) {
final ParseState state = in.state();
final Fractum f = in.asFractum();
if( f != null ) {
// out.println( f );
// final CommandPoint p = in.asCommandPoint();
// if( p != null ) {
// // out.println( p );
// out.println( p.tagName() );
// out.println( p.modifierSet() );
// out.println( p.appendageClause() );
// ; }
out.println( f.tagName() );
printComponentsOf( f, " " );
; }
else {
out.print( " " );
out.println( state ); }
if( state.isFinal() ) break;
in.next(); }}
catch( final ParseError x ) {
out.print( sourceFile );
out.print( ':' );
out.print( x.lineNumber );
out.print( ": " );
out.println( x ); }
// x.printStackTrace( out ); }
catch( final IllegalParseState x ) {
out.print( sourceFile );
out.print( ':' );
out.print( x.pointer.lineNumber );
out.print( ": " );
out.println( x ); }}
// x.printStackTrace( out ); }}
private static void printComponentsOf( final Granum granum, final String indent ) throws ParseError {
for( final Granum component: granum.components() ) {
out.print( indent );
// out.println( component.tagName() );
out.println( component );
printComponentsOf( component, indent + " " ); }}}
// NOTE
// ────
// AFN Atypical file naming is allowed here. ‘The compiler does not enforce the optional restriction
// defined at the end of JLS §7.6, that a type in a named package should exist in a file whose
// name is composed from the type name followed by the .java extension.’
//
//
//
// No longer, however, does this allowance extend to the package name. While in JDK releases
// prior to 22 “the launcher's source-file mode was permissive about which package, if any,
// was declared”, current releases enforce a correspondence between the declared package name
// and the file path. Failing this, the launcher aborts with “end of path to source file
// does not match its package name”.