emacs.d/clones/lisp/www.cliki.net/Issue EQUAL-CIRCULAR-LIST.html
2022-10-07 15:47:14 +02:00

78 lines
No EOL
4.6 KiB
HTML

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>CLiki: Issue EQUAL-CIRCULAR-LIST</title>
<link rel="alternate" type="application/atom+xml" title="ATOM feed of edits to current article"
href="https://www.cliki.net/site/feed/article.atom?title=Issue%20EQUAL-CIRCULAR-LIST">
<link rel="stylesheet" href="static/css/style.css">
<link rel="stylesheet" href="static/css/colorize.css">
</head>
<body>
<span class="hidden">CLiki - Issue EQUAL-CIRCULAR-LIST</span>
<div id="content"><div id="content-area"><div id="article-title">Issue EQUAL-CIRCULAR-LIST</div><div id="article"><a href="Issue.html" class="category">Issue</a>: EQUAL-CIRCULAR-LIST<p>Forum: Editorial<p>References: <a href="https://www.cliki.net/site/HyperSpec/Body/fun_equal.html" class="hyperspec">EQUAL</a><p>Category: CLARIFICATION/CHANGE<p>Edit history: 2004-07-20, Version 1 by Bruno Haible<p>Status: For CLiki consideration<p><dl>
<dt>Problem Description:<p></dt>
<dd>Under CLHS rules, (<a href="https://www.cliki.net/site/HyperSpec/Body/fun_equal.html" class="hyperspec">EQUAL</a> proper-list circular-list) may fail to terminate, but in all known implementation it will terminate<p></dd>
<dt>Proposal (EQUAL-CIRCULAR-LIST:ALLOW):<p></dt>
<dd>Change "<a href="https://www.cliki.net/site/HyperSpec/Body/fun_equal.html" class="hyperspec">EQUAL</a> may fail to terminate if x or y is circular" to "if x <em>and</em> y are circular", so that (equal t '#1=(nil #1#)) is required to terminate.<p></dd>
<dt>Test case:<p></dt>
<dd>(equal '(a b c) '#1=(a b . #1#))<p></dd>
<dt>Rationale:<p></dt>
<dd>All reasonable implementations of <a href="https://www.cliki.net/site/HyperSpec/Body/fun_equal.html" class="hyperspec">EQUAL</a> behave this way.<p></dd>
<dt>Current practice:<p></dt>
<dd>
<a href="SBCL.html" class="internal">SBCL</a> and <a href="CLISP.html" class="internal">CLISP</a> implement ALLOW.<p></dd>
<dt>Cost to Implementors:<p></dt>
<dd>None.<p></dd>
<dt>Cost to Users:<p></dt>
<dd>None.<p></dd>
<dt>Cost of Non-Adoption:<p></dt>
<dd>Users who assume a normal recursive implementation of EQUAL are trapped into pitfalls.<p></dd>
<dt>Benefits:<p></dt>
<dd>Legalize existing practice.<p></dd>
<dt>Aesthetics:<p><dt>Discussion:
<ul>
<li>Bruno Haible says: I agree with proposal ALLOW. It is common practice to use (equal proper-list circular-list). The standard should allow it.
</li>
</ul>
</dt>
</dt>
</dl></div></div>
<div id="footer" class="buttonbar"><ul><li><a href="Issue&#32;EQUAL-CIRCULAR-LIST.html">Current version</a></li>
<li><a href="https://www.cliki.net/site/history?article=Issue%20EQUAL-CIRCULAR-LIST">History</a></li>
<li><a href="https://www.cliki.net/site/backlinks?article=Issue%20EQUAL-CIRCULAR-LIST">Backlinks</a></li><li><a href="https://www.cliki.net/site/edit-article?title=Issue%20EQUAL-CIRCULAR-LIST&amp;from-revision=3770934417">Edit</a></li><li><a href="https://www.cliki.net/site/edit-article?create=t">Create</a></li></ul></div>
</div>
<div id="header-buttons" class="buttonbar">
<ul>
<li><a href="https://www.cliki.net/">Home</a></li>
<li><a href="https://www.cliki.net/site/recent-changes">Recent Changes</a></li>
<li><a href="CLiki.html">About</a></li>
<li><a href="Text&#32;Formatting.html">Text Formatting</a></li>
<li><a href="https://www.cliki.net/site/tools">Tools</a></li>
</ul>
<div id="search">
<form action="https://www.cliki.net/site/search">
<label for="search_query" class="hidden">Search CLiki</label>
<input type="text" name="query" id="search_query" value="" />
<input type="submit" value="search" />
</form>
</div>
</div>
<div id="pageheader">
<div id="header">
<span id="logo">CLiki</span>
<span id="slogan">the common lisp wiki</span>
<div id="login"><form method="post" action="https://www.cliki.net/site/login">
<label for="login_name" class="hidden">Account name</label>
<input type="text" name="name" id="login_name" class="login_input" />
<label for= "login_password" class="hidden">Password</label>
<input type="password" name="password" id="login_password" class="login_input" />
<input type="submit" name="login" value="login" id="login_submit" /><br />
<div id="register"><a href="https://www.cliki.net/site/register">register</a></div>
<input type="submit" name="reset-pw" value="reset password" id="reset_pw" />
</form>
</div>
</div>
</div>
</body></html>