From owner-freebsd-questions@FreeBSD.ORG Tue Apr 6 18:00:52 2010 Return-Path: Delivered-To: freebsd-questions@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 421BA106564A for ; Tue, 6 Apr 2010 18:00:52 +0000 (UTC) (envelope-from cswiger@mac.com) Received: from asmtpout025.mac.com (asmtpout025.mac.com [17.148.16.100]) by mx1.freebsd.org (Postfix) with ESMTP id 260BC8FC1B for ; Tue, 6 Apr 2010 18:00:51 +0000 (UTC) MIME-version: 1.0 Content-transfer-encoding: 7BIT Content-type: text/plain; charset=us-ascii Received: from cswiger1.apple.com ([17.209.4.71]) by asmtp025.mac.com (Sun Java(tm) System Messaging Server 6.3-8.01 (built Dec 16 2008; 32bit)) with ESMTPSA id <0L0G0038ZVCYCV50@asmtp025.mac.com> for freebsd-questions@freebsd.org; Tue, 06 Apr 2010 11:00:35 -0700 (PDT) X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 spamscore=0 ipscore=0 phishscore=0 bulkscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx engine=5.0.0-0908210000 definitions=main-1004060175 From: Chuck Swiger In-reply-to: <86wrwkiunp.fsf@red.stonehenge.com> Date: Tue, 06 Apr 2010 11:00:34 -0700 Message-id: <2EE33758-C39C-41DC-B6A8-B34CF6B3B25A@mac.com> References: <4BB8108A.9080104@FreeBSD.org> <1270371713.5861.98.camel@tao.thought.org> <86aatjnsts.fsf@red.stonehenge.com> <861vevnsow.fsf@red.stonehenge.com> <20100404163353.GA15198@guilt.hydra> <20100404201442.b456044e.freebsd@edvax.de> <4BB9A5ED.3040309@infracaninophile.co.uk> <20100405173632.739a0c42@gumby.homeunix.com> <20100406015544.GA21119@guilt.hydra> <20100406132049.641b9edf@gumby.homeunix.com> <86wrwkiunp.fsf@red.stonehenge.com> To: "Randal L. Schwartz" X-Mailer: Apple Mail (2.1078) Cc: RW , freebsd-questions@freebsd.org Subject: Re: perl qstn... X-BeenThere: freebsd-questions@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: User questions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 06 Apr 2010 18:00:52 -0000 Hi-- On Apr 6, 2010, at 6:21 AM, Randal L. Schwartz wrote: >>>>>> "RW" == RW writes: > RW> Imperative languages have a natural order of decision followed by > RW> action, and code is most easily readable if the syntax doesn't try to > RW> subvert that. > > And yet, there's an equally valid argument that the most important > thing should stand out the most. In that sense, in the Perl statement: > > warn "x = $x, y = $y, z = $z\n" > if $debug; > > ... the most important part is that it's printing something to stderr, > and what's being printed. It's only minor that it's only when > debugging, and luckily Perl lets us relegate that to the tail end of > the statement. > > Now, if you argue "oh, the most important thing there is 'if debug'", > then fine, you'd write that as: > > if ($debug) { warn ... } > > And I'd be fine with that. Let's suppose you want to display one message if debugging is enabled, and a shorter message if it is not. Adding an else clause to an if statement is a natural change and the result remains highly readable. Can one even use this postfix test syntax with an else, or would you have to re-write the first version entirely? As far as I am concerned, the first version resembles exception handling, ie: try: except Error1: ...and should be reserved for situations where the statement is expected to run normally. If it is reasonable that the test might fail more often than in unusual circumstances, then I'd really prefer to put the test first. > If you don't like all this freedom, there's always Python. :) Yes, Perl lets you innovate a remarkable number of ways of solving the same problem using syntax that varies from clean and maintainable to constructs which even the original author won't understand without effort a few months later. It seems to be uncommon for one to write unreadable Python code; I'm not sure additional freedom to write obfuscated code would be as beneficial as one may assume.... Regards, -- -Chuck