Affiliation:
1. University of Massachusetts at Amherst, USA
2. University of California at San Diego, USA
3. Brown University, USA
Abstract
Scores of compilers produce JavaScript, enabling programmers to use many languages on the Web, reuse existing code, and even use Web IDEs. Unfortunately, most compilers inherit the browser's compromised execution model, so long-running programs freeze the browser tab, infinite loops crash IDEs, and so on. The few compilers that avoid these problems suffer poor performance and are difficult to engineer.
This paper presents Stopify, a source-to-source compiler that extends JavaScript with debugging abstractions and blocking operations, and easily integrates with existing compilers. We apply Stopify to ten programming languages and develop a Web IDE that supports stopping, single-stepping, breakpointing, and long-running computations. For nine languages, Stopify requires no or trivial compiler changes. For eight, our IDE is the first that provides these features. Two of our subject languages have compilers with similar features. Stopify's performance is competitive with these compilers and it makes them dramatically simpler.
Stopify's abstractions rely on first-class continuations, which it provides by compiling JavaScript to JavaScript. We also identify sub-languages of JavaScript that compilers implicitly use, and exploit these to improve performance. Finally, Stopify needs to repeatedly interrupt and resume program execution. We use a sampling-based technique to estimate program speed that outperforms other systems.
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Reference81 articles.
1. Babylon: A JavaScript parser used in Babel. htps://github.com/babel/ babel/tree/master/packages/babylon . Accessed Nov 10 2017. Babylon: A JavaScript parser used in Babel. htps://github.com/babel/ babel/tree/master/packages/babylon . Accessed Nov 10 2017.
2. CONS should not CONS its arguments, part II
3. Representing control in the presence of one-shot continuations
4. It's alive! continuous feedback in UI programming
5. Scaling up functional programming education: under the hood of the OCaml MOOC
Cited by
2 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Teaching Programming to Novices Using the codeBoot Online Environment;Electronic Proceedings in Theoretical Computer Science;2022-07-26
2. Microsoft MakeCode: embedded programming for education, in blocks and TypeScript;Proceedings of the 2019 ACM SIGPLAN Symposium on SPLASH-E - SPLASH-E 2019;2019