Locations.xhtml 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?xml version="1.0" encoding="UTF-8" standalone="no"?>
  2. <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops" xmlns:m="http://www.w3.org/1998/Math/MathML" xmlns:pls="http://www.w3.org/2005/01/pronunciation-lexicon" xmlns:ssml="http://www.w3.org/2001/10/synthesis" xmlns:svg="http://www.w3.org/2000/svg">
  3. <head>
  4. <title>Locations</title>
  5. <link rel="stylesheet" type="text/css" href="docbook-epub.css"/>
  6. <link rel="stylesheet" type="text/css" href="kawa.css"/>
  7. <script src="kawa-ebook.js" type="text/javascript"/>
  8. <meta name="generator" content="DocBook XSL-NS Stylesheets V1.79.1"/>
  9. <link rel="prev" href="Eval-and-Environments.xhtml" title="Eval and Environments"/>
  10. <link rel="next" href="Parameter-objects.xhtml" title="Parameter objects"/>
  11. </head>
  12. <body>
  13. <header/>
  14. <section class="sect1" title="Locations" epub:type="subchapter" id="Locations">
  15. <div class="titlepage">
  16. <div>
  17. <div>
  18. <h2 class="title" style="clear: both">Locations</h2>
  19. </div>
  20. </div>
  21. </div>
  22. <p>A <em class="firstterm">location</em> is a place where a value can be stored.
  23. An <em class="firstterm">lvalue</em> is an expression that refers to a location.
  24. (The name "lvalue" refers to the fact that the left operand
  25. of <code class="literal">set!</code> is an lvalue.)
  26. The only kind of lvalue in standard Scheme is a <em class="firstterm">variable</em>.
  27. Kawa also allows <em class="firstterm">computed lvalues</em>. These are procedure
  28. calls used in "lvalue context", such as the left operand of <code class="literal">set!</code>.
  29. </p>
  30. <p>You can only use procedures that have an associated <em class="firstterm">setter</em>.
  31. In that case, <code class="literal">(set! (f arg ...) value)</code>
  32. is equivalent to <code class="literal">((setter f) arg ... value)</code>
  33. Currently, only a few procedures have associated <code class="literal">setter</code>s,
  34. and only builtin procedures written in Java can have <code class="literal">setter</code>s.
  35. </p>
  36. <p>For example:
  37. </p>
  38. <pre class="screen">(set! (car x) 10)
  39. </pre>
  40. <p>is equivalent to:
  41. </p>
  42. <pre class="screen">((setter car) x 10)
  43. </pre>
  44. <p>which is equivalent to:
  45. </p>
  46. <pre class="screen">(set-car! x 10)
  47. </pre>
  48. <p class="synopsis" kind="Procedure"><span class="kind">Procedure</span><span class="ignore">: </span><a id="idm139667873128672" class="indexterm"/> <code class="function">setter</code> <em class="replaceable"><code>procedure</code></em></p>
  49. <div class="blockquote">
  50. <blockquote class="blockquote">
  51. <p>Gets the "setter procedure" associated with a "getter procedure".
  52. Equivalent to <code class="literal">(procedure-property <em class="replaceable"><code>procedure</code></em> 'setter)</code>.
  53. By convention, a setter procedure takes the same parameters as
  54. the "getter" procedure, plus an extra parameter that is the
  55. new value to be stored in the location specified by the parameters.
  56. The expectation is that following
  57. <code class="literal">((setter <em class="replaceable"><code>proc</code></em>) <em class="replaceable"><code>args</code></em> ... <em class="replaceable"><code>value</code></em>)</code> then
  58. the value of <code class="literal">(<em class="replaceable"><code>proc</code></em> <em class="replaceable"><code>args</code></em> ...)</code> will be <em class="replaceable"><code>value</code></em>.
  59. </p>
  60. <p>The <code class="literal">setter</code> of <code class="literal">setter</code> can be used to set the
  61. <code class="literal">setter</code> property.
  62. For example the Scheme prologue effectively does the following:
  63. </p>
  64. <pre class="screen">(set! (setter vector-set) vector-set!)
  65. </pre>
  66. </blockquote>
  67. </div>
  68. <p>Kawa also gives you access to locations as first-class values:
  69. </p>
  70. <p class="synopsis" kind="Syntax"><span class="kind">Syntax</span><span class="ignore">: </span><a id="idm139667873117648" class="indexterm"/> <code class="function">location</code> <em class="replaceable"><code>lvalue</code></em></p>
  71. <div class="blockquote">
  72. <blockquote class="blockquote">
  73. <p>Returns a location object for the given <em class="replaceable"><code>lvalue</code></em>.
  74. You can get its value (by applying it, as if it were a procedure),
  75. and you can set its value (by using <code class="literal">set!</code> on the application).
  76. The <em class="replaceable"><code>lvalue</code></em> can be a local or global variable, or a procedure
  77. call using a procedure that has a <code class="literal">setter</code>.
  78. </p>
  79. <pre class="screen">(define x 100)
  80. (define lx (location x))
  81. (set! (lx) (cons 1 2)) ;; set x to (1 . 2)
  82. (lx) ;; returns (1 . 2)
  83. (define lc (location (car x)))
  84. (set! (lc) (+ 10 (lc)))
  85. ;; x is now (11 . 2)
  86. </pre>
  87. </blockquote>
  88. </div>
  89. <p class="synopsis" kind="Syntax"><span class="kind">Syntax</span><span class="ignore">: </span><a id="idm139667873111840" class="indexterm"/> <code class="function">define-alias</code> <em class="replaceable"><code>variable</code></em> <em class="replaceable"><code>lvalue</code></em></p>
  90. <div class="blockquote">
  91. <blockquote class="blockquote">
  92. <p>Define <em class="replaceable"><code>variable</code></em> as an alias for <em class="replaceable"><code>lvalue</code></em>.
  93. In other words, makes it so that <code class="literal">(location <em class="replaceable"><code>variable</code></em>)</code>
  94. is equivalent to <code class="literal">(location <em class="replaceable"><code>lvalue</code></em>)</code>.
  95. This works both top-level and inside a function.
  96. </p>
  97. </blockquote>
  98. </div>
  99. <p class="synopsis" kind="Syntax"><span class="kind">Syntax</span><span class="ignore">: </span><a id="idm139667873105376" class="indexterm"/> <code class="function">define-private-alias</code> <em class="replaceable"><code>variable</code></em> <em class="replaceable"><code>lvalue</code></em></p>
  100. <div class="blockquote">
  101. <blockquote class="blockquote">
  102. <p>Same as <code class="literal">define-alias</code>, but the <em class="replaceable"><code>variable</code></em>
  103. is local to the current module.
  104. </p>
  105. </blockquote>
  106. </div>
  107. <p>Some people might find it helpful to think of a location
  108. as a settable <em class="firstterm">thunk</em>. Others may find it useful to
  109. think of the <code class="literal">location</code> syntax as similar to the C ‘<code class="literal">&amp;</code>’ operator;
  110. for the ‘<code class="literal">*</code>’ indirection operator, Kawa uses procedure application.
  111. </p>
  112. <p>You can use <code class="literal">define-alias</code> to define a shorter type synonym,
  113. similar to Java’s <code class="literal">import TypeName</code> (single-type-import) declaration:
  114. </p>
  115. <pre class="screen">(define-alias StrBuf java.lang.StringBuffer)
  116. </pre>
  117. </section>
  118. <footer>
  119. <div class="navfooter">
  120. <p>
  121. Up: <a accesskey="u" href="Eval-and-Environments.xhtml">Eval and Environments</a></p>
  122. <p>
  123. Next: <a accesskey="n" href="Parameter-objects.xhtml">Parameter objects</a></p>
  124. </div>
  125. </footer>
  126. </body>
  127. </html>