Skip to content

Commit

Permalink
Deploying to gh-pages from @ 25dac8a 🚀
Browse files Browse the repository at this point in the history
  • Loading branch information
cgay committed Dec 13, 2024
1 parent 9e61c21 commit 2dea4da
Show file tree
Hide file tree
Showing 267 changed files with 1,364 additions and 12 deletions.
236 changes: 236 additions & 0 deletions _sources/proposals/dep-0013-multi-assignment.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,236 @@
*************************
Multiple Value Assignment
*************************

=============== =============================================
DEP #: 13
Type: Standards Track
Affects-DRM: Yes
Author: Carl Gay
Status: Draft
Created: 10-Dec-2024
Last-Modified: 10-Dec-2024
Post-History: None
Target-Version: 2025.1
=============== =============================================


Abstract
========

Add new syntax to assign multiple variables from a single multi-valued expression.

Specification
=============

The DRM defines the syntax of assignment expressions to be::

place := new-value

This DEP adds new syntax on the left hand side to allow for multiple *places* to be set
from the multiple values returned by the ``new-value`` expression, which we rename here
to ``new-values``::

(place1, place2, ...) := new-values

The first return value is assigned to *place1*, the second value to *place2*, etc. The
last *place* may be preceded by ``#rest``, in which case it is assigned a sequence
containing all the remaining values.

If there are more *places* than values returned by ``new-values``, the extra *places* are
assigned the value :drm:`#f`.

The name ``_`` (underscore) may be used to indicate that a value is to be ignored. For
example, ``(_, remainder) := round(3.2)`` will ignore the first return value and assign
``remainder`` the value ``0.2``.

The order of assignment of values to *places* is unspecified.


BNF Changes
-----------

No changes are required to the Dylan BNF as described in the DRM. ``LEAF := EXPRESSION``
is already valid and ``( EXPRESSION )`` syntax is a valid ``LEAF`` production.


Rationale
=========

Multiple value assignment syntax naturally matches the existing multiple value binding
syntax provided by :drm:`let` and can occasionally be a useful tool to make code more
concise.


Examples
========

Some examples from the Open Dylan sources that can be made more concise:

