MetaOCaml server pages: Web publishing as staged computation

0Citations
Citations of this article
9Readers
Mendeley users who have this article in their library.

Abstract

Modern dynamic web services are really computer programs. Some parts of these programs run off-line, others run server-side on each request, and still others run within the browser. In other words, web publishing is staged computation, either for better performance, or because certain resources are available in one stage but not another. Unfortunately, the various web programming languages make it difficult to spread computation over more than one stage. This is a tremendous opportunity for multi-stage languages in general, and for MetaOCaml in particular. We present the design of MetaOCaml Server Pages. Unlike other languages in its genre, the embedded MetaOCaml code blocks may be annotated with staging information, so that the programmer may safely and precisely control which computation occurs in which stage. A prototype web server, written in OCaml, supports web sites with both static and dynamic content. We provide several sample programs and demonstrate the performance gains won using multi-stage programming. © 2006 Elsevier B.V. All rights reserved.

Author supplied keywords

Cite

CITATION STYLE

APA

League, C. (2006). MetaOCaml server pages: Web publishing as staged computation. Science of Computer Programming, 62(1), 66–84. https://doi.org/10.1016/j.scico.2006.05.004

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free