guard-mthaml 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/README.md +34 -0
- data/lib/guard/mthaml.rb +140 -0
- data/lib/guard/mthaml/compiler/MtHaml.php +255 -0
- data/lib/guard/mthaml/templates/Guardfile +12 -0
- data/lib/guard/mthaml/version.rb +5 -0
- data/vendor/autoload.php +7 -0
- data/vendor/coffeescript/coffeescript/LICENSE +22 -0
- data/vendor/coffeescript/coffeescript/README.md +96 -0
- data/vendor/coffeescript/coffeescript/composer.json +23 -0
- data/vendor/coffeescript/coffeescript/grammar.y +309 -0
- data/vendor/coffeescript/coffeescript/make.php +115 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Compiler.php +76 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Error.php +15 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Helpers.php +116 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Init.php +96 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Lexer.php +1356 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Nodes.php +105 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Parser.php +3326 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Rewriter.php +552 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Scope.php +196 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/SyntaxError.php +9 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/Value.php +20 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Access.php +31 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Arr.php +69 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Assign.php +353 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Base.php +288 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Block.php +294 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Call.php +283 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Class.php +282 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Closure.php +49 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Code.php +203 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Comment.php +39 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Existence.php +42 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Extends.php +26 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/For.php +250 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/If.php +161 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/In.php +99 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Index.php +27 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Literal.php +96 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Obj.php +126 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Op.php +292 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Param.php +119 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Parens.php +45 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Range.php +225 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Return.php +56 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Slice.php +47 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Splat.php +100 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Switch.php +121 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Throw.php +37 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Try.php +79 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/Value.php +210 -0
- data/vendor/coffeescript/coffeescript/src/CoffeeScript/yy/While.php +112 -0
- data/vendor/coffeescript/coffeescript/tests/cases/arrays.coffee +77 -0
- data/vendor/coffeescript/coffeescript/tests/cases/assignment.coffee +352 -0
- data/vendor/coffeescript/coffeescript/tests/cases/booleans.coffee +21 -0
- data/vendor/coffeescript/coffeescript/tests/cases/classes.coffee +681 -0
- data/vendor/coffeescript/coffeescript/tests/cases/comments.coffee +207 -0
- data/vendor/coffeescript/coffeescript/tests/cases/compilation.coffee +72 -0
- data/vendor/coffeescript/coffeescript/tests/cases/comprehensions.coffee +501 -0
- data/vendor/coffeescript/coffeescript/tests/cases/control_flow.coffee +430 -0
- data/vendor/coffeescript/coffeescript/tests/cases/eval.coffee +29 -0
- data/vendor/coffeescript/coffeescript/tests/cases/exception_handling.coffee +102 -0
- data/vendor/coffeescript/coffeescript/tests/cases/formatting.coffee +146 -0
- data/vendor/coffeescript/coffeescript/tests/cases/function_invocation.coffee +552 -0
- data/vendor/coffeescript/coffeescript/tests/cases/functions.coffee +188 -0
- data/vendor/coffeescript/coffeescript/tests/cases/helpers.coffee +96 -0
- data/vendor/coffeescript/coffeescript/tests/cases/importing.coffee +18 -0
- data/vendor/coffeescript/coffeescript/tests/cases/interpolation.coffee +138 -0
- data/vendor/coffeescript/coffeescript/tests/cases/javascript_literals.coffee +10 -0
- data/vendor/coffeescript/coffeescript/tests/cases/numbers.coffee +76 -0
- data/vendor/coffeescript/coffeescript/tests/cases/objects.coffee +271 -0
- data/vendor/coffeescript/coffeescript/tests/cases/operators.coffee +277 -0
- data/vendor/coffeescript/coffeescript/tests/cases/option_parser.coffee +43 -0
- data/vendor/coffeescript/coffeescript/tests/cases/ranges.coffee +88 -0
- data/vendor/coffeescript/coffeescript/tests/cases/regexps.coffee +63 -0
- data/vendor/coffeescript/coffeescript/tests/cases/scope.coffee +43 -0
- data/vendor/coffeescript/coffeescript/tests/cases/slicing_and_splicing.coffee +143 -0
- data/vendor/coffeescript/coffeescript/tests/cases/soaks.coffee +134 -0
- data/vendor/coffeescript/coffeescript/tests/cases/strict.coffee +155 -0
- data/vendor/coffeescript/coffeescript/tests/cases/strings.coffee +107 -0
- data/vendor/coffeescript/coffeescript/tests/css/style.css +43 -0
- data/vendor/coffeescript/coffeescript/tests/index.php +119 -0
- data/vendor/coffeescript/coffeescript/tests/js/lib/coffeescript_1.1.1.js +8 -0
- data/vendor/coffeescript/coffeescript/tests/js/lib/coffeescript_1.2.0.js +8 -0
- data/vendor/coffeescript/coffeescript/tests/js/lib/coffeescript_1.3.0.js +8 -0
- data/vendor/coffeescript/coffeescript/tests/js/lib/coffeescript_1.3.1.js +8 -0
- data/vendor/coffeescript/coffeescript/tests/js/lib/diff.js +276 -0
- data/vendor/coffeescript/coffeescript/tests/js/main.js +123 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/LICENSE.txt +10 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/Lempar.php +948 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/Action.php +257 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/ActionTable.php +299 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/Config.php +574 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/Data.php +1857 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/Parser.php +851 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/PropagationLink.php +126 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/Rule.php +144 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/State.php +283 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/Symbol.php +288 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/PHP/ParserGenerator/cli.php +5 -0
- data/vendor/coffeescript/coffeescript/vendor/ParserGenerator/ParserGenerator.php +811 -0
- data/vendor/composer/ClassLoader.php +383 -0
- data/vendor/composer/autoload_classmap.php +9 -0
- data/vendor/composer/autoload_namespaces.php +12 -0
- data/vendor/composer/autoload_psr4.php +10 -0
- data/vendor/composer/autoload_real.php +50 -0
- data/vendor/composer/installed.json +166 -0
- data/vendor/michelf/php-markdown/License.md +36 -0
- data/vendor/michelf/php-markdown/Michelf/Markdown.inc.php +10 -0
- data/vendor/michelf/php-markdown/Michelf/Markdown.php +3117 -0
- data/vendor/michelf/php-markdown/Michelf/MarkdownExtra.inc.php +11 -0
- data/vendor/michelf/php-markdown/Michelf/MarkdownExtra.php +38 -0
- data/vendor/michelf/php-markdown/Michelf/MarkdownInterface.inc.php +9 -0
- data/vendor/michelf/php-markdown/Michelf/MarkdownInterface.php +37 -0
- data/vendor/michelf/php-markdown/Readme.md +305 -0
- data/vendor/michelf/php-markdown/Readme.php +31 -0
- data/vendor/michelf/php-markdown/composer.json +31 -0
- data/vendor/mthaml/mthaml/CHANGELOG +48 -0
- data/vendor/mthaml/mthaml/LICENSE +44 -0
- data/vendor/mthaml/mthaml/README.markdown +262 -0
- data/vendor/mthaml/mthaml/composer.json +45 -0
- data/vendor/mthaml/mthaml/docs/Makefile +153 -0
- data/vendor/mthaml/mthaml/docs/_static/mthaml.css +30 -0
- data/vendor/mthaml/mthaml/docs/_theme/mthaml/theme.conf +4 -0
- data/vendor/mthaml/mthaml/docs/conf.py +242 -0
- data/vendor/mthaml/mthaml/docs/index.rst +18 -0
- data/vendor/mthaml/mthaml/docs/twig-syntax.rst +274 -0
- data/vendor/mthaml/mthaml/examples/README.md +5 -0
- data/vendor/mthaml/mthaml/examples/autoload.php +8 -0
- data/vendor/mthaml/mthaml/examples/example-php.haml +5 -0
- data/vendor/mthaml/mthaml/examples/example-php.php +37 -0
- data/vendor/mthaml/mthaml/examples/example-twig-noext.twig +11 -0
- data/vendor/mthaml/mthaml/examples/example-twig.haml +9 -0
- data/vendor/mthaml/mthaml/examples/example-twig.php +60 -0
- data/vendor/mthaml/mthaml/examples/example.twig.haml +8 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Autoloader.php +22 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Environment.php +178 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Escaping.php +33 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Exception.php +9 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Exception/SyntaxErrorException.php +9 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/AbstractFilter.php +43 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Cdata.php +16 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/CoffeeScript.php +33 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Css.php +26 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Escaped.php +22 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/FilterInterface.php +15 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Javascript.php +26 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Less.php +27 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Less/LeafoLess.php +20 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Less/OyejorgeLess.php +23 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Markdown.php +58 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Markdown/CebeMarkdown.php +22 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Markdown/Ciconia.php +21 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Markdown/MichelfMarkdown.php +21 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Markdown/Parsedown.php +21 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Php.php +37 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Plain.php +24 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Preserve.php +19 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Scss.php +37 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Filter/Twig.php +47 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Indentation/Indentation.php +96 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Indentation/IndentationException.php +9 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Indentation/IndentationInterface.php +50 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Indentation/Undefined.php +41 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Comment.php +71 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Doctype.php +96 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/EscapableAbstract.php +19 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Filter.php +51 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Insert.php +42 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/InterpolatedString.php +73 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/NestAbstract.php +117 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/NestInterface.php +10 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/NodeAbstract.php +77 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/ObjectRefClass.php +42 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/ObjectRefId.php +42 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Root.php +35 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Run.php +71 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Statement.php +45 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Tag.php +90 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/TagAttribute.php +62 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/TagAttributeInterpolation.php +24 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/TagAttributeList.php +24 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Node/Text.php +37 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/Autoclose.php +25 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/Escaping.php +105 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/MergeAttrs.php +110 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/Midblock.php +37 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/NodeVisitorAbstract.php +226 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/NodeVisitorInterface.php +97 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/PhpRenderer.php +288 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/Printer.php +265 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/RendererAbstract.php +581 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/NodeVisitor/TwigRenderer.php +252 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Parser.php +862 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Parser/Buffer.php +147 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Runtime.php +218 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Runtime/AttributeInterpolation.php +16 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Runtime/AttributeList.php +16 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Support/Php/Executor.php +157 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Support/Twig/Extension.php +47 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Support/Twig/Lexer.php +48 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Support/Twig/Loader.php +81 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Target/Php.php +23 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Target/TargetAbstract.php +87 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Target/TargetInterface.php +12 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/Target/Twig.php +23 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/TreeBuilder.php +100 -0
- data/vendor/mthaml/mthaml/lib/MtHaml/TreeBuilderException.php +9 -0
- data/vendor/mthaml/mthaml/phpunit.xml +25 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/EnvironmentTest.php +59 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/HamlSpecTest.php +83 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/IndentationTest.php +140 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/Node/DoctypeTest.php +51 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/Node/NodeTest.php +110 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/NodeVisitor/PhpRendererTest.php +113 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/NodeVisitor/TwigRendererTest.php +68 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/NodeVisitorsTest.php +44 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/Parser/BufferTest.php +77 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/ParserTest.php +47 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/RuntimeTest.php +356 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/Support/Php/ExecutorTest.php +83 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/Support/Twig/LoaderTest.php +65 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/TestCase.php +49 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/TestCaseTest.php +50 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/Support/Php/Executor.001.haml +1 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/attr_list_php.test +20 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/attr_list_twig.test +12 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/boolean_attr_php.test +16 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/boolean_attr_twig.test +16 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/bug28_php.test +15 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/bug28_twig.test +15 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/bug42.test +13 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/bug8_twig.test +10 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/coffeescript_filter.test +31 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/comments.test +26 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/cond_cmt.test +25 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/doctype.test +18 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/doctype_html4.test +20 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/doctype_invalid.test +12 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/doctype_invalid_xhtml.test +12 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/doctype_php.test +18 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/doctype_xhtml.test +30 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/filters.test +51 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/insert_non_echo_php.test +11 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/insert_non_echo_twig.test +11 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/interpolation_in_html_attrs_php.test +31 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/interpolation_in_html_attrs_twig.test +31 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/less_filter_leafo.test +33 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/less_filter_oyejorge.test +49 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/markdown_filter_cebemarkdown.test +35 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/markdown_filter_ciconia.test +36 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/markdown_filter_michelf.test +34 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/markdown_filter_parsedown.test +31 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/markdown_optimization_filter_michelf.test +23 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/mergeattrs.test +18 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/nuke_inner_whitespace.test +77 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/nuke_outer_whitespace.test +122 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/object_ref_php.test +14 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/object_ref_twig.test +14 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/php.test +109 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/php_autoescaping.test +22 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/php_autoescaping_once.test +25 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/php_blocks.test +29 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/php_filters.test +42 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/scss_filter.test +32 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/strip_inline_comments_php.test +22 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/test.test +24 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/trailing_semicolon_php.test +14 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/try_catch_php.test +17 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/twig.test +112 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/twig_blocks.test +29 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/twig_filters.test +37 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/twig_whitespace.test +32 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/environment/whitespace.test +63 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/nodevisitors/autoclose.test +30 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/nodevisitors/escaping.test +52 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/nodevisitors/escaping_attr_once.test +52 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/nodevisitors/escaping_html_false.test +52 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/nodevisitors/mergeattrs.test +26 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/nodevisitors/midblock.test +54 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/nodevisitors/midblock_002.test +32 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/attr_list.test +14 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/attrs.test +42 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/attrs_002.test +35 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/attrs_003.test +30 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/attrs_html_linebreak.test +17 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/blocks.test +27 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/blocks_002.test +15 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/boolean_attr.test +19 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/bug28.test +15 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/bug8.test +11 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/cond_cmt.test +23 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/doctype.test +11 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/double_equal.test +7 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/empty_line_after_multiline.test +10 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_001.test +8 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_002.test +8 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_003.test +8 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_004.test +6 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_005.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_006.test +7 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_007.test +7 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_008.test +7 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_009.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_010.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_013.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_016.test +7 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_017.test +8 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_018.test +6 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_019.test +6 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/errors_020.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/filters.test +20 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/filters_002.test +19 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/filters_003.test +13 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/filters_004.test +21 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/filters_005.test +22 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/filters_006.test +23 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/insertflags.test +17 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/interpolation.test +36 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/interpolation_in_html_attrs.test +17 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/multiline.test +18 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/multiline_code.test +59 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/multiple_attr_kinds.test +47 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/non_rendered_comment.test +31 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/ns.test +11 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/object_ref.test +22 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/object_ref_error1.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/object_ref_error2.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/quotes_in_haml.test +10 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/ruby19_attrs.test +11 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/ruby_attrs_comma.test +23 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/ruby_attrs_comma_errors_001.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/ruby_attrs_comma_errors_002.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/ruby_attrs_comma_errors_003.test +5 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/standard.test +114 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/parser/tagflags.test +39 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/runtime/php_filters.test +28 -0
- data/vendor/mthaml/mthaml/test/MtHaml/Tests/fixtures/runtime/twig_filters.test +31 -0
- data/vendor/mthaml/mthaml/test/bootstrap.php +3 -0
- metadata +398 -0
@@ -0,0 +1,225 @@
|
|
1
|
+
<?php
|
2
|
+
|
3
|
+
namespace CoffeeScript;
|
4
|
+
|
5
|
+
class yy_Range extends yy_Base
|
6
|
+
{
|
7
|
+
public $children = array('from', 'to');
|
8
|
+
|
9
|
+
public $from_num = 0;
|
10
|
+
public $to_num = 0;
|
11
|
+
|
12
|
+
private static function check($num)
|
13
|
+
{
|
14
|
+
// '0' evaluates to FALSE in PHP, but TRUE in JavaScript. Explicit conditions here.
|
15
|
+
return ! in_array($num, array(0, NULL, FALSE, ''), TRUE);
|
16
|
+
}
|
17
|
+
|
18
|
+
function constructor($from, $to, $tag)
|
19
|
+
{
|
20
|
+
$this->from = $from;
|
21
|
+
$this->to = $to;
|
22
|
+
$this->exclusive = $tag === 'exclusive';
|
23
|
+
$this->equals = $this->exclusive ? '' : '=';
|
24
|
+
|
25
|
+
return $this;
|
26
|
+
}
|
27
|
+
|
28
|
+
function compile_array($options)
|
29
|
+
{
|
30
|
+
if (self::check($this->from_num) && self::check($this->to_num) && abs($this->from_num - $this->to_num) <= 20)
|
31
|
+
{
|
32
|
+
$range = range($this->from_num, $this->to_num);
|
33
|
+
|
34
|
+
if ($this->exclusive)
|
35
|
+
{
|
36
|
+
array_pop($range);
|
37
|
+
}
|
38
|
+
|
39
|
+
return '['.implode(', ', $range).']';
|
40
|
+
}
|
41
|
+
|
42
|
+
$idt = $this->tab.TAB;
|
43
|
+
$i = $options['scope']->free_variable('i');
|
44
|
+
$result = $options['scope']->free_variable('results');
|
45
|
+
$pre = "\n{$idt}{$result} = [];";
|
46
|
+
|
47
|
+
if (self::check($this->from_num) && self::check($this->to_num))
|
48
|
+
{
|
49
|
+
$options['index'] = $i;
|
50
|
+
$body = $this->compile_node($options);
|
51
|
+
}
|
52
|
+
else
|
53
|
+
{
|
54
|
+
$vars = "{$i} = {$this->from_c}".($this->to_c !== $this->to_var ? ", {$this->to_c}" : '');
|
55
|
+
$cond = "{$this->from_var} <= {$this->to_var}";
|
56
|
+
$body = "var {$vars}; {$cond} ? {$i} <{$this->equals} {$this->to_var} : {$i} >{$this->equals} {$this->to_var}; {$cond} ? {$i}++ : {$i}--";
|
57
|
+
}
|
58
|
+
|
59
|
+
$post = "{ {$result}.push({$i}); }\n{$idt}return {$result};\n{$options['indent']}";
|
60
|
+
|
61
|
+
$has_args = function($node)
|
62
|
+
{
|
63
|
+
return $node->contains(function($n)
|
64
|
+
{
|
65
|
+
return ($n instanceof yy_Literal) && $n->value === 'arguments' && ! $n->as_key;
|
66
|
+
});
|
67
|
+
|
68
|
+
return FALSE;
|
69
|
+
};
|
70
|
+
|
71
|
+
$args = '';
|
72
|
+
|
73
|
+
if ($has_args($this->from) || $has_args($this->to))
|
74
|
+
{
|
75
|
+
$args = ', arguments';
|
76
|
+
}
|
77
|
+
|
78
|
+
return "(function() {{$pre}\n{$idt}for ({$body}){$post}}).apply(this{$args})";
|
79
|
+
}
|
80
|
+
|
81
|
+
function compile_node($options)
|
82
|
+
{
|
83
|
+
if ( ! (isset($this->from_var) && $this->from_var))
|
84
|
+
{
|
85
|
+
$this->compile_variables($options);
|
86
|
+
}
|
87
|
+
|
88
|
+
if ( ! (isset($options['index']) && $options['index']))
|
89
|
+
{
|
90
|
+
return $this->compile_array($options);
|
91
|
+
}
|
92
|
+
|
93
|
+
$known = self::check($this->from_num) && self::check($this->to_num);
|
94
|
+
$idx = del($options, 'index');
|
95
|
+
$idx_name = del($options, 'name');
|
96
|
+
$named_index = $idx_name && $idx_name !== $idx;
|
97
|
+
|
98
|
+
$var_part = "{$idx} = {$this->from_c}";
|
99
|
+
|
100
|
+
if ($this->to_c !== $this->to_var)
|
101
|
+
{
|
102
|
+
$var_part .= ", {$this->to_c}";
|
103
|
+
}
|
104
|
+
|
105
|
+
if (isset($this->step) && $this->step !== $this->step_var)
|
106
|
+
{
|
107
|
+
$var_part .= ", {$this->step}";
|
108
|
+
}
|
109
|
+
|
110
|
+
list($lt, $gt) = array("{$idx} <{$this->equals}", "{$idx} >{$this->equals}");
|
111
|
+
|
112
|
+
if (isset($this->step_num) && self::check($this->step_num))
|
113
|
+
{
|
114
|
+
$cond_part = intval($this->step_num) > 0 ? "{$lt} {$this->to_var}" : "{$gt} {$this->to_var}";
|
115
|
+
}
|
116
|
+
else if ($known)
|
117
|
+
{
|
118
|
+
list($from, $to) = array(intval($this->from_num), intval($this->to_num));
|
119
|
+
$cond_part = $from <= $to ? "{$lt} {$to}" : "{$gt} {$to}";
|
120
|
+
}
|
121
|
+
else
|
122
|
+
{
|
123
|
+
$cond = "{$this->from_var} <= {$this->to_var}";
|
124
|
+
$cond_part = "{$cond} ? {$lt} {$this->to_var} : {$gt} {$this->to_var}";
|
125
|
+
}
|
126
|
+
|
127
|
+
if (isset($this->step_var) && $this->step_var)
|
128
|
+
{
|
129
|
+
$step_part = "{$idx} += {$this->step_var}";
|
130
|
+
}
|
131
|
+
else if ($known)
|
132
|
+
{
|
133
|
+
if ($named_index)
|
134
|
+
{
|
135
|
+
$step_part = $from <= $to ? "++{$idx}" : "--{$idx}";
|
136
|
+
}
|
137
|
+
else
|
138
|
+
{
|
139
|
+
$step_part = $from <= $to ? "{$idx}++" : "{$idx}--";
|
140
|
+
}
|
141
|
+
}
|
142
|
+
else
|
143
|
+
{
|
144
|
+
if ($named_index)
|
145
|
+
{
|
146
|
+
$step_part = "{$cond} ? ++{$idx} : --{$idx}";
|
147
|
+
}
|
148
|
+
else
|
149
|
+
{
|
150
|
+
$step_part = "{$cond} ? {$idx}++ : {$idx}--";
|
151
|
+
}
|
152
|
+
}
|
153
|
+
|
154
|
+
if ($named_index)
|
155
|
+
{
|
156
|
+
$var_part = "{$idx_name} = {$var_part}";
|
157
|
+
$step_part = "{$idx_name} = {$step_part}";
|
158
|
+
}
|
159
|
+
|
160
|
+
return "{$var_part}; {$cond_part}; {$step_part}";
|
161
|
+
}
|
162
|
+
|
163
|
+
function compile_simple($options)
|
164
|
+
{
|
165
|
+
list($from, $to) = array($this->from_num, $this->to_num);
|
166
|
+
|
167
|
+
$idx = del($options, 'index');
|
168
|
+
$step = del($options, 'step');
|
169
|
+
|
170
|
+
if ($step)
|
171
|
+
{
|
172
|
+
$stepvar = $options['scope']->free_variable('step');
|
173
|
+
}
|
174
|
+
|
175
|
+
$var_part = "{$idx} = {$from}";
|
176
|
+
|
177
|
+
if ($step)
|
178
|
+
{
|
179
|
+
$var_part .= ", {$stepvar} = ".$step->compile($options);
|
180
|
+
}
|
181
|
+
|
182
|
+
$cond_part = $from <= $to ? "{$idx} <{$this->equals} {$to}" : "{$idx} >{$this->equals} {$to}";
|
183
|
+
|
184
|
+
if ($step)
|
185
|
+
{
|
186
|
+
$step_part = "{$idx} += {$stepvar}";
|
187
|
+
}
|
188
|
+
else
|
189
|
+
{
|
190
|
+
$step_part = $from <= $to ? "{$idx}++" : "{$idx}--";
|
191
|
+
}
|
192
|
+
|
193
|
+
return "{$var_part}; {$cond_part}; {$step_part}";
|
194
|
+
}
|
195
|
+
|
196
|
+
function compile_variables($options)
|
197
|
+
{
|
198
|
+
$options = array_merge($options, array('top' => TRUE));
|
199
|
+
|
200
|
+
list($this->from_c, $this->from_var) = $this->from->cache($options, LEVEL_LIST);
|
201
|
+
list($this->to_c, $this->to_var) = $this->to->cache($options, LEVEL_LIST);
|
202
|
+
|
203
|
+
if ($step = del($options, 'step'))
|
204
|
+
{
|
205
|
+
list($this->step, $this->step_var) = $step->cache($options, LEVEL_LIST);
|
206
|
+
}
|
207
|
+
|
208
|
+
if (preg_match(SIMPLENUM, $this->from_var, $m))
|
209
|
+
{
|
210
|
+
$this->from_num = $m[0];
|
211
|
+
}
|
212
|
+
|
213
|
+
if (preg_match(SIMPLENUM, $this->to_var, $m))
|
214
|
+
{
|
215
|
+
$this->to_num = $m[0];
|
216
|
+
}
|
217
|
+
|
218
|
+
if (isset($this->step_var) && $this->step_var && preg_match(SIMPLENUM, $this->step_var, $m))
|
219
|
+
{
|
220
|
+
$this->step_num = $m[0];
|
221
|
+
}
|
222
|
+
}
|
223
|
+
}
|
224
|
+
|
225
|
+
?>
|
@@ -0,0 +1,56 @@
|
|
1
|
+
<?php
|
2
|
+
|
3
|
+
namespace CoffeeScript;
|
4
|
+
|
5
|
+
class yy_Return extends yy_Base
|
6
|
+
{
|
7
|
+
public $children = array('expression');
|
8
|
+
|
9
|
+
function constructor($expr = NULL)
|
10
|
+
{
|
11
|
+
if ($expr && ! ($expr->unwrap()->is_undefined()))
|
12
|
+
{
|
13
|
+
$this->expression = $expr;
|
14
|
+
}
|
15
|
+
|
16
|
+
return $this;
|
17
|
+
}
|
18
|
+
|
19
|
+
function compile($options, $level = NULL)
|
20
|
+
{
|
21
|
+
$expr = (isset($this->expression) && $this->expression) ? $this->expression->make_return() : NULL;
|
22
|
+
|
23
|
+
if ($expr && ! ($expr instanceof yy_Return))
|
24
|
+
{
|
25
|
+
$ret = $expr->compile($options, $level);
|
26
|
+
}
|
27
|
+
else
|
28
|
+
{
|
29
|
+
$ret = parent::compile($options, $level);
|
30
|
+
}
|
31
|
+
|
32
|
+
return $ret;
|
33
|
+
}
|
34
|
+
|
35
|
+
function compile_node($options)
|
36
|
+
{
|
37
|
+
return $this->tab.'return'.(isset($this->expression) && $this->expression ? ' '.$this->expression->compile($options, LEVEL_PAREN) : '').';';
|
38
|
+
}
|
39
|
+
|
40
|
+
function is_statement($options = NULL)
|
41
|
+
{
|
42
|
+
return TRUE;
|
43
|
+
}
|
44
|
+
|
45
|
+
function jumps()
|
46
|
+
{
|
47
|
+
return $this;
|
48
|
+
}
|
49
|
+
|
50
|
+
function make_return($res = NULL)
|
51
|
+
{
|
52
|
+
return $this;
|
53
|
+
}
|
54
|
+
}
|
55
|
+
|
56
|
+
?>
|
@@ -0,0 +1,47 @@
|
|
1
|
+
<?php
|
2
|
+
|
3
|
+
namespace CoffeeScript;
|
4
|
+
|
5
|
+
class yy_Slice extends yy_Base
|
6
|
+
{
|
7
|
+
public $children = array('range');
|
8
|
+
|
9
|
+
function constructor($range)
|
10
|
+
{
|
11
|
+
$this->range = $range;
|
12
|
+
|
13
|
+
return $this;
|
14
|
+
}
|
15
|
+
|
16
|
+
function compile_node($options)
|
17
|
+
{
|
18
|
+
$to = $this->range->to;
|
19
|
+
$from = $this->range->from;
|
20
|
+
|
21
|
+
$from_str = $from ? $from->compile($options, LEVEL_PAREN) : '0';
|
22
|
+
$compiled = $to ? $to->compile($options, LEVEL_PAREN) : '';
|
23
|
+
|
24
|
+
if ($to && ! ( ! $this->range->exclusive && intval($compiled) === -1))
|
25
|
+
{
|
26
|
+
$to_str = ', ';
|
27
|
+
|
28
|
+
if ($this->range->exclusive)
|
29
|
+
{
|
30
|
+
$to_str .= $compiled;
|
31
|
+
}
|
32
|
+
else if (preg_match(SIMPLENUM, $compiled))
|
33
|
+
{
|
34
|
+
$to_str .= (intval($compiled) + 1);
|
35
|
+
}
|
36
|
+
else
|
37
|
+
{
|
38
|
+
$compiled = $to->compile($options, LEVEL_ACCESS);
|
39
|
+
$to_str .= "{$compiled} + 1 || 9e9";
|
40
|
+
}
|
41
|
+
}
|
42
|
+
|
43
|
+
return ".slice({$from_str}".(isset($to_str) ? $to_str : '').')';
|
44
|
+
}
|
45
|
+
}
|
46
|
+
|
47
|
+
?>
|
@@ -0,0 +1,100 @@
|
|
1
|
+
<?php
|
2
|
+
|
3
|
+
namespace CoffeeScript;
|
4
|
+
|
5
|
+
class yy_Splat extends yy_Base
|
6
|
+
{
|
7
|
+
public $children = array('name');
|
8
|
+
|
9
|
+
static function compile_splatted_array($options, $list, $apply = FALSE)
|
10
|
+
{
|
11
|
+
$index = -1;
|
12
|
+
|
13
|
+
while (isset($list[++$index]) && ($node = $list[$index]) && ! ($node instanceof yy_Splat))
|
14
|
+
{
|
15
|
+
continue;
|
16
|
+
}
|
17
|
+
|
18
|
+
if ($index >= count($list))
|
19
|
+
{
|
20
|
+
return '';
|
21
|
+
}
|
22
|
+
|
23
|
+
if (count($list) === 1)
|
24
|
+
{
|
25
|
+
$code = $list[0]->compile($options, LEVEL_LIST);
|
26
|
+
|
27
|
+
if ($apply)
|
28
|
+
{
|
29
|
+
return $code;
|
30
|
+
}
|
31
|
+
|
32
|
+
return utility('slice').".call({$code})";
|
33
|
+
}
|
34
|
+
|
35
|
+
$args = array_slice($list, $index);
|
36
|
+
|
37
|
+
foreach ($args as $i => $node)
|
38
|
+
{
|
39
|
+
$code = $node->compile($options, LEVEL_LIST);
|
40
|
+
$args[$i] = ($node instanceof yy_Splat) ? utility('slice').".call({$code})" : "[{$code}]";
|
41
|
+
}
|
42
|
+
|
43
|
+
if ($index === 0)
|
44
|
+
{
|
45
|
+
return $args[0].'.concat('.implode(', ', array_slice($args, 1)).')';
|
46
|
+
}
|
47
|
+
|
48
|
+
$base = array();
|
49
|
+
|
50
|
+
foreach (array_slice($list, 0, $index) as $node)
|
51
|
+
{
|
52
|
+
$base[] = $node->compile($options, LEVEL_LIST);
|
53
|
+
}
|
54
|
+
|
55
|
+
return '['.implode(', ', $base).'].concat('.implode(', ', $args).')';
|
56
|
+
}
|
57
|
+
|
58
|
+
function constructor($name)
|
59
|
+
{
|
60
|
+
if (is_object($name))
|
61
|
+
{
|
62
|
+
$this->name = $name;
|
63
|
+
}
|
64
|
+
else
|
65
|
+
{
|
66
|
+
$this->name = yy('Literal', $name);
|
67
|
+
}
|
68
|
+
|
69
|
+
return $this;
|
70
|
+
}
|
71
|
+
|
72
|
+
function assigns($name)
|
73
|
+
{
|
74
|
+
return $this->name->assigns($name);
|
75
|
+
}
|
76
|
+
|
77
|
+
function compile($options, $level = NULL)
|
78
|
+
{
|
79
|
+
if (isset($this->index) && $this->index)
|
80
|
+
{
|
81
|
+
return $this->compile_param($options);
|
82
|
+
}
|
83
|
+
else
|
84
|
+
{
|
85
|
+
return $this->name->compile($options);
|
86
|
+
}
|
87
|
+
}
|
88
|
+
|
89
|
+
function is_assignable()
|
90
|
+
{
|
91
|
+
return TRUE;
|
92
|
+
}
|
93
|
+
|
94
|
+
function unwrap()
|
95
|
+
{
|
96
|
+
return $this->name;
|
97
|
+
}
|
98
|
+
}
|
99
|
+
|
100
|
+
?>
|
@@ -0,0 +1,121 @@
|
|
1
|
+
<?php
|
2
|
+
|
3
|
+
namespace CoffeeScript;
|
4
|
+
|
5
|
+
class yy_Switch extends yy_Base
|
6
|
+
{
|
7
|
+
public $children = array('subject', 'cases', 'otherwise');
|
8
|
+
|
9
|
+
function constructor($subject = NULL, $cases = array(), $otherwise = NULL)
|
10
|
+
{
|
11
|
+
$this->subject = $subject;
|
12
|
+
$this->cases = $cases;
|
13
|
+
$this->otherwise = $otherwise;
|
14
|
+
|
15
|
+
return $this;
|
16
|
+
}
|
17
|
+
|
18
|
+
function compile_node($options)
|
19
|
+
{
|
20
|
+
$idt1 = $options['indent'].TAB;
|
21
|
+
$idt2 = $options['indent'] = $idt1.TAB;
|
22
|
+
|
23
|
+
$code = $this->tab.'switch ('
|
24
|
+
.($this->subject ? $this->subject->compile($options, LEVEL_PAREN) : 'false')
|
25
|
+
.") {\n";
|
26
|
+
|
27
|
+
foreach ($this->cases as $i => $case)
|
28
|
+
{
|
29
|
+
list($conditions, $block) = $case;
|
30
|
+
|
31
|
+
foreach (flatten(array($conditions)) as $cond)
|
32
|
+
{
|
33
|
+
if ( ! $this->subject)
|
34
|
+
{
|
35
|
+
$cond = $cond->invert();
|
36
|
+
}
|
37
|
+
|
38
|
+
$code .= $idt1.'case '.$cond->compile($options, LEVEL_PAREN).":\n";
|
39
|
+
}
|
40
|
+
|
41
|
+
if ($body = $block->compile($options, LEVEL_TOP))
|
42
|
+
{
|
43
|
+
$code .= $body."\n";
|
44
|
+
}
|
45
|
+
|
46
|
+
if ($i === (count($this->cases) - 1) && ! $this->otherwise)
|
47
|
+
{
|
48
|
+
break;
|
49
|
+
}
|
50
|
+
|
51
|
+
$expr = $this->last_non_comment($block->expressions);
|
52
|
+
|
53
|
+
if ($expr instanceof yy_Return ||
|
54
|
+
($expr instanceof yy_Literal && $expr->jumps() && ''.$expr->value !== 'debugger'))
|
55
|
+
{
|
56
|
+
continue;
|
57
|
+
}
|
58
|
+
|
59
|
+
$code .= $idt2."break;\n";
|
60
|
+
}
|
61
|
+
|
62
|
+
if ($this->otherwise && count($this->otherwise->expressions))
|
63
|
+
{
|
64
|
+
$code .= $idt1."default:\n".$this->otherwise->compile($options, LEVEL_TOP)."\n";
|
65
|
+
}
|
66
|
+
|
67
|
+
return $code.$this->tab.'}';
|
68
|
+
}
|
69
|
+
|
70
|
+
function is_statement($options = NULL)
|
71
|
+
{
|
72
|
+
return TRUE;
|
73
|
+
}
|
74
|
+
|
75
|
+
function jumps($options = array())
|
76
|
+
{
|
77
|
+
if ( ! isset($options['block']))
|
78
|
+
{
|
79
|
+
$options['block'] = TRUE;
|
80
|
+
}
|
81
|
+
|
82
|
+
foreach ($this->cases as $case)
|
83
|
+
{
|
84
|
+
list($conds, $block) = $case;
|
85
|
+
|
86
|
+
if ($block->jumps($options))
|
87
|
+
{
|
88
|
+
return $block;
|
89
|
+
}
|
90
|
+
}
|
91
|
+
|
92
|
+
if (isset($this->otherwise) && $this->otherwise)
|
93
|
+
{
|
94
|
+
return $this->otherwise->jumps($options);
|
95
|
+
}
|
96
|
+
|
97
|
+
return FALSE;
|
98
|
+
}
|
99
|
+
|
100
|
+
function make_return($res = NULL)
|
101
|
+
{
|
102
|
+
foreach ($this->cases as $pair)
|
103
|
+
{
|
104
|
+
$pair[1]->make_return($res);
|
105
|
+
}
|
106
|
+
|
107
|
+
if ($res && ! $this->otherwise)
|
108
|
+
{
|
109
|
+
$this->otherwise = yy('Block', array(yy('Literal', 'void 0')));
|
110
|
+
}
|
111
|
+
|
112
|
+
if ($this->otherwise)
|
113
|
+
{
|
114
|
+
$this->otherwise->make_return($res);
|
115
|
+
}
|
116
|
+
|
117
|
+
return $this;
|
118
|
+
}
|
119
|
+
}
|
120
|
+
|
121
|
+
?>
|