Towards Lakosian Multilingual Software Design Principles
Damian Lyons, Saba Zahra, Thomas Marshall
2019
Abstract
Large software systems often comprise programs written in different programming languages. In the case when cross-language interoperability is accomplished with a Foreign Function Interface (FFI), for example pybind11, Boost.Python, Emscripten, PyV8, or JNI, among many others, common software engineering tools, such as call-graph analysis, are obstructed by the opacity of the FFI. This complicates debugging and fosters potential inefficiency and security problems. One contributing issue is that there is little rigorous software design advice for multilingual software. In this paper, we present our progress towards a more rigorous design approach to multilingual software. The approach is based on the existing approach to the design of large-scale C++ systems developed by Lakos. The FFI is an aspect of physical rather than logical architecture. The Lakosian approach is one of the few design methodologies to address physical design rather than just logical design. Using the MLSA toolkit developed in prior work for analysis of multilingual software, we focus in on one FFI – the pybind11 FFI. An extension to the Lakosian C++ design rules is proposed to address multilingual software that uses pybind11. Using a sample of 50 public GitHub repositories that use pybind11, we measure how many repositories would currently satisfy these rules. We conclude with a proposed generalization of the pybind11-based rules for any multilingual software using an FFI interface.
DownloadPaper Citation
in Harvard Style
Lyons D., Zahra S. and Marshall T. (2019). Towards Lakosian Multilingual Software Design Principles.In Proceedings of the 14th International Conference on Software Technologies - Volume 1: ICSOFT, ISBN 978-989-758-379-7, pages 306-314. DOI: 10.5220/0007958303060314
in Bibtex Style
@conference{icsoft19,
author={Damian Lyons and Saba Zahra and Thomas Marshall},
title={Towards Lakosian Multilingual Software Design Principles},
booktitle={Proceedings of the 14th International Conference on Software Technologies - Volume 1: ICSOFT,},
year={2019},
pages={306-314},
publisher={SciTePress},
organization={INSTICC},
doi={10.5220/0007958303060314},
isbn={978-989-758-379-7},
}
in EndNote Style
TY - CONF
JO - Proceedings of the 14th International Conference on Software Technologies - Volume 1: ICSOFT,
TI - Towards Lakosian Multilingual Software Design Principles
SN - 978-989-758-379-7
AU - Lyons D.
AU - Zahra S.
AU - Marshall T.
PY - 2019
SP - 306
EP - 314
DO - 10.5220/0007958303060314