Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(432)

Side by Side Diff: lib/runtime/harmony_feature_check.js

Issue 1169473003: fixes #43, remove => workaround (Closed) Base URL: git@github.com:dart-lang/dev_compiler.git@master
Patch Set: Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « lib/runtime/dart/isolate.js ('k') | lib/src/js/nodes.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 // Feature test for harmony support, alert if not present. 5 // Feature test for harmony support, alert if not present.
6 (function () { 6 (function () {
7 try { 7 try {
8 var f = new Function( 8 var f = new Function(
9 '"use strict";'+ 9 '"use strict";'+
10 'class C {' + 10 'class C {' +
11 'constructor(x) { this.x = x; };' + 11 'constructor(x) { this.x = x; };' +
12 // TODO(jmesserly): arrow functions on V8 don't have lexical this yet. 12 '["foo"]() { return x => this.x + x; };' +
13 // https://code.google.com/p/v8/issues/detail?id=2700
14 '["foo"]() { var self = this; return x => self.x + x; };' +
15 '};' + 13 '};' +
16 'return new C(42).foo()(100);'); 14 'return new C(42).foo()(100);');
17 if (f() == 142) return; // supported! 15 if (f() == 142) return; // supported!
18 } catch (e) { 16 } catch (e) {
19 } 17 }
20 18
21 var message = 'This script needs EcmaScript 6 features ' + 19 var message = 'This script needs EcmaScript 6 features ' +
22 'like `class` and `=>`. Please run in a browser with support, ' + 20 'like `class` and `=>`. Please run in a browser with support, ' +
23 'for example: chrome --js-flags="--harmony-arrow-functions' + 21 'for example: chrome --js-flags="--harmony-arrow-functions' +
24 ' --harmony-classes --harmony-computed-property-names"'; 22 ' --harmony-classes --harmony-computed-property-names"';
25 console.error(message); 23 console.error(message);
26 alert(message); 24 alert(message);
27 25
28 })(); 26 })();
OLDNEW
« no previous file with comments | « lib/runtime/dart/isolate.js ('k') | lib/src/js/nodes.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698