Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 2 additions & 5 deletions index.js
Original file line number Diff line number Diff line change
@@ -1,10 +1,7 @@
var aparse = require('acorn').parse;
var aparse = require('acorn-node').parse;
function parse (src, opts) {
if (!opts) opts = {}
return aparse(src, {
ecmaVersion: opts.ecmaVersion || 8,
allowHashBang: true
});
return aparse(src, opts);
}

module.exports = function (src, file,opts) {
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
"description": "detect and report syntax errors in source code strings",
"main": "index.js",
"dependencies": {
"acorn": "^4.0.3"
"acorn-node": "^1.2.0"
},
"devDependencies": {
"tap": "^1.1.0"
Expand Down
7 changes: 3 additions & 4 deletions readme.markdown
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ if (err) {
}
```

***
---

```
$ node check.js
Expand Down Expand Up @@ -55,9 +55,8 @@ stringified.

If there are no syntax errors in `src`, return `undefined`.

Optionally set:

* `opts.ecmaVersion` - default: 8
Options will be passed through to [acorn-node](https://github.com/browserify/acorn-node).
acorn-node defaults to options that match the most recent Node versions.

## err.toString()

Expand Down
23 changes: 23 additions & 0 deletions test/esm.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
var test = require('tap').test;

var fs = require('fs');
var check = require('../');

var file = __dirname + '/sources/esm.js';
var src = fs.readFileSync(file);

test('esm with sourceType script', function (t) {
var err = check(src, file);
t.ok(err);
t.equal(err.line, 1);
t.equal(err.column, 1);
t.equal(err.message, "'import' and 'export' may appear only with 'sourceType: module'");
t.ok(String(err).indexOf(file + ':1'));
t.end();
});

test('esm with sourceType module', function (t) {
var err = check(src, file, { sourceType: 'module' });
t.notOk(err);
t.end();
});
2 changes: 2 additions & 0 deletions test/sources/esm.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
import x from 'y';
export default z;
2 changes: 2 additions & 0 deletions test/sources/spread.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
var a = { ...b }
;({ d, ...e } = a)
13 changes: 13 additions & 0 deletions test/spread.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
var test = require('tap').test;

var fs = require('fs');
var check = require('../');

var file = __dirname + '/sources/spread.js';
var src = fs.readFileSync(file);

test('spread', function (t) {
var err = check(src, file);
t.notOk(err);
t.end();
});