Edit report at https://bugs.php.net/bug.php?id=63156&edit=1

 ID:                 63156
 Updated by:         ni...@php.net
 Reported by:        herb at bobbingwide dot com
 Summary:            using if ( expression ) requires functions to be
                     declared before calls
 Status:             Duplicate
 Type:               Bug
 Package:            *Programming Data Structures
 Operating System:   Windows XP
 PHP Version:        5.3.17
 Block user comment: N
 Private report:     N

 New Comment:

@herb: You are using a conditional function definitions, in which case PHP 
*can't* know which function will be used, at least not in the general case. 
Function hoisting only works with "top-level" function declarations.

This is also documented on http://php.net/manual/en/functions.user-defined.php. 
See in particular those two lines:

> Functions need not be defined before they are referenced, *except* when a 
> function is conditionally defined as shown in the two examples below.

> When a function is defined in a conditional manner such as the two examples 
> shown. Its definition must be processed *prior* to being called.

A very simple solution to your particular problem (which at the same time will 
yield cleaner code) is to abort early if the constant is defined:

<?php
if (defined('CONSTANT')) {
    return;
}
// the rest of the file here


Previous Comments:
------------------------------------------------------------------------
[2012-09-25 14:11:14] herb at bobbingwide dot com

laruence... agreed. That's how I solved it, as documented in my original report.
I was just commenting on the original response in #17055.
It was the unexpected behaviour that threw me more than anything.

------------------------------------------------------------------------
[2012-09-25 12:22:07] larue...@php.net

hmm, it's not the only way,  since you can get it works well by declare it 
before reference to it:
<?php
if ( true ) {
  function a() {
    echo "a" . PHP_EOL;
  }
  a();
}

------------------------------------------------------------------------
[2012-09-25 11:33:02] herb at bobbingwide dot com

I accept that this is a duplicate of #17055.

And since derick said, in response to #17055, "I don't see any fast 
implementation of this.", 10 years ago (May 2002), I'm inclined to agree that 
this will have to be dealt with as a documentation problem.

However, in my particular scenario the original response to the problem... "The 
only way to prevent this is to move out the function declaration out of the 
branch and in the main scope of the script." is not acceptable since the whole 
point of the encapsulating code was to prevent the functions from being 
multiply 
defined.

So I believe the documentation should provide a clear explanation of the 
parsing 
and interpretation processes involved.

------------------------------------------------------------------------
[2012-09-25 09:46:26] larue...@php.net

dup to #17055

------------------------------------------------------------------------
[2012-09-25 05:13:48] re...@php.net

Top level declaration are available after compiling, but conditional declaration
can only be available after executed. (since PHP itself didn't do optimization, 
i`f(true) {doSomething();}` is not equal to `doSomething();` exactly )

the same rules for class declarations.

This could be classified as a documentation problem.

------------------------------------------------------------------------


The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at

    https://bugs.php.net/bug.php?id=63156


-- 
Edit this bug report at https://bugs.php.net/bug.php?id=63156&edit=1

Reply via email to