ID:               48546
 Comment by:       simon at stienen dot name
 Reported By:      cory dot mawhorter at ephective dot com
 Status:           Open
 Bug Type:         Feature/Change Request
 Operating System: na
 PHP Version:      6CVS-2009-06-14 (CVS)
 New Comment:

To be honest, I don't think either would be necessary, however while I
can see some slight sense for 1), I don't see any need for 2) at all -
if you want something like that: Just write such a function, but make
sure to use $GLOBALS['foo'] instead of just $foo in your include file.
Every other way to do this would mess with scoping. And believe me: If
you don't want to do SOMETHING, it's messing with the scope.

Anyway, my two cents to 1):
Imo this feature (even if unnecessary in the first place) would be of
much more use, if it would return false on failure (as stated), but the
*actual* file name to be included on success. This way, you could extend
the file naming scheme to, for example, have "mod:bla" include/require
the "bla" script from your modules directory.
Additionally it might be nice to have a second parameter telling you
whether it's an include or a require process (maybe even whether it's a
_once), so you could decide to soften that error.

Anyway, as I said: This is nothing that couldn't be done without such a
callback in the first place: You could just
   include sanitize('foo');
instead.


Previous Comments:
------------------------------------------------------------------------

[2009-06-14 03:34:32] cory dot mawhorter at ephective dot com

Description:
------------
Two suggestions for include/require.

1) A callback function.
2) Custom include/require functions.

Reproduce code:
---------------
Callback function example:

function verify_path($absfile) {
   return (basename($absfile) == 'some-file.php');
}

set_include_cb('verify_path');
include 'some-file.php'; // cb returns true: file included
include 'some-other-file.php'; // cb returns false: warning
require 'some-other-file.php'; // cb returns false: fatal error

I could see this being useful in more situations than simply verifying
the include path is correct.

An include/require replacement:

function my_custom_include($inc) {
    // of course, includes into the scope of the function
    include($inc); 

    // it'd be nice if you could tell it to include into 
    // the root scope or whatever... this might be difficult 
    // to do for security reasons... but i'm still throwing 
    // it out there
}

my_custom_include('some-file.php');



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


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

Reply via email to