Settings

Theme

Recki-CT – A compiler for PHP, written in PHP

github.com

20 points by armenb 11 years ago · 14 comments

Reader

steakejjs 11 years ago

This looks awesome. PHP doesn't get a lot of love but it is really improving a lot and obviously still dominates the web... Glad the turkish bug is finally done with.

Would be really nice to see security augmentations to the language. The vast majority (maybe 9/10) sites I look at where no framework was used, the site is missing have no CSRF tokens, very poor XSS protections, and RCEs are pretty common too. I think this would really improve the language.

  • krapp 11 years ago

    I find it odd that a language whose entire purpose is mixing code in with html doesn't come with the ability to automatically escape any echoed string by default. If you're not using something like Twig you have to wrap each variable in htmlspecialchars or something.

    The argument that 'PHP is a framework' may be valid, but as a framework, raw PHP kind of sucks.

    • goykasi 11 years ago

      PHP is simply a scripting language. It has numerous other uses besides just "mixing code in with html"; it wouldn't make sense to have something like enabled by default. For example, all console scripts would need to disable it.

      • krapp 11 years ago

        Yes, it's a general purpose language and can be used for many different things, but as its name once indicated, PHP's primary use case is preprocessing hypertext. I think it would make sense since that's what almost all the PHP in the wild is involved with. Although i'm sure escaping could also be disabled by default when running from the command line.

  • frozenport 11 years ago

    There is something to be said about security by obscurity. I don't want to see any security implementation because is means shared vulnerabilit.

    • steakejjs 11 years ago

      What? I don't understand what you mean. PHP is not any more insecure than other languages. Some extremely secure sites run PHP....so security augmentations would not be obscurity.

      An example would be built in CSRF protections through something like a form builder

      • meowface 11 years ago

        >PHP is not any more insecure than other languages.

        This is debatable. It's not if you know to avoid many awful components of the language that are pushed in tutorials (like extract, or mysql_query, or register_globals, or loose comparisons).

        • jtreminio 11 years ago

          register_globals was removed several years ago;

          mysql_* functions all have a big red warning at the top of the docs pages warning users not to use it;

          extract has a big red warning about using it on untrusted data.

          PHP shouldn't hold developer's hands, but it does enough to warn them away from the Here There Be Dragons.

          • meowface 11 years ago

            You're right about register_globals.

            However, the others require users to actually read the documentation, which unfortunately many do not. A new user of PHP reading a tutorial does not necessarily know these functions are unsafe. They type the functions into their program and they still work, even on the latest versions of PHP. They don't see a visible deprecation warning on the page.

devNoise 11 years ago

Does anyone have an idea for some of Recki-CT's use cases? I get that compiled PHP will be faster. This seems useful for PHP scripts you would run from the command line. Using the resulting binary as a CGI with Apache would incur the fork/exec cost that the PHP module avoided.

dang 11 years ago

A dupe of https://news.ycombinator.com/item?id=8244014.

mappu 11 years ago

>This means that global variables, dynamic variables (variable-variables, variable function calls, etc) and references are not allowed.

Globals, sure, bad practice. Ideally we wouldn't have any. Dynamic variables make sense to exclude, it turns static analysis into the halting problem. Luckily they're a bad practice too since 5.3 introduced closures.

But references?

EDIT: It's by Anthony Ferrara! and some other pretty big names in the PHP community

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection