Language embeddings that preserve staging and safety
Programming Languages
2007-05-23 v1
Abstract
We study embeddings of programming languages into one another that preserve what reductions take place at compile-time, i.e., staging. A certain condition -- what we call a `Turing complete kernel' -- is sufficient for a language to be stage-universal in the sense that any language may be embedded in it while preserving staging. A similar line of reasoning yields the notion of safety-preserving embeddings, and a useful characterization of safety-universality. Languages universal with respect to staging and safety are good candidates for realizing domain-specific embedded languages (DSELs) and `active libraries' that provide domain-specific optimizations and safety checks.
Cite
@article{arxiv.cs/0509057,
title = {Language embeddings that preserve staging and safety},
author = {Todd L. Veldhuizen},
journal= {arXiv preprint arXiv:cs/0509057},
year = {2007}
}