Automatic Reasoning Techniques for Non-Serializable

Total Page:16

File Type:pdf, Size:1020Kb

Automatic Reasoning Techniques for Non-Serializable AUTOMATIC REASONING TECHNIQUES FOR NON-SERIALIZABLE DATA-INTENSIVE APPLICATIONS A Dissertation Submitted to the Faculty of Purdue University by Gowtham Kaki In Partial Fulfillment of the Requirements for the Degree of Doctor of Philosophy August 2019 Purdue University West Lafayette, Indiana ii THE PURDUE UNIVERSITY GRADUATE SCHOOL STATEMENT OF DISSERTATION APPROVAL Dr. Suresh Jagannathan, Chair Department of Computer Science Dr. Xiangyu Zhang Department of Computer Science Dr. Tiark Rompf Department of Computer Science Dr. Pedro Fonseca Department of Computer Science Approved by: Dr. Voicu S Popescu Head of the Department Graduate Program iii To Pavani, my source of strength and wisdom. In the pursuit of unity, elegance, and happiness ... iv ACKNOWLEDGMENTS I will be forever grateful to my advisor Suresh Jagannathan, who took a chance on me seven years ago when I had nothing to show except for my enthusiasm for functional programming. Right from the beginning, Suresh has been receptive of my ideas, regardless of how vague and ill-conceived they were, and would patiently work with me over multiple iterations of reifying them into research papers. I have immensely benefited from his constant encouragement to think bold and different, to question fundamental assumptions, and to fearlessly pursue unconventional ap- proaches to their logical conclusion. Working with him over the past seven years has taught me how to think, changed my perception towards research and life in general, and helped me grow as a scientist and a human being. I am thankful to KC Sivaramakrishnan, my long-time collaborator, mentor, and friend, for his constant encouragement and timely feedback. It is KC who introduced me to the fascinating world of distributed data stores, weak consistency and isolation { the focus of my current work, and also the topic of this thesis. I have hugely benefited from the numerous discussions we had over the years on these topics, several of them resulting in new ideas that are now published. As my senior in the research group, KC has set a fine example through the high standards of his work ethic for me to emulate During my internships at Microsoft Research India, I have had the good fortune of collaborating with Ganesan Ramalingam, who, through his own example, reinforced in me such virtues as clarity of thought, intellectual humility, and sense of crafts- manship in doing research. I have also enjoyed my collaborations with several other immensely talented people, including Kartik Nagar, Mahsa Nazafzadeh, Kiarash Rah- mani, Kapil Earanky, and Samodya Abeysiriwardane, each of whom taught me a new perspective in problem solving. v I am fortunate to have been part of a vibrant research community in Programming Languages at Purdue. Gustavo Petri, He Zhu, KC Sivaramakrishnan, and Xuankang Lin helped me bring the Purdue PL (PurPL) reading group into existence in Spring 2014. PurPL has since matured into an umbrella organization for all PL groups at Purdue, thanks to the meticulous work of Tiark Rompf, Roopsha Samantha, Ben Delaware, Milind Kulkarni, and their students. I have personally benefited from the sense of community and belongingness that PurPL fosters among the PL graduate students at Purdue. I am thankful for friendship and encouragement that I received from several of my friends at Purdue, including Abhilash Jindal, GV Srikanth, Priya Murria, Vandith Pamuru, Sivakami Suresh, Habiba Farrukh, Devendra Verma, Raghu Vamsi, Jithin Joseph, Ravi Pramod, Suvidha Kancherla, and Praseem Banzal. They have made my long stay at Purdue enjoyable, and gave me memories that are worth cherishing. I am incredibly lucky to have made lasting friendships during my undergraduate years at BITS, Pilani, which continued to support and sustain me through my Ph.D. Over the last seven years, it is to these friends that I have often turned to during the tough times when I felt an acute need for solace and acceptance. For their unadulterated friendship and unconditional acceptance, I am forever indebted to my friends Bharat and Swathi, Karthik and Vandana, Kartik and Mounica, Kashyap and Nikitha, Krishna and Subbu, Sandeep and Sowjanya, Sasidhar and Prathyusha, Uttam and Sreeja, and Mahesh Lagadapati. They constitute my family beyond my kin. Lastly, but most importantly, I would like to thank my parents for reposing an im- mense faith in my abilities and values, and offering me a complete freedom to pursue my own interests without once expressing any misgiving. My greatest sense of grati- tude however is towards my best friend and wife Pavani without whose unconditional love, tireless support, and constant encouragement none of the work described in this thesis would have been possible; If I have achieved anything through this thesis, it is as much hers as it is mine. vi TABLE OF CONTENTS Page LIST OF TABLES :::::::::::::::::::::::::::::::::: viii LIST OF FIGURES ::::::::::::::::::::::::::::::::: ix ABSTRACT ::::::::::::::::::::::::::::::::::::: xi 1 INTRODUCTION :::::::::::::::::::::::::::::::: 1 1.1 Contributions :::::::::::::::::::::::::::::::: 5 1.1.1 Compositional Reasoning and Inference for Weak Isolation ::: 5 1.1.2 Bounded Verification under Weak Consistency :::::::::: 6 1.1.3 Principled Derivation of Mergeable Replicated Data Types ::: 6 1.2 Roadmap :::::::::::::::::::::::::::::::::: 7 2 COMPOSITIONAL REASONING AND INFERENCE FOR WEAK ISO- LATION :::::::::::::::::::::::::::::::::::::: 8 2.1 Motivation :::::::::::::::::::::::::::::::::: 8 2.2 : Syntax and Semantics ::::::::::::::::::::::::: 18 2.2.1T Isolation Specifications ::::::::::::::::::::::: 24 2.3 The Reasoning Framework ::::::::::::::::::::::::: 27 2.3.1 The Rely-Guarantee Judgment :::::::::::::::::: 28 2.3.2 Semantics and Soundness ::::::::::::::::::::: 33 2.4 Inference ::::::::::::::::::::::::::::::::::: 35 2.4.1 Soundness of Inference ::::::::::::::::::::::: 41 2.4.2 From to the First-Order Logic :::::::::::::::::: 42 2.4.3 DecidabilityS ::::::::::::::::::::::::::::: 47 2.5 ACIDifier Implementation :::::::::::::::::::::::: 49 2.5.1 Pragmatics ::::::::::::::::::::::::::::: 51 2.6 Evaluation :::::::::::::::::::::::::::::::::: 53 2.7 Related Work :::::::::::::::::::::::::::::::: 57 3 BOUNDED VERIFICATION UNDER WEAK CONSISTENCY ::::::: 60 3.1 Replicated State Anomalies: The Motivation for Verification :::::: 61 3.2 The Q9 Programming Framework ::::::::::::::::::::: 63 3.2.1 Explicit Effect Representation ::::::::::::::::::: 67 3.3 System Model :::::::::::::::::::::::::::::::: 70 3.4 The Q9 Verification Engine :::::::::::::::::::::::: 72 3.4.1 Core Calculus :::::::::::::::::::::::::::: 72 3.4.2 Abstract Relations ::::::::::::::::::::::::: 76 vii Page 3.4.3 Symbolic Execution ::::::::::::::::::::::::: 77 3.4.4 Automated Repair ::::::::::::::::::::::::: 86 3.5 Transactions ::::::::::::::::::::::::::::::::: 89 3.6 Implementation and Evaluation :::::::::::::::::::::: 91 3.6.1 Verification Experiments :::::::::::::::::::::: 92 3.6.2 Validation Experiments ::::::::::::::::::::::: 97 3.7 Related Work :::::::::::::::::::::::::::::::: 98 4 DERIVATION OF MERGEABLE REPLICATED DATA TYPES ::::: 102 4.1 Motivation ::::::::::::::::::::::::::::::::: 107 4.2 Abstracting Data Structures as Relations :::::::::::::::: 115 4.3 Deriving Relational Merge Specifications :::::::::::::::: 118 4.3.1 Compositionality ::::::::::::::::::::::::: 119 4.3.2 Type Specifications for Characteristic Relations :::::::: 122 4.3.3 Derivation Rules ::::::::::::::::::::::::: 124 4.4 Deriving Merge Functions :::::::::::::::::::::::: 129 4.4.1 Concretizing Orders ::::::::::::::::::::::: 131 4.5 Implementation :::::::::::::::::::::::::::::: 132 4.5.1 Quark store :::::::::::::::::::::::::::: 133 4.6 Evaluation ::::::::::::::::::::::::::::::::: 134 4.6.1 Data Structure Benchmarks ::::::::::::::::::: 135 4.6.2 Application Benchmarks ::::::::::::::::::::: 139 4.7 Related Work ::::::::::::::::::::::::::::::: 141 5 CONCLUDING REMARKS AND FUTURE WORK :::::::::::: 144 REFERENCES ::::::::::::::::::::::::::::::::::: 148 VITA :::::::::::::::::::::::::::::::::::::::: 157 viii LIST OF TABLES Table Page 2.1 The discovered isolation levels for TPC-C transactions ::::::::::: 56 3.1 Consistency Models ::::::::::::::::::::::::::::::: 88 3.2 A sample of the anomalies found and fixes discovered by Q9 :::::::: 93 3.3 Verification Statistics :::::::::::::::::::::::::::::: 96 4.1 Characteristic relations for various data types ::::::::::::::: 117 4.2 A description of data structure benchmarks used in Quark evaluation. :: 135 4.3 Quark application Benchmarks :::::::::::::::::::::::: 139 ix LIST OF FIGURES Figure Page 2.1 TPC-C new order transaction :::::::::::::::::::::::: 9 2.2 Database schema of TPC-C's order management system. The naming convention indicates primary keys and foreign keys. For e.g., ol id is the primary key column of the order line table, whereas ol o id is a foreign key that refers to the o id column of the order table. :::::::::::: 11 2.3 An RC execution involving two instances (T1 and T2) of the new order trans- action depicted in Fig. 2.1. Both instances read the d id District record concurrently, because neither transaction is committed when the reads are executed. The subsequent operations are effectively sequentialized, since T2 commits before T1. Nonetheless, both transactions read the same value for d next o id resulting in them adding Order records with the same ids, which in turn triggers a violation of TPC-C's consistency condition. :::::::::: 12 2.4 Foreach loop from Fig. 2.1 ::::::::::::::::::::::::::: 16 2.5 : Syntax ::::::::::::::::::::::::::::::::::::
Recommended publications
  • On the Naming of Methods: a Survey of Professional Developers
    On the Naming of Methods: A Survey of Professional Developers Reem S. Alsuhaibani Christian D. Newman Michael J. Decker Michael L. Collard Jonathan I. Maletic Computer Science Software Engineering Computer Science Computer Science Computer Science Kent State University Rochester Institute of Bowling Green State The University of Akron Kent State University Prince Sultan University Technology University Ohio, USA Ohio, USA Riyadh, Saudi Arabia New York, USA Ohio, USA [email protected] [email protected] [email protected] [email protected] [email protected] Abstract—This paper describes the results of a large (+1100 Here, we focus specifically on the names given to methods responses) survey of professional software developers concerning in object-oriented software systems. However, much of this also standards for naming source code methods. The various applies to (free) functions in non-object-oriented systems (or standards for source code method names are derived from and parts). We focus on methods for several reasons. First, we are supported in the software engineering literature. The goal of the interested in method naming in the context of automatic method survey is to determine if there is a general consensus among summarization and documentation. Furthermore, different developers that the standards are accepted and used in practice. programming language constructs have their own naming Additionally, the paper examines factors such as years of guidelines. That is, local variables are named differently than experience and programming language knowledge in the context methods, which are named differently than classes [10,11]. Of of survey responses. The survey results show that participants these, prior work has found that function names have the largest very much agree about the importance of various standards and how they apply to names and that years of experience and the number of unique name variants when analyzed at the level of programming language has almost no effect on their responses.
    [Show full text]
  • Perl 6 Deep Dive
    Perl 6 Deep Dive Data manipulation, concurrency, functional programming, and more Andrew Shitov BIRMINGHAM - MUMBAI Perl 6 Deep Dive Copyright © 2017 Packt Publishing All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews. Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author, nor Packt Publishing, and its dealers and distributors will be held liable for any damages caused or alleged to be caused directly or indirectly by this book. Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information. First published: September 2017 Production reference: 1060917 Published by Packt Publishing Ltd. Livery Place 35 Livery Street Birmingham B3 2PB, UK. ISBN 978-1-78728-204-9 www.packtpub.com Credits Author Copy Editor Andrew Shitov Safis Editing Reviewer Project Coordinator Alex Kapranoff Prajakta Naik Commissioning Editor Proofreader Merint Mathew Safis Editing Acquisition Editor Indexer Chaitanya Nair Francy Puthiry Content Development Editor Graphics Lawrence Veigas Abhinash Sahu Technical Editor Production Coordinator Mehul Singh Nilesh Mohite About the Author Andrew Shitov has been a Perl enthusiast since the end of the 1990s, and is the organizer of over 30 Perl conferences in eight countries.
    [Show full text]
  • Declare Variable on Python
    Declare Variable On Python Is Herby devout when Ambrose presaged familiarly? Rob castigate stertorously. Jake interchanging unwieldily? The final equals sign should point to the value you want to assign to your variables. There are some guidelines you need to know before you name a variable. Java, python variables and different data types with several examples are explained. There is a question that always hovers among Python programmers. Strings are declared within a single or double quote. Break a string based on some rule. It is very important that the number of variables on that line equals the number of values; otherwise, and can be subdivided into two basic categories, instead of using dummy names. Python interpreter allocates the memory to the variable. Python assigns values from right to left. However, Sam, then check your prediction. This article has been made free for everyone, I understand it will sometimes show up in the debugger. The data stored in memory can be of many types. Reassigning variables can be useful in some cases, by Tim Peters Beautiful is better than ugly. The variables that are prefixed with __ are known as the special variables. Swapping values between two variables is a common programming operation. We will go through python variables and python data types in more detail further in this blog. Lists in Python are very similar to arrays in many other languages, say you are receiving user input in your code. What if we try to call the local variable outside of the function? This appends a single value to the end of a list.
    [Show full text]
  • C++ API for BLAS and LAPACK
    2 C++ API for BLAS and LAPACK Mark Gates ICL1 Piotr Luszczek ICL Ahmad Abdelfattah ICL Jakub Kurzak ICL Jack Dongarra ICL Konstantin Arturov Intel2 Cris Cecka NVIDIA3 Chip Freitag AMD4 1Innovative Computing Laboratory 2Intel Corporation 3NVIDIA Corporation 4Advanced Micro Devices, Inc. February 21, 2018 This research was supported by the Exascale Computing Project (17-SC-20-SC), a collaborative effort of two U.S. Department of Energy organizations (Office of Science and the National Nuclear Security Administration) responsible for the planning and preparation of a capable exascale ecosystem, including software, applications, hardware, advanced system engineering and early testbed platforms, in support of the nation's exascale computing imperative. Revision Notes 06-2017 first publication 02-2018 • copy editing, • new cover. 03-2018 • adding a section about GPU support, • adding Ahmad Abdelfattah as an author. @techreport{gates2017cpp, author={Gates, Mark and Luszczek, Piotr and Abdelfattah, Ahmad and Kurzak, Jakub and Dongarra, Jack and Arturov, Konstantin and Cecka, Cris and Freitag, Chip}, title={{SLATE} Working Note 2: C++ {API} for {BLAS} and {LAPACK}}, institution={Innovative Computing Laboratory, University of Tennessee}, year={2017}, month={June}, number={ICL-UT-17-03}, note={revision 03-2018} } i Contents 1 Introduction and Motivation1 2 Standards and Trends2 2.1 Programming Language Fortran............................ 2 2.1.1 FORTRAN 77.................................. 2 2.1.2 BLAST XBLAS................................. 4 2.1.3 Fortran 90.................................... 4 2.2 Programming Language C................................ 5 2.2.1 Netlib CBLAS.................................. 5 2.2.2 Intel MKL CBLAS................................ 6 2.2.3 Netlib lapack cwrapper............................. 6 2.2.4 LAPACKE.................................... 7 2.2.5 Next-Generation BLAS: \BLAS G2".....................
    [Show full text]
  • Json Schema Type Number Or Null
    Json Schema Type Number Or Null decreeInflectionless ablaze. and Intermittently parsonical cavalierly,Penn frescos: Vassili which reinter Benjamen highlighting is strapless and unfeudalizes enough? Happiest sarcoplasm. Thaddius boobs his Tucana May also takes precedence over each json null values passed to be submitted as described by calling either as geo. Rfc will crash if not of type number. The json type? Schemas and Types GraphQL. Means any worse at jail so little is support one quality from my chosen set followed by any character not number of times. JSON Data Types REST API Tutorial. Example 47 a string-valued annotation a Boolean-valued annotation a slender float-valued annotation. Computing whether it has a number type of the schema to be appreciated, by related resources. 3 Answers You want also specimen type number null as Adam suggests but always think anyOf is cleaner as long as he use demand draft-04 implementation and ties the minimum and maximum declaration to purchase number explicitly Disclaimer I don't know instead about the python implementation my flip is about json schema. Where crazy is now string specifying any valid JSON Schema type boolean integer number of array decay and null Unless creating an empty schema. Currently the null type number or edit my web url to work for? Given named types can also several different way to help, type schema number or json null values: just describes the schema validator criteria are some examples. Numeric multipleOf exclusiveMaximum exclusiveMinimum. Relatively systematic ways json object; the number or null type number or unknown properties.
    [Show full text]
  • Scripting Layer for Android: Updated and Expanded Support
    POLITECNICO DI MILANO School of Industrial and Information Engineering Master of Science in Computer Science and Engineering SCRIPTING LAYER FOR ANDROID: UPDATED AND EXPANDED SUPPORT Master graduation thesis: Miguel Angel Palacio Delgado – Student ID: 816355 Supervisor: Dr. Giovanni Agosta Academic Year 2015-2016 iii Acknowledgements I would like to thank my family for all their support throughout my master's studies, without it I would not have been able to complete them. I would also like to express my gratitude to those friends that somehow helped me during my stay in Milan. I specially thank my supervisor Giovanni Agosta for all his understanding, cooperation and availability during the development of this work. Milan, April 2016 iv Abstract The Scripting Layer for Android (SL4A) is a software suite that brings scripting languages to Android by allowing the creation, edition and execution of scripts and the use of interactive interpreters directly on Android devices. These scripts have access to many of the APIs available to traditional Android applications, with the inherent ease of scripting languages. Despite being initially developed at Google, SL4A was never an official project and it is currently not maintained. The main purpose of this work is to update the SL4A libraries to support the most recent versions of the Android operative system as well as to extend the support for missing components in the user interface library. Lo Scripting Layer for Android (SL4A) è una suite di software che porta linguaggi di scripting ad Android, permettendo la creazione, edizione ed esecuzione di scripts e anche l'uso di interprete interattivi direttamente su dispositivi Android.
    [Show full text]
  • Friend Documentation Release 0.2.1
    Friend Documentation Release 0.2.1 Joseph Wright Mar 19, 2021 Contents: 1 Introduction 1 1.1 What is Friend?..............................................1 2 API Reference 3 2.1 friend package..............................................3 3 Indices and tables 11 Python Module Index 13 Index 15 i ii CHAPTER 1 Introduction 1.1 What is Friend? Friend is all of those of utilities you keep reimplementing across your Python projects, that all got together and decided to live in harmony. Maybe you just parsed some YAML that contained some configuration in “snake_case”, and you want to pass this configuration to a boto3 function which takes the same values but in “PascalCase”. Then you might find snake_to_pascal_obj or one of its variants to come in handy. with open('conf.yml') as f: conf= yaml.load(f) ec2= boto3.resource('ec2') ec2.create_instances( ImageId='ami-12345678', BlockDeviceMappings=snake_to_pascal_obj(conf['block_device_mappings']), .... ) Or you need to add a retry to that script that keeps breaking your Jenkins job because the corporate proxy fails about 5% of the time. Sure, you can add a try/except and wrap it in a for loop, but putting the retryable decorator on top of that problematic function will do that for you in one configurable line. @retryable(times=5) def flaky_function(): status= requests.get('https://service.corp/v2/status').json() if 'error' in status: send_important_email(status['error']) 1 Friend Documentation, Release 0.2.1 2 Chapter 1. Introduction CHAPTER 2 API Reference 2.1 friend package 2.1.1 friend.collections module friend.collections.select_dict(coll, key, value) Given an iterable of dictionaries, return the dictionaries where the values at a given key match the given value.
    [Show full text]
  • The Rust Programming Language
    The Rust Programming Language The Rust Programming Language Steve Klabnik and Carol Nichols, with Contributions from the Rust Community The Rust Programming Language, © Steve Klabnik and Carol Nichols, with Contributions from the Rust Community. Contents I Getting started 7 1 Introduction 9 1.1 Contributing to the book ................. 10 1.2 ................................ 10 1.3 ................................ 12 2 Guessing Game 21 2.1 Setting Up a New Project ................. 21 2.2 Processing a Guess ..................... 22 2.3 Generating a Secret Number ............... 27 2.4 Comparing the Guess to the Secret Number ....... 33 2.5 Allowing Multiple Guesses with Looping ......... 38 2.6 Summary .......................... 44 3 Common Programming Concepts 45 3.1 ................................ 46 3.2 ................................ 50 3.3 ................................ 58 3.4 ................................ 65 3.5 ................................ 66 4 Understanding Ownership 77 4.1 ................................ 77 4.2 ................................ 90 4.3 ................................ 97 5 Using Structs to Structure Related Data 105 5.1 ................................ 105 5.2 ................................ 111 5.3 ................................ 117 6 6 Enums and Pattern Matching 123 6.1 ................................ 123 6.2 ................................ 132 6.3 ................................ 138 II Basic Rust Literacy 143 1 Using Modules to Reuse and Organize Code 145 1.1 ...............................
    [Show full text]
  • Package 'Lettercase'
    Package ‘lettercase’ March 3, 2016 Title Utilities for Formatting Strings with Consistent Capitalization, Word Breaks and White Space Version 0.13.1 Date 2016-03-03 Description Utilities for formatting strings and character vectors to for capitalization, word break and white space. Supported formats are: snake_case, spine-case, camelCase, PascalCase, Title Case, UPPERCASE, lowercase, Sentence case or combinations thereof. 'lettercase' strives to provide a simple, consistent, intuitive and high performing interface. Depends R (>= 3.1.0), stringr (>= 1.0.0) Suggests testthat, knitr, magrittr (>= 1.5) License GPL-2 | file LICENSE LazyData true Collate 'lettercase-package.R' 'make_names.R' 'make_str_replace.R' 'patterns.R' 'str_cap_words.R' 'str_collapse_whitespace.R' 'str_delete.R' 'str_functions.R' 'str_is.R' 'str_lowercase.R' 'str_sentence_case.R' 'str_snake_case.R' 'str_spine_case.R' 'str_title_case.R' 'str_transform.R' 'str_ucfirst.R' 'str_uppercase.R' 'utils.R' 'zzz.R' VignetteBuilder knitr NeedsCompilation no Author Christopher Brown [aut, cre], Decision Patterns [cph] Maintainer Christopher Brown <[email protected]> Repository CRAN Date/Publication 2016-03-03 23:54:35 R topics documented: lettercase . .2 make_names . .3 1 2 lettercase make_str_replace . .4 pattern_whitespace . .5 str_cap_words . .5 str_collapse_whitespace . .6 str_delete . .7 str_delete_whitespace . .8 str_is . .9 str_lowercase . 10 str_sentence_case . 12 str_snake_case . 13 str_spine_case . 13 str_title_case . 14 str_transform . 15 str_ucfirst . 16 Index 17 lettercase lettercase Description Utilities for formatting strings according to common cases: upper case, lower case, snake case, camel case, spine case, title case, sentence case etc. Details The lettercase package provides utilities that help manage and maintain string formats related to: • capitalization • whitespace / word separating characters • special characters • acronyms Most often, the common convenience functions will be used.
    [Show full text]
  • Pop PHP Framework Release 4.6.0
    Pop PHP Framework Release 4.6.0 Mar 11, 2021 Contents 1 Overview 3 1.1 Introduction...............................................3 1.2 About the Framework..........................................3 1.3 Community & Support..........................................4 2 Installation 5 2.1 Using Composer.............................................5 2.2 Requirements...............................................5 2.3 Recommendations............................................6 3 Getting Started 7 3.1 Applications...............................................7 3.2 Routing.................................................. 10 3.3 Controllers................................................ 15 3.4 Models.................................................. 16 3.5 Services.................................................. 17 3.6 Events.................................................. 19 3.7 Modules................................................. 20 4 User Guide 23 4.1 MVC................................................... 23 4.2 Views................................................... 24 4.3 HTTP................................................... 33 4.4 Console.................................................. 39 4.5 Databases................................................. 45 4.6 Sessions................................................. 65 4.7 Forms................................................... 67 4.8 Images.................................................. 86 4.9 PDFs................................................... 93 4.10 Popcorn.................................................
    [Show full text]
  • Perl 6 Introduction
    Perl 6 Introduction Naoum Hankache [email protected] Table of Contents 1. Introduction 1.1. What is Perl 6 1.2. Jargon 1.3. Installing Perl 6 1.4. Running Perl 6 code 1.5. Editors 1.6. Hello World! 1.7. Syntax overview 2. Operators 3. Variables 3.1. Scalars 3.2. Arrays 3.3. Hashes 3.4. Types 3.5. Introspection 3.6. Scoping 3.7. Assignment vs. Binding 4. Functions and mutators 5. Loops and conditions 5.1. if 5.2. unless 5.3. with 5.4. for 5.5. given 5.6. loop 6. I/O 6.1. Basic I/O using the Terminal 6.2. Running Shell Commands 6.3. File I/O 6.4. Working with files and directories 7. Subroutines 7.1. Definition 7.2. Signature 7.3. Multiple dispatch 7.4. Default and Optional Arguments 8. Functional Programming 8.1. Functions are first-class citizens 8.2. Closures 8.3. Anonymous functions 8.4. Chaining 8.5. Feed Operator 8.6. Hyper operator 8.7. Junctions 8.8. Lazy Lists 9. Classes & Objects 9.1. Introduction 9.2. Encapsulation 9.3. Named vs. Positional Arguments 9.4. Methods 9.5. Class Attributes 9.6. Access Type 9.7. Inheritance 9.8. Multiple Inheritance 9.9. Roles 9.10. Introspection 10. Exception Handling 10.1. Catching Exceptions 10.2. Throwing Exceptions 11. Regular Expressions 11.1. Regex definition 11.2. Matching characters 11.3. Matching categories of characters 11.4. Unicode properties 11.5. Wildcards 11.6. Quantifiers 11.7. Match Results 11.8.
    [Show full text]
  • Welcome to ECE 250 Algorithms and Data Structures
    2019-09-04 Identifiers 2 ECE 150 Fundamentals of Programming Outline • In this presentation, we will: – Define identifiers and their purpose • Reviewing some of the identifiers we have already seen • Discussing case sensitivity • Describing naming conventions – Define Identifiers • Reserved identifiers • Keywords Douglas Wilhelm Harder, M.Math. LEL Prof. Hiren Patel, Ph.D. [email protected] [email protected] © 2018 by Douglas Wilhelm Harder and Hiren Patel. Some rights reserved. Identifiers Identifiers 3 4 Identifiers Identifiers • Apart from literals, we have seen words that appear to refer to • Each identifier can have a different significance something, either an action or some other property: int main std cout endl return Identifier Description int A type, a standardized means of storing and manipulating data • Such symbols are called identifiers—they are used to allow the main The name of a function A namespace; specifically all identifiers in the standard library are programmer to refer to a specific means of storage or operations on std data within the std namespace and must be referred to using std:: An object (a data structure) in the standard library that allows cout printing to the console or standard output An object in the standard library that is used to indicate that we endl are at the end of a line and we should continue on the next return An indication of the value to be returned from a function 1 2019-09-04 Identifiers Identifiers 5 6 Identifiers Identifiers • Any combination of underscores, letters and numbers
    [Show full text]