Reusable KissState
This commit is contained in:
@@ -27,16 +27,9 @@ typedef KissState = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
class Kiss {
|
class Kiss {
|
||||||
/**
|
public static function defaultKissState():KissState {
|
||||||
Build a Haxe class from a corresponding .kiss file
|
|
||||||
**/
|
|
||||||
macro static public function build(kissFile:String):Array<Field> {
|
|
||||||
try {
|
|
||||||
var classFields = Context.getBuildFields();
|
|
||||||
var className = Context.getLocalClass().get().name;
|
var className = Context.getLocalClass().get().name;
|
||||||
|
|
||||||
var stream = new Stream(kissFile);
|
|
||||||
|
|
||||||
var k = {
|
var k = {
|
||||||
className: className,
|
className: className,
|
||||||
readTable: Reader.builtins(),
|
readTable: Reader.builtins(),
|
||||||
@@ -55,6 +48,20 @@ class Kiss {
|
|||||||
k.defAlias("has", Symbol("Lambda.has"));
|
k.defAlias("has", Symbol("Lambda.has"));
|
||||||
k.defAlias("count", Symbol("Lambda.count"));
|
k.defAlias("count", Symbol("Lambda.count"));
|
||||||
|
|
||||||
|
return k;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Build a Haxe class from a corresponding .kiss file
|
||||||
|
**/
|
||||||
|
macro static public function build(kissFile:String, ?k:KissState):Array<Field> {
|
||||||
|
try {
|
||||||
|
var classFields = Context.getBuildFields();
|
||||||
|
var stream = new Stream(kissFile);
|
||||||
|
|
||||||
|
if (k == null)
|
||||||
|
k = defaultKissState();
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
stream.dropWhitespace();
|
stream.dropWhitespace();
|
||||||
if (stream.isEmpty())
|
if (stream.isEmpty())
|
||||||
|
Reference in New Issue
Block a user