> On 9 Oct 2019, at 01:34, Björn Larsson <bjorn.x.lars...@telia.com> wrote:
> 
> Den 2019-10-08 kl. 20:22, skrev Stephen Reay:
>> 
>>> On 9 Oct 2019, at 01:08, Björn Larsson <bjorn.x.lars...@telia.com> wrote:
>>> 
>>> Den 2019-10-08 kl. 17:49, skrev Stephen Reay:
>>>>> On 8 Oct 2019, at 22:21, Andreas Hennings <andr...@dqxtech.net> wrote:
>>>>> 
>>>>> The problem with the backtick operator syntax is that it is an obscure
>>>>> but innocent-looking syntax for something that can have a huge,
>>>>> perhaps devastating, impact.
>>>>> It is rare enough in the field (as far as regular packages and
>>>>> applications are concerned) that you can spend 5 years working with
>>>>> PHP without ever learning about it. When you see it for the first
>>>>> time, you will be surprised that this actually executes the code like
>>>>> shell_exec(). This kind of surprise can make you shiver, and will
>>>>> leave a bad taste about the language.
>>>>> 
>>>>> The "<?=" and "<?php" also should really have no place in regular
>>>>> application code outside of templates. If we were to design the
>>>>> language from scratch (which we are not), we would surely not require
>>>>> to start each file with a "<?php". It is like a vestigial organ from
>>>>> the olden days..
>>>>> But removing this in a BC-breaking way would be too costly atm..
>>>>> The only thing I could imagine here is to introduce a distinct type of
>>>>> PHP file which does not require the initial "<?php", and where any
>>>>> further php open or close tags are illegal.
>>>>> 
>>>>> Back to the backtick:
>>>>> If it was just about regular applications and packages, then I think
>>>>> we should get rid of it to prevent the kind of nasty surprise and bad
>>>>> taste I mentioned before.
>>>>> 
>>>>> But as Zeev pointed out, this syntax might be more prevalent in admin
>>>>> scripts, which might have been running on a server for ages and the
>>>>> person who created them might no longer be around. Here the removal
>>>>> would have an unpleasant impact.
>>>>> 
>>>>> The surprise from seeing the backtick operator will differ depending
>>>>> how you see the language: As an application language, as a shell
>>>>> enhancement tool, or as a template engine? PHP can be all three of
>>>>> that, but not every developer will think about it that way.
>>>>> 
>>>>> -- Andreas
>>>>> 
>>>>> 
>>>>> 
>>>>> 
>>>>> 
>>>>> 
>>>>> On Tue, 8 Oct 2019 at 16:30, Chase Peeler <chasepee...@gmail.com> wrote:
>>>>>> On Sun, Oct 6, 2019 at 9:18 AM Reinis Rozitis <r...@roze.lv> wrote:
>>>>>> 
>>>>>>>> -----Original Message-----
>>>>>>>> From: Olumide Samson [mailto:oludons...@gmail.com]
>>>>>>>> 
>>>>>>>> it should be deprecated  for exec usage since they both do same thing
>>>>>>> With that logic <?= should also be deprecated in favor of echo because 
>>>>>>> it
>>>>>>> does the same thing and is hard to find in internet search engines (was 
>>>>>>> in
>>>>>>> some other argument).
>>>>>>> 
>>>>>>> 
>>>>>> And we should deprecate the "print" command, since it's the same as echo.
>>>>>> We should deprecate 'printf', since you can just do 'echo sprintf' and, 
>>>>>> now
>>>>>> that I think about it, we should deprecate sprintf as well, since you can
>>>>>> just use vsprintf. It's a simple change too... sprintf($s,$a,$b,$c) =>
>>>>>> vsprintf($s,[$a,$b,$c]);. I'm just it can be done with just a simple 
>>>>>> regex
>>>>>> search/replace.
>>>>>> 
>>>>>> The fact that are SO many different ways to output text is REALLY 
>>>>>> confusing
>>>>>> for new developers. I think it's imperative we fix all of these items 
>>>>>> RIGHT
>>>>>> NOW. By doing so, I'm sure all the .NET developers that are talking smack
>>>>>> about PHP will suddenly denounce c# and start using PHP as well!
>>>>>> 
>>>>>> 
>>>>>>>> This isn't high cost breaking changes coz it has a verifiable, ready
>>>>>>> alternative to upgrade to without huge Regex searches.
>>>>>>> 
>>>>>>> Since `` are used for literal strings (for poorly chosen reserved words 
>>>>>>> as
>>>>>>> field, table names (which happens from time to time)) in MySQL 
>>>>>>> (multiline)
>>>>>>> queries I doubt there is a simple way to distinguish and replace 
>>>>>>> everything
>>>>>>> to exec().
>>>>>>> 
>>>>>>> rr
>>>>>>> 
>>>>>>> --
>>>>>>> PHP Internals - PHP Runtime Development Mailing List
>>>>>>> To unsubscribe, visit: http://www.php.net/unsub.php
>>>>>>> 
>>>>>>> 
>>>>>> --
>>>>>> Chase Peeler
>>>>>> chasepee...@gmail.com
>>>>> -- 
>>>>> PHP Internals - PHP Runtime Development Mailing List
>>>>> To unsubscribe, visit: http://www.php.net/unsub.php
>>>>> 
>>>> If a server has “scripts” that work now, and there’s no admin involved 
>>>> maintaining it (i.e. updating said scripts) - how is this going to be a 
>>>> problem? If there’s no one to maintain the script, there’s equally no one 
>>>> to update to an entirely new version of PHP either.
>>>> 
>>> Couldn't it be like that the hosting provider no longer
>>> support old PHP versions and the application is forced
>>> up to a new version? And maybe the customer don't
>>> have any technical staff, but needs to rent it in. Then
>>> the least hassle the better, minimising cost.
>>> 
>>> I myself can back down to PHP 5.4 if I wanted to, but
>>> not all hosting providers provides that luxury. I have
>>> really appreciated the smooth upgrade path that PHP
>>> 7.x has provided even if 7.2 needed some small extra
>>> work. 7.0 migration was also pretty smooth, so if 8.0
>>> can repeat that it would be nice.
>>> 
>>> r//Björn L
>> Hi Björn,
>> 
>> 
>> I just want to clarify, you’re imagining a scenario where someone (a) rents 
>> a server that they don’t have control over (i.e. shared hosting) and (b) has 
>> some application running on it that is dependent on running commands via 
>> backquotes which (c) is unmaintained/not being updated and (d) the person 
>> renting the server is not technical enough to ‘fix’ the program?
>> 
>> Have I understood that correctly?
>> 
>> 
>> Cheers
>> 
>> Stephen
>> 
> Hi,
> 
> The scenario I was thinking about is a small company where
> they don't have technical staff permanently employed, more
> taking it in when needed for feature updates, maintenance,
> PHP upgrades etc. And cost should be kept to a minimum,
> especially if there no improvements for the end customer.
> 
> The hosting provider offers a classic LAMP with basic support,
> e.g. managing backups etc. And some hosting providers says
> that yes, feel free to run your app on PHP 5.6 while others
> say we no longer support it, we support PHP 7.1 as lowest
> version.
> 
> Cheers //Björn L
> 

Hi Björn,

Ok - I can see that, I’ve had my share of small on-demand clients too.

So lets say this RFC passes, and from 8.0 (currently slated for ~12 to ~14 
months away) the backtick is deprecated. Maybe the hosting company upgrades 
their minimum/single install to 8.0 some time in 2020, and this company’s 
site/app starts logging that backticks are deprecated.

The RFC doesn’t lay out a timeline for removal, but given the current 
discussion it’s safe to assume it the eventual removal would only be voted 
through at a .0 release - so that means 9.0 minimum. The 7.x series will have 
lasted 5 years by the time 8.0 is released. Obviously that’s not a definitive 
timeline, but going by that rough guide, we’re talking about a feature that 
will become unavailable to use, in roughly 6 years time, and can in most cases 
can be fixed by calling an automated tool, once.


I’m not saying breaking things for the sake of breaking them is a valid 
objective for any RFC - but I also don’t agree with those claiming there is “no 
benefit” to removing backtick support.

Cheers

Stephen

 

--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to