We provide intuitive debugging support for traversing all states of and diagnose the root cause of verification errors Satisfiability Modulo Theories Solver Our solution is to insert zero-width whitespace characters (unicode \ u200B) at the
Previous PDF | Next PDF |
[PDF] LES ISOTOPES DE LOXYGENE - International Atomic Energy Agency
11 sept 1972 · of the theories of phlogiston current at that tirre and one can say, that with this that the reason why oxygen isotopes are produced in Israel was that Dead multiplicity and we obtain the states *S,3 P and lD, which in the absence of near the relevant nucleus, and the principal axes of A are there fore also
Expanding KTHs Canvas ecosystem to support additional - DiVA
2 fév 2020 · Test result from the thesis by Samuel Johansson and Emma Skärvinge MARC Standards Office of the United States Library of Congress with input from users* can be extended to other use cases without requiring fundamental changes; \u200b Theory 11 2 1 \u200b \u200b Data Redundancy 11
[PDF] Advanced Features for an Integrated Verification - ETH Zürich
We provide intuitive debugging support for traversing all states of and diagnose the root cause of verification errors Satisfiability Modulo Theories Solver Our solution is to insert zero-width whitespace characters (unicode \ u200B) at the
[PDF] MSL C++ Referencebook - NXP
23 sept 2011 · claims, costs, damages, and expenses, and reasonable attorney fees arising out The _MSL_MULTITHREAD flag causes some mutex objects to be set up in the properties of the implementation's representation of the fundamental types Logic errors in theory can be predicted in advance while runtime
[PDF] Program Review - Academic & Service - Athletics & Kinesiology Latest
26 fév 2020 · Please provide comment on the rates of progress through the basic skills course sequence Gabrielle De La Rosa – 1 Team All-Conference, All-Region, and All- State Selection\u200B decisions regarding lifestyle changes which result in an Apply critical thinking skills to exercise theory in the areas of
101007/978-3-642-71496-2pdf
forward the theory that the whole chitin shell was interspersed with olfactory cells This research has partially contributed to the fundamental basic knowledge argument for the relatively recent origin of cavity-nesting Apis species; if this type had Aesculus (1) or honeydews with a high amount of melecitose which cause
[PDF] Calorimetric and Magnetic Studies on the Vortex Lattice of - UZH
blished theories of the vortex lattice to predict the vortex lattice melting entropy and which cause a strongly temperature dependent self heating of this sample i e they occupy all electronic states up to an energy called the Fermi energy εf Having derived the two fundamental length scales λ and ξ we can find an
[PDF] ub online application
[PDF] uber charles de gaulle paris centre
[PDF] uber industry analysis
[PDF] ubuntu 32 bit
[PDF] ubuntu bind9 dns forwarder
[PDF] ubuntu linux certification
[PDF] uc a1 lecture theatre
[PDF] uc academic calendar 2019 20
[PDF] uc berkeley academic calendar 2019 20
[PDF] uc berkeley academic calendar 2020 21
[PDF] ucc article 9 flow chart
[PDF] ucc article 9 outline
[PDF] ucc article 9 pdf
[PDF] ucc article 9 summary
Advanced Features for an Integrated
rukaelin@student.ethz.chMaster Thesis
November 2016
Supervisor
Arshavir Ter-Gabrielyan
Abstract
Currently, in software verification, the IDE support is insufficient, especially for symbolic exe- cution. Many verification technologies are being developed, but only few IDEs target software verification. For example, users of the Viper framework had only little assistance in writing, and no assistance in debugging their software so far. The common way of invoking the verifier is through the command line, as a sufficient IDE support has been missing. An IDE capable of handling more than one language is desirable, as there are many small verification languages. Without proper IDE support writing, verifying, and debugging software is cumbersome. Many of the tasks normally handled by an IDE need to be performed manually. A capable IDE so- lution could reduce the overhead of verifying software and thereby improve the programmer"s productivity. In this Master"s thesis, we built a cross-platform IDE for creating Viper programs. The IDE assists the user in the process of writing, verifying, and debugging Viper source code. This support ranges from automatically performing tasks at the right time to visualizing the symbolic states and counterexamples. We provide intuitive debugging support for traversing all states of symbolic execution and allow the user to visually compare states. The Viper IDE is based on Microsoft Visual Studio Code. We use the Viper toolchain as a verification engine. Weprovideasolutionforsymbolicexecution, whereastheexistingsolutionsfocusonadifferent verification approach. We manage to visualize the internal state of the verification in a usable way. The implemented solution is highly configurable and allows for an easy integration of additional tools, for example, for specification inference. These novel features allow the user to explore failed verification attempts and thereby understand the cause of the problem. Moreover, the implemented solution generally improves the usability of the Viper framework. i iiAcknowledgment
First and foremost, I would like to thank my thesis advisor Arshavir Ter-Gabrielyan of the Chair of programming methodology at ETH Zürich. He guided the project and provided invaluable feedback. His door was always open whenever I had a question, and he took the time for testing the system and proofreading the thesis. My thanks go to Prof. Dr. Peter Müller, head of the Chair of programming methodology at ETH Zürich for providing the big picture and valuable feedback. During the course of this project many people were involved in answering technical and con- ceptual questions and testing the system. I am grateful for Malte Schwerhoff"s help with all verification backend-related issues. He also assisted the project planning with insightful ideas. I would like to thank Dimitar Asenov for his support in taking the right decisions for the user interface of the project. My thanks go to Marco Eilers, Dr. Alex Summers, and all other testers for detecting and reporting issues. Finally, I want to express my gratitude to my family and friends, especially Amanda Jenny for their support and continuous encouragement throughout the thesis. Thank you for taking your time to proofread the thesis. Without you this thesis would not have been possible. iii ivContents
1. Introduction
11.1. Problem Statement
11.2. Goals
21.3. Previous Solution
31.4. Viper
31.5. Abbreviations
51.6. Structure of this Document
52. State-of-the-Art
72.1. Verification Technologies
72.1.1. Satisfiability Modulo Theories Solver
82.1.2. Verification Condition Generation
82.1.3. Symbolic Execution
82.2. Integrated Development Environments for Verification
82.2.1. Design Concepts for Debugging Symbolic Execution
92.2.2. Dafny Integrated Development Environment
92.3. Previous Solution
92.4. Text Editor Comparison
92.4.1. Sublime Text
102.4.2. Atom
112.4.3. Visual Studio Code
113. Requirement Analysis and Overview of Planned Features
153.1. Pre-Verification Phase
153.2. Pre-Verification Information Reporting
163.3. Interaction with the SE Verification Backend
17 vContents
3.4. Error Reporting
183.5. Supported Operating Systems
194. Graphical User Interface
214.1. Basic GUI Features
214.1.1. Syntax Highlighting
224.1.2. Code Completion
224.1.3. Automatic Verification Invocation
234.2. Features for Debugging Symbolic Execution Faliures
244.2.1. Marking Symbolic Execution States
254.2.2. Simplified Debugging Mode
274.2.3. Advanced Debugging Mode
294.2.4. State Visualization
314.2.5. Comparing States
364.3. Status Bar
374.3.1. Error Reporting
374.3.2. Progress Reporting
394.4. Commands and Shortcuts
415. Implementation
435.1. Infrastructure
435.1.1. Language Client
445.1.2. Language Server
455.1.3. Debugger
465.1.4. External Tools
465.1.5. Third-Party Tools
475.2. The Viper Protocol
475.2.1. Client-Server Communication
475.2.2. Communication of the Debugger with Client and Server
505.2.3. Communication between Backends and the IDE
515.2.4. Control Flow of the Viper IDE
545.3. Configuration
565.3.1. Configuration Validation
565.3.2. Path Resolution
575.3.3. Verification Backend Settings
595.3.4. Extensibility
595.4. Logging
615.5. Adaptation of Tools
625.5.1. Output for Progress Reporting
625.5.2. Outputting SE States
635.5.3. Outputting the Counterexample
645.5.4. Backwards Compatibility
645.5.5. Validation of Changes
655.6. Corner Cases
655.6.1. Opening Individual Files Without an Opened Workspace
655.6.2. State Markers
66vi
Contents
5.6.3. Installation
665.6.4. Platform-Independent Path Configuration
675.6.5. Output Buffer Size
685.7. Syntax Highlighting
685.8. Automatic Code Formatting
685.9. Time Management of the Viper IDE
695.10. The Shutdown Sequence of Viper IDE
696. Evaluation
716.1. Achieved Goals
716.1.1. Core Features
716.1.2. Extension Features
726.1.3. Unplanned Features
736.1.4. Extensibility
746.2. Comparison of Visual Features with Design Concepts
746.2.1. Design Principles
756.2.2. Comparison of the Debug Controls
766.3. Comparison to Dafny IDE
766.3.1. State Markers
766.3.2. Error List
806.3.3. State Visualization
806.3.4. Comparison of Progress Reporting
806.4. Performance Benchmark of the Adopted Backend
816.5. Test Coverage
826.6. Limitations
827. Conclusion and Future Work
857.1. Future Work
86List of Figures
89List of Tables
91Bibliography
94A. Infrastructure
95B. Debug Launch Configuration
97C. List.vpr
99D. Temporary Files
101E. Default Configuration
103F. Output Messages
107vii