On 19 Apr 2002 [EMAIL PROTECTED] wrote: > ID: 16687 > Updated by: [EMAIL PROTECTED] > Reported By: [EMAIL PROTECTED] > Status: Bogus > Bug Type: Scripting Engine problem > Operating System: Red Hat Linux 7.1 > PHP Version: 4.2.0 > New Comment: > > True true. Derick (or someone else) mind briefly explaining why this > is/has to be different?
Zeev, can you elaborate why this was implemented like this? I forgot it :) Derick > > > Previous Comments: > ------------------------------------------------------------------------ > > [2002-04-19 11:11:00] [EMAIL PROTECTED] > > But then why does it work under certain circumstances and not others? > Regardless whether intended or not, this is inconsistent behaviour. > > I also think that having these differences between regular variables > and the "superglobals" shouldn't be necessary. If I can't use them in > the same contexts as regular variables, then I would personally prefer > the $HTTP_*_VARS instead, because you can. > > I have found my approach to abstracting this difference ($HTTP_*_VARS > vs. $_*) between PHP versions to be really beneficial to my scripts. I > can abstract them both down to one name, and use a single reference to > the appropriate one instead of sticking if statements every time I need > to know which one to use. > > Sorry to keep buggin' ya, but I think this may be a fair enough > argument for change. > > ------------------------------------------------------------------------ > > [2002-04-19 10:33:59] [EMAIL PROTECTED] > > You can't use superglobals indirectly, check this: > > $t = "_GET"; > var_dump ($$t); > > doesn't work neither, and it wasn't supposed to work. > > However, this does work (because $HTTP_GET_VARS is not a superglobal): > > $t = "HTTP_GET_VARS"; > var_dump ($$t); > > > Derick > > ------------------------------------------------------------------------ > > [2002-04-18 19:09:09] [EMAIL PROTECTED] > > reclassified > > ------------------------------------------------------------------------ > > [2002-04-18 17:30:28] [EMAIL PROTECTED] > > It seems to be happening only under certain contexts. Here is a script > that works fine: > > <?php > > $test = 'asdf'; > > define ('_TEST', 'test'); > > echo 'constant: '; > print_r (${_TEST}); > > echo '<br />direct: '; > print_r ($test); > > ?> > > And here is code that does not: > > <?php > > if (PHP_VERSION < '4.1.0') { > define ('_GET', 'HTTP_GET_VARS'); > } else { > define ('_GET', '_GET'); > } > > class CGI { > var $param = array (); > > function CGI () { > global $HTTP_GET_VARS, $HTTP_POST_VARS, $HTTP_POST_FILES; > > if (${_GET}) { > reset (${_GET}); > while (list ($k, $v) = each (${_GET})) { > if (get_magic_quotes_gpc () == 1) { > $this->{$k} = stripslashes ($v); > } else { > $this->{$k} = $v; > } > array_push ($this->param, $k); > } > } else { > echo '<br />_GET value: '; print_r (_GET); > echo '<br />$_GET value: '; print_r ($_GET); > echo '<br />${_GET} value: '; print_r (${_GET}); > } > } > } > > $cgi = new CGI; > > echo '<br />$cgi value: '; print_r ($cgi); > > ?> > > ------------------------------------------------------------------------ > > [2002-04-18 16:43:17] [EMAIL PROTECTED] > > Constants do not appear to be interpreted properly in the following > context: > > ${CONSTANT} > > I found this problem with the following code: > > <?php > > if (PHP_VERSION < '4.1.0') { > define ('_GET', 'HTTP_GET_VARS'); > // etc. > } else { > define ('_GET', '_GET'); > // etc. > } > > print_r (${_GET}); > > ?> > > This should print out the $_GET hash in 4.2.0RC4, but it prints > nothing. A quick check of the _GET constant shows that it does contain > the proper value. > > I compile php with: > > './configure' '--with-pgsql=shared' '--with-gd' > '--with-mysql=/usr/local/mysql' > '--with-apxs2=/usr/local/apache2/bin/apxs' '--enable-shmop' > '--enable-xslt' '--with-xslt-sablot' > > Thanks! > > ------------------------------------------------------------------------ > > > -- > Edit this bug report at http://bugs.php.net/?id=16687&edit=1 > -- PHP Development Mailing List <http://www.php.net/> To unsubscribe, visit: http://www.php.net/unsub.php