Mercurial Hosting > luan
changeset 607:c5ad80f869da
improve theming indentation
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Mon, 07 Dec 2015 15:08:42 -0700 (2015-12-07) |
parents | bd7a26d52737 |
children | d2e0855b3105 |
files | core/src/luan/impl/ThemeParser.java |
diffstat | 1 files changed, 28 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/core/src/luan/impl/ThemeParser.java Fri Dec 04 09:39:23 2015 -0700 +++ b/core/src/luan/impl/ThemeParser.java Mon Dec 07 15:08:42 2015 -0700 @@ -155,7 +155,7 @@ } { addSymbol(MOD); - LuanElement se = se(0,"local M = {}"); + LuanElement se = se(0,"local M = {['-INDENT-']=''}"); TableExpr.Field indent = new TableExpr.Field(new ConstExpr(null,INDENT),new ConstExpr(null,"")); TableExpr tableExpr = new TableExpr( se, new TableExpr.Field[]{indent}, ExpList.emptyExpList ); SetStmt setStmt = new SetStmt( new SetLocalVar(stackIndex(MOD)), tableExpr ); @@ -202,7 +202,7 @@ return rtn; } - private Stmt parseBody(String tagName,String spaces,boolean afterIndent) throws ParseException { + private Stmt parseBody(String tagName,final String spaces,boolean afterIndent) throws ParseException { List<Stmt> stmts = new ArrayList<Stmt>(); int stackStart = symbolsSize(); int start = parser.currentIndex(); @@ -225,7 +225,7 @@ while( !matchEndTag(tagName) ) { if( parser.endOfInput() ) throw exception("unclosed block"); - Stmt block = parseBlock(spaces); + Stmt block = parseBlock(spaces,afterIndent); if( block != null ) { addText(start,end,stmts,false); start = parser.currentIndex(); @@ -274,8 +274,12 @@ private boolean matchEndTag(String tagName) { parser.begin(); +/* if( tagName.startsWith("define:") ) EndOfLine(); +*/ + if( EndOfLine() ) + InlineSpaces(); return parser.match("{/") && parser.match(tagName) && parser.match('}') ? parser.success() : parser.failure(); } @@ -297,8 +301,16 @@ } } - private Stmt parseBlock(String spaces) throws ParseException { + private Stmt parseBlock(String spaces,boolean afterIndent) throws ParseException { int start = parser.begin(); + String tagSpaces = null; + if( afterIndent ) { + tagSpaces = spaces; + } else if( EndOfLine() ) { + int startSpaces = parser.currentIndex(); + InlineSpaces(); + tagSpaces = parser.textFrom(startSpaces); + } if( !parser.match("{block:") ) return parser.failure(null); String name = parseName(); @@ -306,6 +318,18 @@ throw exception("invalid block name"); if( !parser.match("}") ) return null; + if( tagSpaces != null ) { + parser.begin(); + InlineSpaces(); + if( EndOfLine() ) { + int startSpaces = parser.currentIndex(); + InlineSpaces(); + String line1Spaces = parser.textFrom(startSpaces); + if( line1Spaces.startsWith(tagSpaces) ) + spaces += line1Spaces.substring(tagSpaces.length()); + } + parser.failure(); // rollback + } frame = new Frame(frame); addSymbol(ENV); Stmt block = parseBody("block:"+name,spaces,false);