PEP:3125
Title:Remove Backslash Continuation
Version:55233
Last-Modified:2007-05-10 15:18:18 -0700 (Thu, 10 May 2007)
Author:Jim J. Jewett <JimJJewett at gmail.com>
Status:Rejected
Type:Standards Track
Content-Type:text/x-rst
Created:29-Apr-2007
Post-History:29-Apr-2007, 30-Apr-2007, 04-May-2007

Contents

Rejection Notice

This PEP is rejected. There wasn't enough support in favor, the feature to be removed isn't all that harmful, and there are some use cases that would become harder.

Abstract

Python initially inherited its parsing from C. While this has been generally useful, there are some remnants which have been less useful for Python, and should be eliminated.

This PEP proposes elimination of terminal \ as a marker for line continuation.

Motivation

One goal for Python 3000 should be to simplify the language by removing unnecessary or duplicated features. There are currently several ways to indicate that a logical line is continued on the following physical line.

The other continuation methods are easily explained as a logical consequence of the semantics they provide; \ is simply an escape character that needs to be memorized.

Existing Line Continuation Methods

Parenthetical Expression - ([{}])

Open a parenthetical expression. It doesn't matter whether people view the "line" as continuing; they do immediately recognize that the expression needs to be closed before the statement can end.

Examples using each of (), [], and {}:

def fn(long_argname1,
       long_argname2):
    settings = {"background": "random noise",
                "volume": "barely audible"}
    restrictions = ["Warrantee void if used",
                    "Notice must be received by yesterday",
                    "Not responsible for sales pitch"]

Note that it is always possible to parenthesize an expression, but it can seem odd to parenthesize an expression that needs parentheses only for the line break:

assert val>4, (
    "val is too small")

Triple-Quoted Strings

Open a triple-quoted string; again, people recognize that the string needs to finish before the next statement starts.

banner_message = """
    Satisfaction Guaranteed,
    or DOUBLE YOUR MONEY BACK!!!





                                    some minor restrictions apply"""

Terminal \ in the general case

A terminal \ indicates that the logical line is continued on the following physical line (after whitespace). There are no particular semantics associated with this. This form is never required, although it may look better (particularly for people with a C language background) in some cases:

>>> assert val>4, \
        "val is too small"

Also note that the \ must be the final character in the line. If your editor navigation can add whitespace to the end of a line, that invisible change will alter the semantics of the program. Fortunately, the typical result is only a syntax error, rather than a runtime bug:

>>> assert val>4, \
        "val is too small"

SyntaxError: unexpected character after line continuation character

This PEP proposes to eliminate this redundant and potentially confusing alternative.

Terminal \ within a string

A terminal \ within a single-quoted string, at the end of the line. This is arguably a special case of the terminal \, but it is a special case that may be worth keeping.

>>> "abd\
 def"
'abd def'

Alternate Proposals

Several people have suggested alternative ways of marking the line end. Most of these were rejected for not actually simplifying things.

The one exception was to let any unfinished expression signify a line continuation, possibly in conjunction with increased indentation.

This is attractive because it is a generalization of the rule for parentheses.

The initial objections to this were:

Andrew Koenig then pointed out [2] a better implementation strategy, and said that it had worked quite well in other languages. [3] The improved suggestion boiled down to:

The whitespace that follows an (operator or) open bracket or parenthesis can include newline characters.

It would be implemented at a very low lexical level -- even before the decision is made to turn a newline followed by spaces into an INDENT or DEDENT token.

There is still some concern that it could mask bugs, as in this example [4]:

# Used to be y+1, the 1 got dropped.  Syntax Error (today)
# would become nonsense.
x = y+
f(x)

Requiring that the continuation be indented more than the initial line would add both safety and complexity.

Open Issues

References

[1](email subject) PEP 30XZ: Simplified Parsing, van Rossum http://mail.python.org/pipermail/python-3000/2007-April/007063.html
[2](email subject) PEP-3125 -- remove backslash continuation, Koenig http://mail.python.org/pipermail/python-3000/2007-May/007237.html
[3]The Snocone Programming Language, Koenig http://www.snobol4.com/report.htm
[4](email subject) PEP-3125 -- remove backslash continuation, van Rossum http://mail.python.org/pipermail/python-3000/2007-May/007244.html