Coffeescript Quick Reference

Total Page:16

File Type:pdf, Size:1020Kb

Coffeescript Quick Reference Objects and arrays Loops and Comprehensions If, Else, Unless, and Conditional Assignment · · Objects and arrays are similar to Comprehensions for ... in work · if/else can be written without paren- JavaScript over arrays, objects, and ranges theses and curly braces CoffeeScript · · Comprehensions replace for loops, When each property is listed on its own · Multi-line conditionals are delimited by with optional when guard clauses and line, the commas are optional indentation Quick Reference the value of the current array index: · Objects may be created using indenta- · if and unless can be used in postfix tion instead of explicit braces, similar to for value, index in array form i.e. at the end of the statement coffeescript.org YAML · Array comprehensions are expressions, and can be returned and assigned · · Reserved words, like class, can be used if statements can be used as expres- · as properties of an object without quot- Comprehensions may replace sions. No need for ?: ing them as strings each/forEach, map or select/filter · Use a range when the start and end of a 1 loop is known (integer steps) Chained Comparisons General Lexical Scoping and Variable Safety · Use by to step in fixed-size increments · Whitespace is significant · · · Variables are declared implicitly when When assigning the value of a compre- Use a chained comparison to test if a · Ending a line will terminate expressions used (no var keyword). hension to a variable, CoffeeScript col- value is within a range: - no need to use semicolons lects the result of each iteration into an minimum < value < maximum · The compiler ensures that variables are · array Semicolons can be used to fit multiple declared within lexical scope. An outer · expressions onto a single line variable is not redeclared within an in- Return null, undefined or true if a · Use indentation instead of curly braces ner function when it is in scope loop is only for side-effects Array Slicing and Splicing with Ranges {} to surround blocks of code in · · Using an inner variable can not shadow To iterate over the key and value prop- functions, if statements, switch, and an outer variable, only refer to it. So erties in an object, use of · Ranges can be used to extract slices of try/catch avoid reusing the name of an external · Use: for own key, value of object arrays · Comments starts with # and run to the variable in a deeply nested function to iterate over the keys that are directly · end of the line With two dots [3..6], the range is in- · CoffeeScript output is wrapped in an defined on an object clusive (3, 4, 5, 6) anonymous function, making it diffi- · The only low-level loop is the while · With three dots [3...6], the range ex- Functions cult to accidentally pollute the global loop. It can be used as an expression, cludes the end (3, 4, 5) namespace returning an array containing the result · Functions are defined by an optional list of each iteration through the loop · The same syntax can be used with as- · To create top-level variables for other of parameters in parentheses, an arrow, signment to replace a segment of an ar- scripts, attach them as properties on · until is equivalent to while not and an optional function body. The ray with new values, splicing it window, or to exports in CommonJS. · loop is equivalent to while true empty function looks like: -> · · Use: exports ? this · The do keyword inserts a closure wrap- Strings are immutable and can not be Mostly no need to use parentheses to spliced invoke a function if it is passed argu- per, forwards any arguments and in- vokes a passed function ments. The implicit call wraps forward Splats to the end of the line or block expres- sion. · Splats ... can be used instead of the Try/Catch/Finally Embedded JavaScript · Functions may have default values for variable number of arguments object arguments. Override the default value and are available for both function def- · try/catch statements are as in · Use backquotes `` to embed JavaScript by passing a non-null argument. inition and invocation JavaScript (although expressions) code within CoffeeScript 1 E. Hoigaard © 2554/2011 Rev. α 1 Everything is an Expression Existential Operator Destructuring Assignment · Multiple values, comma separated, can be given for each when clause. If any of · · Functions return their final value Use the existential operator ? to check if · To make extracting values from com- the values match, the clause runs · The return value is fetched from each a variable exists. ? returns true unless plex arrays and objects convenient, branch of execution a variable is null or undefined CoffeeScript implements destructuring · Use ?= for safer conditional assignment assignment String Interpolation, Heredocs, and Block Comments · Return early from a function body by than ||= with numbers or strings · When assigning an array or object lit- using an explicit return · Single-quoted strings are literal. Use · The accessor variant of the existential eral to a value, CoffeeScript breaks up · Variable declarations are at the top of backslash for escape characters operator ?. can be used to soak up null and matches both sides against each the scope, so assignment can be used · references in a chain of properties other, assigning the values on the right Double-quoted strings allow for inter- within expressions, even for variables polated values, using #{ ... } · Use ?. instead of the dot accessor . in to the variables on the left that have not been seen before · cases where the base value may be null · The simplest case is parallel assignment Multiline strings are allowed · Statements, when used as part of an ex- or undefined. If all of the properties ex- [a,b] = [b,a] · A heredoc ''' can be used for formatted pression, are converted into expressions ist then the expected result is returned, · It can be used with functions that return or indentation-sensitive text (or to avoid with a closure wrapper. This allows as- if the chain is broken, then undefined is escaping quotes and apostrophes) signment of the result of a comprehen- multiple values returned instead · sion to a variable · It can be used with any depth of array The indentation level that begins a here- · and object nesting to get deeply nested doc is maintained throughout, so the The following are not expressions: Classes, Inheritance, and Super text can be aligned with the body of the break, continue, and return properties and can be combined with splats code · Object orientation as in most other ob- · Double-quoted heredocs """ allow for ject oriented languages Operators and Aliases interpolation · The class structure allows to name the Function binding · Block comments ### are similar to · class, set the superclass with extends, CoffeeScript compiles == into ===, and heredocs, and are preserved in the gen- assign prototypal properties, and define · The fat arrow => can be used to define a != into !==. There is no equivalent to erated code the JavaScript == operator a constructor, in a single assignable function and bind it to the current value expression of this · The alias is is equivalent to ===, and · · isnt corresponds to !== Constructor functions are named as the This is helpful when using callback- Extended Regular Expressions class name, to support reflection based libraries, for creating iterator · Logical operator aliases: and is &&, or is · · Lower level operators: The extends functions to pass to each or event- Extended regular expressions are de- || and not is an alias for ! operator helps with proper prototype handler functions to use with bind limited by /// and are similar to here- · In while, if/else and switch/when docs and block comments. setup. :: gives access to an object’s · Functions created with => are able to ac- statements the then keyword can be prototype. super() calls the immediate cess properties of the this where they · They ignore internal whitespace and used to keep the body on the same line ancestor’s method of the same name are defined can contain comments · Alias for boolean true is on and yes (as · A class definition is a block of exe- in YAML) cutable code, which may be used for Aliases · Alias for boolean false is off and no meta programming. Switch/When/Else · · In the context of a class definition, For single-line statements, unless can · The switch statement do not need a and : && or : || not :! this is the class object itself (the be used as the inverse of if break after every case is : == isnt : != constructor function), so static · Use @property or @method instead of · properties can be assigned by using A switch is a returnable, assignable ex- yes : true no : false this.something @property: value, and functions de- pression on : true off : false · Use in to test for array presence fined in parent classes can be called · The format is: switch condition, when · Use of to test for object-key presence with: @inheritedMethodName() clauses, else the default case http://autotelicum.github.com/Smooth-CoffeeScript/ 2.
Recommended publications
  • Coffeescript Accelerated Javascript Development.Pdf
    Download from Wow! eBook <www.wowebook.com> What readers are saying about CoffeeScript: Accelerated JavaScript Development It’s hard to imagine a new web application today that doesn’t make heavy use of JavaScript, but if you’re used to something like Ruby, it feels like a significant step down to deal with JavaScript, more of a chore than a joy. Enter CoffeeScript: a pre-compiler that removes all the unnecessary verbosity of JavaScript and simply makes it a pleasure to write and read. Go, go, Coffee! This book is a great introduction to the world of CoffeeScript. ➤ David Heinemeier Hansson Creator, Rails Just like CoffeeScript itself, Trevor gets straight to the point and shows you the benefits of CoffeeScript and how to write concise, clear CoffeeScript code. ➤ Scott Leberknight Chief Architect, Near Infinity Though CoffeeScript is a new language, you can already find it almost everywhere. This book will show you just how powerful and fun CoffeeScript can be. ➤ Stan Angeloff Managing Director, PSP WebTech Bulgaria Download from Wow! eBook <www.wowebook.com> This book helps readers become better JavaScripters in the process of learning CoffeeScript. What’s more, it’s a blast to read, especially if you are new to Coffee- Script and ready to learn. ➤ Brendan Eich Creator, JavaScript CoffeeScript may turn out to be one of the great innovations in web application development; since I first discovered it, I’ve never had to write a line of pure JavaScript. I hope the readers of this wonderful book will be able to say the same. ➤ Dr. Nic Williams CEO/Founder, Mocra CoffeeScript: Accelerated JavaScript Development is an excellent guide to Coffee- Script from one of the community’s most esteemed members.
    [Show full text]
  • Chapter 1: Introduction to the Pencil Code Environment
    Chapter 1: Introduction to the Pencil Code Environment In this manual we will show how to use Pencil Code to explore programming. Pencil Code is a free programming tool available at pencilcode.net. Pencil Code was developed by Google engineer David Bau together with his son Anthony Bau, with open-source contributions from many others. Two Ways of Looking at a Program There are two ways of viewing a program. A computer user sees a program by looking at its output. A programmer works with a program’s source code. In Pencil Code, the screen is split into two halves, with the source code on the left and the output on the right. You run programs by by pressing the “play” button in the middle. The Pencil Code interface splits the screen, showing source code on the left and output on the right. The play button in the center runs the code and produces output. Languages and Libraries in Pencil Code Pencil Code supports code in both blocks and text using mainstream web programming languages and useful libraries including: • HTML, the standard HyperText Markup Language for the web. • JavaScript, the standard programming language of web browsers. • CSS, the standard Cascading Style Sheet language for visual styles on the web. • jQuery, a popular library that simplifies programming interactive websites. • CoffeeScript, a language that lets you do more with less typing than JavaScript. • jQuery-turtle, which extends jQuery to simplify graphics and animation for novices. With Pencil Code, students can use these technologies to create web applications with global visibility and impact while exploring fundamental concepts in computational thinking.
    [Show full text]
  • Coffeescript Accelerated Javascript Development, Second Edition
    Extracted from: CoffeeScript Accelerated JavaScript Development, Second Edition This PDF file contains pages extracted from CoffeeScript, published by the Prag- matic Bookshelf. For more information or to purchase a paperback or PDF copy, please visit http://www.pragprog.com. Note: This extract contains some colored text (particularly in code listing). This is available only in online versions of the books. The printed versions are black and white. Pagination might vary between the online and printed versions; the content is otherwise identical. Copyright © 2015 The Pragmatic Programmers, LLC. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form, or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior consent of the publisher. The Pragmatic Bookshelf Dallas, Texas • Raleigh, North Carolina CoffeeScript Accelerated JavaScript Development, Second Edition Trevor Burnham The Pragmatic Bookshelf Dallas, Texas • Raleigh, North Carolina Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book, and The Pragmatic Programmers, LLC was aware of a trademark claim, the designations have been printed in initial capital letters or in all capitals. The Pragmatic Starter Kit, The Pragmatic Programmer, Pragmatic Programming, Pragmatic Bookshelf, PragProg and the linking g device are trade- marks of The Pragmatic Programmers, LLC. Every precaution was taken in the preparation of this book. However, the publisher assumes no responsibility for errors or omissions, or for damages that may result from the use of information (including program listings) contained herein. Our Pragmatic courses, workshops, and other products can help you and your team create better software and have more fun.
    [Show full text]
  • PHP String Interview Questions
    By OnlineInterviewQuestions.com String Interview Questions in PHP Q1. What is String in PHP? The String is a collection or set of characters in sequence in PHP. The String in PHP is used to save and manipulate like an update, delete and read the data. Q2. How to cast a php string to integer? The int or integer used for a variable into an integer in PHP. Q3. How to perform string concatenation in PHP? The string concatenation means two strings connect together. The dot ( . ) sign used in PHP to combine two string. Example:- <?php $stringa = " creative "; $stringb = "writing "; echo $stringa . $stringb; ?> Q4. How to get php string length? To determine the string length in PHP, strlen() function used. Example:- echo strlen(“creative writing”); Q5. List some escape characters in PHP? Some list escape characters in PHP there are:- \’ \” \\ \n \t \r Q6. How to convert special characters to unicode in php? There is function json_encode() which is converted special characters to Unicode in PHP. Example:- $stringa = " I am good at smiling"; print_r(json_encode($stringa)); Q7. How to add double quotes in string in php? The double quotes in string using (" ") sign and write content under this sign. The double quotes convert variable as value. An example is below:- $str8 = " need to read data where has to go "; echo $str 8output: double quotes in the string echo “ PHP work $str8 output: PHP work need to read data where has to go Q8. Explain how php string interpolation is done? The interpolation is adding variables in among a string data. PHP parses the interpolate variables and replaces this variable with own value while processing the string.
    [Show full text]
  • Learning HTML5 Game Programming Addison-Wesley Learning Series
    Learning HTML5 Game Programming Addison-Wesley Learning Series Visit informit.com/learningseries for a complete list of available publications. The Addison-Wesley Learning Series is a collection of hands-on programming guides that help you quickly learn a new technology or language so you can apply what you’ve learned right away. Each title comes with sample code for the application or applications built in the text. This code is fully annotated and can be reused in your own projects with no strings attached. Many chapters end with a series of exercises to encourage you to reexamine what you have just learned, and to tweak or adjust the code as a way of learning. Titles in this series take a simple approach: they get you going right away and leave you with the ability to walk off and build your own application and apply the language or technology to whatever you are working on. Learning HTML5 Game Programming A Hands-on Guide to Building Online Games Using Canvas, SVG, and WebGL James L. Williams Upper Saddle River, NJ • Boston • Indianapolis • San Francisco New York • Toronto • Montreal • London • Munich • Paris • Madrid Cape Town • Sydney • Tokyo • Singapore • Mexico City Many of the designations used by manufacturers and sellers to distinguish their products Associate are claimed as trademarks. Where those designations appear in this book, and the publish- Publisher er was aware of a trademark claim, the designations have been printed with initial capital Mark Taub letters or in all capitals. Senior Acquisitions The author and publisher have taken care in the preparation of this book, but make no Editor expressed or implied warranty of any kind and assume no responsibility for errors or omis- Trina MacDonald sions.
    [Show full text]
  • Coding 101: Learn Ruby in 15 Minutes Visit
    Coding 101: Learn Ruby in 15 minutes Visit www.makers.tech 1 Contents 2 Contents 10 Challenge 3 3 About us 11 Defining Methods 4 Installing Ruby 12 Challenge 4 4 Checking you’ve got Ruby 12 Challenge 5 5 Method calls 12 Challenge 6 5 Variables 13 Arrays 6 Truth and Falsehood 14 Hashes 7 Strings, objects and Methods 14 Challenge 7 8 Challenge 1 15 Iterations 8 Challenge 2 16 Challenge 8 9 Method Chaining 16 Challenge 9 10 Conditionals 18 Extra Challenges 2 About Us At Makers, we are creating a new generation of tech talent who are skilled and ready for the changing world of work. We are inspired by the idea of discovering and unlocking potential in people for the benefit of 21st century business and society. We believe in alternative ways to learn how to code, how to be ready for work and how to be of value to an organisation. At our core, Makers combines tech education with employment possibilities that transform lives. Our intensive four-month program (which includes a month-long PreCourse) sets you up to become a high quality professional software engineer. Makers is the only coding bootcamp with 5 years experience training software developers remotely. Your virtual experience will be exactly the same as Makers on-site, just delivered differently. If you’d like to learn more, check out www.makers.tech. 3 Installing Checking Ruby you’ve got Ruby You’ll be happy to know that Ruby comes preinstalled on all Apple computers. However we can’t simply use the system defaults - just in case we mess something up! Open the terminal on your computer and then type in If you’ve got your laptop set up already you can skip this section.
    [Show full text]
  • Open Source on IBM I Webinar Series Day 2 ERWIN EARLEY ([email protected]), SR
    Open Source on IBM i Webinar Series Day 2 ERWIN EARLEY ([email protected]), SR. SOLUTIONS CONSULTANT, PERFORCE, NOVEMBER 2019 2 | COMMON Webinar Series: Open Source on IBM i | November 2019 zend.com Day 1 Review • Introduction to Open Source on IBM i • Why is Open Source on IBM i Important • Understanding the PASE environment as the enabler of Open Source on IBM i • Getting Familiar with the PASE environment 2 | Zend by Perforce © 2019 Perforce Software, Inc. zend.com 3 | COMMON Webinar Series: Open Source on IBM i | November 2019 zend.com Day 2 Agenda • Setting up OSS EcoSystem on IBM i – ACS version • Exploring Containers on IBM i • Managing Open Source on IBM i • Exploring Open Source Programming Languages ▪ Integration with Db2 and ILE • After-Hours Lab: Containers & Setting up Development Environment • After-Hours Lab: Open Source Programming Languages 3 | Zend by Perforce © 2019 Perforce Software, Inc. zend.com IBM Systems Technical University © 3 4 | COMMON Webinar Series: Open Source on IBM i | November 2019 zend.com Setting up OSS Ecosystem on IBM i – ACS Version 4 | Zend by Perforce © 2019 Perforce Software, Inc. zend.com 5 | COMMON Webinar Series: Open Source on IBM i | November 2019 zend.com The directory structure Before installing the Open Source ecosystem / dev home lib sbin tmp usr var Directory Contents bin Commands dev Device Files etc Configuration files home User Home Directories lib Libraries pkgs Package files / commands sbin Privileged commands tmp Temporary files usr Utilities & Applications var Variable files
    [Show full text]
  • Webassembly: High Speed at Low Cost for Everyone
    WebAssembly: high speed at low cost for everyone Andreas Rossberg Google [email protected] Abstract instructions that are widely available on modern CPUs. They map WebAssembly is a new language- and platform-independent bi- to machine code in a predictable manner and with predictable nary code format bringing native-code performance to the web. We performance on all relevant platforms. present its design and report our experience with specifying its se- High-level Data Flow. WebAssembly is an expression language: mantics via a reference interpreter written in OCaml, that currently it is defined as an AST in which machine operators return values serves as a proxy for a future formal specification. and can be used as operands to other operators. The binary format is a post-order serialisation of this AST. This design provides for 1. Introduction more compact binaries than 3-address code or SSA form would. Like it or not, the Web has become one of the most important Low-level Control Flow. Control flow is available mainly in the platforms for application development. Yet there is only one pro- form of sequential blocks and branch instructions, plus a structured gramming language that the Web understands: JavaScript. Liter- conditional. However, branches are still structured: they can only ally hundreds of compilers have been written that translate almost break out of an expression, not jump into one. This prevents ir- every imaginable language into JavaScript in order to run on the reducible control flow and associated complications (it’s the pro- Web [1]. Unfortunately, JavaScript is not the most delightful com- ducers’ responsibility to transform irreducible control flow into pilation target: it’s brittle and often slow in unpredictable ways, all structured form [6]).
    [Show full text]
  • A Typescript Program Generator Based on Alloy
    Federal University of Pernambuco Center of Informatics Bachelor’s Program in Computer Engineering A TypeScript program generator based on Alloy Gabriela Araujo Britto Recife 2020 Federal University of Pernambuco Center of Informatics Gabriela Araujo Britto A TypeScript program generator based on Alloy A B.Sc. Dissertation presented to the Bachelor’s Program in Computer Engineering of the Center of Informatics of Federal University of Pernambuco in partial fulfillment of the requirements for the degree of Bachelor of Science in Computer Engineering. Advisor: Leopoldo Motta Teixeira Recife 2020 Abstract Refactoring is the process of modifying code to improve its internal structure, without altering its external behavior. To aid the programmer in the process of applying common refactorings to code, many IDEs provide refactoring implementations that automate the refactoring process. However, in doing so, the refactoring developers must concern themselves with guaranteeing that their refactoring does not change program behavior. Formally verifying that a refactoring preserves behavior is a complex and costly task. Therefore, in practice, developers use tests as an alternative. Testing a refactoring implementation requires programs as test inputs. Manually writing such programs can be tedious and difficult, as there may be many language features to consider. This work proposes a technique for generating TypeScript programs that can be used as input to test refactorings. We implement this technique in a tool called TSDolly. TSDolly uses an Alloy specification of TypeScript language and the Alloy Analyzer to generate instances for this specification, which are then transformed into TypeScript programs. The majority of the generated programs (at least 97.45%) compiled without errors.
    [Show full text]
  • Archive and Compressed [Edit]
    Archive and compressed [edit] Main article: List of archive formats • .?Q? – files compressed by the SQ program • 7z – 7-Zip compressed file • AAC – Advanced Audio Coding • ace – ACE compressed file • ALZ – ALZip compressed file • APK – Applications installable on Android • AT3 – Sony's UMD Data compression • .bke – BackupEarth.com Data compression • ARC • ARJ – ARJ compressed file • BA – Scifer Archive (.ba), Scifer External Archive Type • big – Special file compression format used by Electronic Arts for compressing the data for many of EA's games • BIK (.bik) – Bink Video file. A video compression system developed by RAD Game Tools • BKF (.bkf) – Microsoft backup created by NTBACKUP.EXE • bzip2 – (.bz2) • bld - Skyscraper Simulator Building • c4 – JEDMICS image files, a DOD system • cab – Microsoft Cabinet • cals – JEDMICS image files, a DOD system • cpt/sea – Compact Pro (Macintosh) • DAA – Closed-format, Windows-only compressed disk image • deb – Debian Linux install package • DMG – an Apple compressed/encrypted format • DDZ – a file which can only be used by the "daydreamer engine" created by "fever-dreamer", a program similar to RAGS, it's mainly used to make somewhat short games. • DPE – Package of AVE documents made with Aquafadas digital publishing tools. • EEA – An encrypted CAB, ostensibly for protecting email attachments • .egg – Alzip Egg Edition compressed file • EGT (.egt) – EGT Universal Document also used to create compressed cabinet files replaces .ecab • ECAB (.ECAB, .ezip) – EGT Compressed Folder used in advanced systems to compress entire system folders, replaced by EGT Universal Document • ESS (.ess) – EGT SmartSense File, detects files compressed using the EGT compression system. • GHO (.gho, .ghs) – Norton Ghost • gzip (.gz) – Compressed file • IPG (.ipg) – Format in which Apple Inc.
    [Show full text]
  • Why I Was Wrong About Typescript TJ Vantoll
    Why I Was Wrong About TypeScript TJ VanToll TypeScript TypeScript TypeScript Why I Was Wrong About TypeScript Whether TypeScript is a good fit for your next project Why I Was Wrong About TypeScript “A typed superset of JavaScript that compiles to plain JavaScript” “A typed superset of JavaScript that compiles to plain JavaScript” !" # $ Compile to JavaScript tools • There are a lot. • 345 • Source: https://github.com/jashkenas/coffeescript/wiki/List-of- languages-that-compile-to-JS • Ruby, Python, Erlang, Java, Scala, C#, F#, Lisp, Scheme, Haskell, Smalltalk, C, C++, Basic, Go, PHP, and way more. Fun names of compile-to-JS tools • treehugger • jangaroo • Waterbear http://waterbearlang.com/ Compile to JavaScript tools • There are a lot. • 345 • Source: https://github.com/jashkenas/coffeescript/wiki/List-of- languages-that-compile-to-JS • Ruby, Python, Erlang, Java, Scala, C#, F#, Lisp, Scheme, Haskell, Smalltalk, C, C++, Basic, Go, PHP, and way more. Why I Was Wrong About TypeScript % “We risk a lot by building our core on top of TypeScript.” “I don’t hear anyone talking about TypeScript.” “I like to keep my JavaScript pure, as God intended.” Why I Was Wrong About TypeScript Why? 3 reasons 1) Commitment to the ECMAScript standard “Some examples [of compile-to-JavaScript frameworks], like Dart, portend that JavaScript has fundamental flaws and to support these scenarios requires a “clean break” from JavaScript in both syntax and runtime. We disagree with this point of view. We believe that with committee participant focus, the standards runtime can be expanded and the syntactic features necessary to support JavaScript at scale can be built upon the existing JavaScript standard.” 2) Types are opt-in 3) Tooling So should you use TypeScript? • Are your apps big? • Do you work on a team? • Unfamiliar codebases? • Non JS developers that need to write JS code? Thanks! @tjvantoll http://bit.ly/DR2017-vantoll.
    [Show full text]
  • Specialising Dynamic Techniques for Implementing the Ruby Programming Language
    SPECIALISING DYNAMIC TECHNIQUES FOR IMPLEMENTING THE RUBY PROGRAMMING LANGUAGE A thesis submitted to the University of Manchester for the degree of Doctor of Philosophy in the Faculty of Engineering and Physical Sciences 2015 By Chris Seaton School of Computer Science This published copy of the thesis contains a couple of minor typographical corrections from the version deposited in the University of Manchester Library. [email protected] chrisseaton.com/phd 2 Contents List of Listings7 List of Tables9 List of Figures 11 Abstract 15 Declaration 17 Copyright 19 Acknowledgements 21 1 Introduction 23 1.1 Dynamic Programming Languages.................. 23 1.2 Idiomatic Ruby............................ 25 1.3 Research Questions.......................... 27 1.4 Implementation Work......................... 27 1.5 Contributions............................. 28 1.6 Publications.............................. 29 1.7 Thesis Structure............................ 31 2 Characteristics of Dynamic Languages 35 2.1 Ruby.................................. 35 2.2 Ruby on Rails............................. 36 2.3 Case Study: Idiomatic Ruby..................... 37 2.4 Summary............................... 49 3 3 Implementation of Dynamic Languages 51 3.1 Foundational Techniques....................... 51 3.2 Applied Techniques.......................... 59 3.3 Implementations of Ruby....................... 65 3.4 Parallelism and Concurrency..................... 72 3.5 Summary............................... 73 4 Evaluation Methodology 75 4.1 Evaluation Philosophy
    [Show full text]