@danielx/civet 0.2.7 → 0.2.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -115,3 +115,11 @@ Things Added that CoffeeScript didn't
115
115
  console.log "hi"
116
116
  ```
117
117
  - TypeScript Types
118
+
119
+ Things Changed from ES6
120
+ ---
121
+
122
+ - Disallow no parens on single argument arrow function. `x => ...` must become `(x) => ...`
123
+ The reasoning is `x -> ` => `x(function() ...)` in CoffeeScript and having `->` and `=>`
124
+ behave more differently than they already do is bad. Passing an anonymous function to an
125
+ application without parens is also convenient.
package/dist/browser.js CHANGED
@@ -421,6 +421,7 @@ var Civet = (() => {
421
421
  AssignmentExpressionRest,
422
422
  YieldExpression,
423
423
  ArrowFunction,
424
+ FatArrow,
424
425
  ConciseBody,
425
426
  ConditionalExpression,
426
427
  ShortCircuitExpression,
@@ -951,7 +952,7 @@ var Civet = (() => {
951
952
  }
952
953
  var AssignmentExpressionRest$0 = YieldExpression;
953
954
  var AssignmentExpressionRest$1 = $S($E($S($EXPECT($L7, fail, 'AssignmentExpressionRest "async"'), __)), ArrowFunction);
954
- var AssignmentExpressionRest$2 = $S($P($S(__, LeftHandSideExpression, __, AssignmentOp)), $C($S($Q(_), Expression), $S(__, Expression)));
955
+ var AssignmentExpressionRest$2 = $S($P($S(__, LeftHandSideExpression, __, AssignmentOp)), Expression);
955
956
  var AssignmentExpressionRest$3 = ConditionalExpression;
956
957
  function AssignmentExpressionRest(state) {
957
958
  if (state.tokenize) {
@@ -971,7 +972,7 @@ var Civet = (() => {
971
972
  }
972
973
  }
973
974
  var ArrowFunction$0 = ThinArrowFunction;
974
- var ArrowFunction$1 = $S($C(BindingIdentifier, Parameters), $E(ReturnTypeSuffix), __, $EXPECT($L10, fail, 'ArrowFunction "=>"'), ConciseBody);
975
+ var ArrowFunction$1 = $S(Parameters, $E(ReturnTypeSuffix), FatArrow, ConciseBody);
975
976
  function ArrowFunction(state) {
976
977
  if (state.tokenize) {
977
978
  return $TOKEN("ArrowFunction", state, ArrowFunction$0(state) || ArrowFunction$1(state));
@@ -979,8 +980,23 @@ var Civet = (() => {
979
980
  return ArrowFunction$0(state) || ArrowFunction$1(state);
980
981
  }
981
982
  }
982
- var ConciseBody$0 = $S($N($S($Q(_), $EXPECT($L11, fail, 'ConciseBody "{"'))), AssignmentExpression);
983
- var ConciseBody$1 = $S(EOS, SingleNestedBlockExpression);
983
+ var FatArrow$0 = $TS($S(__, $EXPECT($L10, fail, 'FatArrow "=>"')), function($skip, $loc, $0, $1, $2) {
984
+ var ws = $1;
985
+ if (!ws.length)
986
+ return " =>";
987
+ return $0;
988
+ });
989
+ function FatArrow(state) {
990
+ if (state.verbose)
991
+ console.log("ENTER:", "FatArrow");
992
+ if (state.tokenize) {
993
+ return $TOKEN("FatArrow", state, FatArrow$0(state));
994
+ } else {
995
+ return FatArrow$0(state);
996
+ }
997
+ }
998
+ var ConciseBody$0 = $S(EOS, SingleNestedBlockExpression);
999
+ var ConciseBody$1 = $S($N($S($Q(_), $EXPECT($L11, fail, 'ConciseBody "{"'))), AssignmentExpression);
984
1000
  var ConciseBody$2 = BracedBlock;
985
1001
  function ConciseBody(state) {
986
1002
  if (state.tokenize) {
@@ -1419,7 +1435,7 @@ var Civet = (() => {
1419
1435
  return BracedBlock$0(state) || BracedBlock$1(state) || BracedBlock$2(state);
1420
1436
  }
1421
1437
  }
1422
- var SingleNestedBlockExpression$0 = $TS($S(PushIndent, $E($S(Nested, $C(Declaration, Statement))), PopIndent), function($skip, $loc, $0, $1, $2, $3) {
1438
+ var SingleNestedBlockExpression$0 = $TS($S(PushIndent, $E($S(Nested, $C(Declaration, Statement))), $C($C($N($S(Nested, $C(Declaration, Statement))), $S(PopIndent, $N($EXPECT($L30, fail, 'SingleNestedBlockExpression ""')))), PopIndent)), function($skip, $loc, $0, $1, $2, $3) {
1423
1439
  var exp = $2;
1424
1440
  if (exp)
1425
1441
  return exp;