Documents

DOI

Incremental build systems are essential for fast, reproducible software builds. Incremental build systems enable short feedback cycles when they capture dependencies precisely and selectively execute build tasks efficiently. A much overlooked feature of build systems is the expressiveness of the scripting language, which directly influences the maintainability of build scripts. In this paper, we present a new incremental build algorithm that allows build engineers to use a full-fledged programming language with explicit task invocation, value and file inspection facilities, and conditional and iterative language constructs. In contrast to prior work on incrementality for such programmable builds, our algorithm scales with the number of tasks affected by a change and is independent of the size of the software project being built. Specifically, our algorithm accepts a set of changed files, transitively detects and re-executes affected build tasks, but also accounts for new task dependencies discovered during building. We have evaluated the performance of our algorithm in a real-world case study and confirm its scalability.
Original languageEnglish
Title of host publicationASE 2018
Subtitle of host publicationProceedings of the 33rd ACM/IEEE International Conference on Automated Software Engineering
Place of PublicationNew York, NY
PublisherAssociation for Computing Machinery (ACM)
Pages76-86
Number of pages11
ISBN (Print)978-1-4503-5937-5
DOIs
Publication statusPublished - 2018
EventASE 2018: 33rd IEEE/ACM International Conference on Automated Software Engineering - Montpellier, France
Duration: 3 Jul 20187 Jul 2018
http://www.ase2018.com

Conference

ConferenceASE 2018
Abbreviated titleASE 2018
CountryFrance
CityMontpellier
Period3/07/187/07/18
Internet address

    Research areas

  • scalable, incremental, build, dynamic task dependency

ID: 47192560