.. code:: dylan
// This occurs a lot in dfmc/conversion/convert.dylan
let (f, l) = join-2x1!(first, last, comp); first := f; last := l; // old
(first, last) := join-2x1!(first, last, comp); // new
.. code:: dylan
// old:
define sealed method set-union!
(set1 :: <bit-set>, set2 :: <bit-set>) => (set1 :: <bit-set>)
let (vector, pad)
= bit-vector-or!(set1.member-vector, set2.member-vector,
pad1: set1.member-vector-pad,
pad2: set2.member-vector-pad);
set1.member-vector := vector;
set1.member-vector-pad := pad;
set1
end method;
// new:
define sealed method set-union!
(set1 :: <bit-set>, set2 :: <bit-set>) => (set1 :: <bit-set>)
(set1.member-vector, set1.member-vector-pad)
:= bit-vector-or!(set1.member-vector, set2.member-vector,
pad1: set1.member-vector-pad,
pad2: set2.member-vector-pad);
set1
end method;
.. code:: dylan
// old:
for (i from 0 below n)
let (thread, result) = join-thread(threads[i]);
results[i] := result;
end for;
// new:
for (i from 0 below n)
(_, results[i]) := join-thread(threads[i]);
end for;
.. code:: dylan
// old:
define method stop-profiling-type
(state :: <profiling-state>, keyword :: <cpu-profiling-type>) => ()
when (element(state, #"cpu-profiling", default: #f))
let (seconds, microseconds) = timer-stop(state[#"cpu-profiling-timer"]);
state[#"cpu-time-seconds"] := seconds;
state[#"cpu-time-microseconds"] := microseconds;
state[#"cpu-profiling"] := #f;
state[#"cpu-profiling-timer"] := #f;
end
end method stop-profiling-type;
// new:
define method stop-profiling-type
(state :: <profiling-state>, keyword :: <cpu-profiling-type>) => ()
when (element(state, #"cpu-profiling", default: #f))
(state[#"cpu-time-seconds"], state[#"cpu-time-microseconds"])
:= timer-stop(state[#"cpu-profiling-timer"]);
state[#"cpu-profiling"] := #f;
state[#"cpu-profiling-timer"] := #f;
end
end method stop-profiling-type;
.. code:: dylan
// old:
let (sec, nsec) = %timer-current-time();
timer.timer-started-seconds := sec;
timer.timer-started-nanoseconds := nsec;
// new:
(timer.timer-started-seconds, timer.timer-started-nanoseconds)
:= %timer-current-time();
.. code:: dylan
// old:
let (name, #rest arguments) = tokenize-command-line(command-line);
*application-name* := name;
*application-arguments* := apply(vector, arguments);
// new:
(*application-name*, #rest *application-arguments*) := tokenize-command-line(command-line);
.. code:: dylan
// old:
let (ins, outs) = split-operation-arguments(request-arguments(request));
request-in-args(request) := ins;
request-out-args(request) := outs;
// new:
(request-in-args(request), request-out-args(request))
:= split-operation-arguments(request-arguments(request));
.. code:: dylan
// old:
let (_n, _what) = goto-position-dialog(window, what | #"line");
n := _n;
what := _what
// new:
(n, what) := goto-position-dialog(window, what | #"line");
.. code:: dylan
// old:
let (width, height) = frame-size(dialog);
$buffer-box-width := width;
$buffer-box-height := height;
// new:
($buffer-box-width, $buffer-box-height) = frame-size(dialog);
Alternatives Considered
=======================

1. One might consider it desirable to allow the left hand side of ``:=`` expressions to
omit the parentheses in multiple value assignments when it is unambiguous. That is, to
allow both ``(a, b) := f()`` and ``a, b := f()`` as long as no ambiguity exists.

In certain contexts parentheses would be required for disambiguation, for example in a
argument list context:

.. code:: dylan
vector(a, b := f())
Is the above equivalent to ``vector(a, f())`` or ``vector(f())``?

.. code:: dylan
vector((a, b) := f())
The above is unambiguously equivalent to ``vector(f())`` since multiple value
assignment always returns the first assigned value.

However, in a body context (i.e., a sequence of semicolon delimited statements)
omitting the parentheses may be desirable as it is less "noisy":

.. code:: dylan
...; a, b := f(); ...
**Decision:** To remove any ambiguity, and to match the existence of parentheses for
multiple value *bindings* with :drm:`let`, parentheses will be *required* for multiple
value assignments.


Reference Implementation
========================

TODO: permalink


Revision History
================

The revision history of this document is available here:
https://github.com/dylan-lang/opendylan/commits/master/documentation/source/proposals/dep-0013-multi-assignment.rst
6 changes: 4 additions & 2 deletions _sources/proposals/index.rst.txt
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ Open Proposals (under consideration)
1 Process Draft :doc:`dep-0001-dep-process`
6 Standard Draft :doc:`dep-0006-single-file-library`
10 Standard Draft :doc:`dep-0010-element-otherwise`
12 Standard Draft :doc:`dep-0012-string-literals`
13 Standard Draft :doc:`dep-0013-multi-assignment`
==== ============= ========== =============================================


Expand All @@ -60,7 +60,8 @@ All Proposals by Number
8 Standard Withdrawn :doc:`dep-0008-multi-line-strings`
10 Standard Draft :doc:`dep-0010-element-otherwise`
11 Standard Final :doc:`dep-0011-numeric-literal-syntax`
12 Standard Draft :doc:`dep-0012-string-literals`
12 Standard Final :doc:`dep-0012-string-literals`
13 Standard Draft :doc:`dep-0013-multi-assignment`
==== ============= ========== =============================================

.. toctree::
Expand All @@ -77,3 +78,4 @@ All Proposals by Number
dep-0010-element-otherwise
dep-0011-numeric-literal-syntax
dep-0012-string-literals
dep-0013-multi-assignment
1 change: 1 addition & 0 deletions about/examples/classes.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/everything_value.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/generic_functions.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/getters_setters_functions.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/hello_world.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/keyword_arguments.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/limited_types.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/macros.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions about/examples/multiple_return_values.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
7 changes: 4 additions & 3 deletions about/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
<head><meta charset="utf-8"/>
<meta name="viewport" content="width=device-width,initial-scale=1"/>
<meta name="color-scheme" content="light dark"><meta name="viewport" content="width=device-width, initial-scale=1" />
<link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Hello, World!" href="examples/hello_world.html" /><link rel="prev" title="String Literal Syntax" href="../proposals/dep-0012-string-literals.html" />
<link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Hello, World!" href="examples/hello_world.html" /><link rel="prev" title="Multiple Value Assignment" href="../proposals/dep-0013-multi-assignment.html" />

<link rel="shortcut icon" href="../_static/favicon.ico"/><!-- Generated with Sphinx 7.1.2 and Furo 2024.08.06 -->
<title>A Quick Tour of Dylan - Open Dylan</title>
Expand Down Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down Expand Up @@ -584,14 +585,14 @@ <h2>A bit more background on Dylan<a class="headerlink" href="#a-bit-more-backgr
</div>
<svg class="furo-related-icon"><use href="#svg-arrow-right"></use></svg>
</a>
<a class="prev-page" href="../proposals/dep-0012-string-literals.html">
<a class="prev-page" href="../proposals/dep-0013-multi-assignment.html">
<svg class="furo-related-icon"><use href="#svg-arrow-right"></use></svg>
<div class="page-info">
<div class="context">
<span>Previous</span>
</div>

<div class="title">String Literal Syntax</div>
<div class="title">Multiple Value Assignment</div>

</div>
</a>
Expand Down
1 change: 1 addition & 0 deletions articles/beyond-java.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions articles/macro-system.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions articles/procedural-dylan/1-distance.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
1 change: 1 addition & 0 deletions articles/procedural-dylan/2-quadratic.html
Original file line number Diff line number Diff line change
Expand Up @@ -261,6 +261,7 @@
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0010-element-otherwise.html">Defaulted Element Reference Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0011-numeric-literal-syntax.html">Numeric Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0012-string-literals.html">String Literal Syntax</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../proposals/dep-0013-multi-assignment.html">Multiple Value Assignment</a></li>
</ul>
</li>
</ul>
Expand Down
Loading

0 comments on commit 2dea4da

Please sign in to comment.