SEPLMar 31, 2017

Edit Transactions: Dynamically Scoped Change Sets for Controlled Updates in Live Programming

arXiv:1703.10862v211 citations
Originality Incremental advance
AI Analysis

This addresses a specific issue for programmers using live programming environments, offering a proactive tool to control change granularity, though it is incremental as it builds on existing live programming concepts.

The paper tackles the problem of managing intermediate changes in live programming environments, where immediate feedback can conflict with performing combined steps like refactoring, by proposing Edit Transactions that collect changes for delayed activation; the result shows potential to increase confidence, reduce run-time errors, and make live programming more predictable, as assessed in a case study comparing programming activities and errors.

Live programming environments enable programmers to edit a running program and obtain immediate feedback on each individual change. The liveness quality is valued by programmers to help work in small steps and continuously add or correct small functionality while maintaining the impression of a direct connection between each edit and its manifestation at run-time. Such immediacy may conflict with the desire to perform a combined set of intermediate steps, such as a refactoring, without immediately taking effect after each individual edit. This becomes important when an incomplete sequence of small-scale changes can easily break the running program. State-of-the-art solutions focus on retroactive recovery mechanisms, such as debugging or version control. In contrast, we propose a proactive approach: Multiple individual changes to the program are collected in an Edit Transaction, which can be made effective if deemed complete. Upon activation, the combined steps become visible together. Edit Transactions are capable of dynamic scoping, allowing a set of changes to be tested in isolation before being extended to the running application. This enables a live programming workflow with full control over change granularity, immediate feedback on tests, delayed effect on the running application, and coarse-grained undos. We present an implementation of Edit Transactions along with Edit-Transaction-aware tools in Squeak/Smalltalk. We asses this implementation by conducting a case study with and without the new tool support, comparing programming activities, errors, and detours for implementing new functionality in a running simulation. We conclude that workflows using Edit Transactions have the potential to increase confidence in a change, reduce potential for run-time errors, and eventually make live programming more predictable and engaging.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes