Keyword and Optional Arguments in PLT Scheme
暂无分享,去创建一个
The lambda and procedure-application forms in PLT Scheme support arguments that are tagged with keywords, instead of identified by position, as well as optional arguments with default values. Unlike previous keyword-argument systems for Scheme, a keyword is not self-quoting as an expression, and keyword arguments use a different calling convention than non-keyword arguments. Consequently, a keyword serves more reliably (e.g., in terms of error reporting) as a lightweight syntactic delimiter on procedure arguments. Our design requires no changes to the PLT Scheme core compiler, because lambda and application forms that support keywords are implemented by macros over conventional core forms that lack keyword support. 1. Using Keyword and Optional Arguments A rich programming language offers many ways to abstract and parameterize code. In Scheme, first-class procedures are the primary means of abstraction, and procedures are unquestionably the right vehicle for parameterizing code with respect to a few run-time values. For parameterization over larger sets of values, however, Scheme procedures quickly become inconvenient. Keyword and optional arguments support tasks that need more arguments than fit comfortably into procedures, but where radiacally different forms—such as unit or class in PLT Scheme— are too heavyweight conceptually and notationally. At the same time, keyword and optional arguments offer a smooth extension path for existing procedure-based APIs. Keyword arguments can be added to a procedure to extend its functionality without binding a new identifier (which always carries the danger of colliding with other bindings) and in a way that composes with other such extensions. Keyword arguments in PLT Scheme are supported through a straightforward extension of the lambda, define, and application forms. Lexically, a keyword starts with #: and continues in the same way as an identifier; for example, #:color is a keyword. A keyword is associated with a formal or actual argument by placing the keyword before the argument name or expression. For example, a rectangle procedure that accepts two by-position arguments and one argument with the #:color keyword can be written as 1 See Section 7.7 for a discussion on this choice of keyword syntax. Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. To copy otherwise, to republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. 2009 Workshop on Scheme and Functional Programming (define rectangle (lambda (width height #:color color) ....))
[1] Andrew Shalit,et al. The Dylan Reference Manual , 1996 .
[2] Robert Bruce Findler,et al. Slideshow: functional presentations , 2004, ICFP '04.
[3] Matthias Felleisen,et al. A tail-recursive machine with stack inspection , 2004, TOPL.
[4] Peter Seibel,et al. Practical Common Lisp , 2005 .