data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
convex.core.lang.Reader Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of convex-core Show documentation
Show all versions of convex-core Show documentation
Convex core libraries and common utilities
package convex.core.lang;
import java.io.IOException;
import convex.core.data.ACell;
import convex.core.data.AList;
import convex.core.data.Syntax;
import convex.core.lang.reader.AntlrReader;
import convex.core.util.Utils;
/**
* Parboiled Parser implementation which reads source code and produces a tree
* of parsed objects.
*
* Supports reading in either raw form (ACell) mode or wrapping with Syntax Objects. The
* latter is required for source references etc.
*
* "Talk is cheap. Show me the code." - Linus Torvalds
*/
@SuppressWarnings("javadoc")
public class Reader {
/**
* Parses an expression and returns a Syntax object
*
* @param source
* @return Parsed form
*/
public static Syntax readSyntax(String source) {
return Syntax.create(read(source));
}
public static ACell readResource(String path) {
String source;
try {
source = Utils.readResourceAsString(path);
} catch (IOException e) {
throw Utils.sneakyThrow(e);
}
return read(source);
}
public static ACell readResourceAsData(String path) throws IOException {
String source = Utils.readResourceAsString(path);
return read(source);
}
/**
* Parses an expression list and returns a list of raw forms
*
* @param source
* @return List of Syntax Objects
*/
public static AList readAll(String source) {
return AntlrReader.readAll(source);
}
/**
* Parses an expression and returns a form as an Object
*
* @param source Reader instance to get expression from
* @return Parsed form (may be nil)
*/
public static ACell read(java.io.Reader source) throws IOException {
return AntlrReader.read(source);
}
/**
* Parses an expression and returns a canonical Cell representing a form
*
* @param source Java source string to read
* @return Parsed form (may be nil)
*/
@SuppressWarnings("unchecked")
public static R read(String source) {
return (R) AntlrReader.read(source);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy