

![]() | Start a set with this search |
![]() | Include this search in one of my sets |
![]() | Exclude this search from one of my sets |
![]() | Permalink to these results Paste this link in email or IM: |
| Atom feed for tracking future search results Paste this URL into your reader: |
18 messages in net.php.lists.internalsRe: [PHP-DEV] [PATCH] Scalar type hin...| From | Sent On | Attachments |
|---|---|---|
| Hannes Magnusson | Nov 3, 2006 10:00 am | .txt |
| Pierre | Nov 3, 2006 10:39 am | |
| Marcus Boerger | Nov 3, 2006 10:46 am | |
| Ron Korving | Nov 3, 2006 10:48 am | |
| Ilia Alshanetsky | Nov 3, 2006 11:06 am | |
| Pierre | Nov 3, 2006 11:12 am | |
| Zeev Suraski | Nov 3, 2006 12:34 pm | |
| Brian Moon | Nov 3, 2006 2:45 pm | |
| Richard Lynch | Nov 6, 2006 12:18 pm | |
| Markus Fischer | Nov 6, 2006 11:00 pm | |
| Richard Quadling | Nov 7, 2006 1:26 am | |
| Ron Korving | Nov 7, 2006 2:19 am | |
| Richard Quadling | Nov 7, 2006 2:39 am | |
| Christian Schneider | Nov 7, 2006 6:45 am | |
| Richard Quadling | Nov 7, 2006 7:33 am | |
| Richard Lynch | Nov 7, 2006 10:45 am | |
| Richard Quadling | Nov 8, 2006 1:37 am | |
| Derick Rethans | Nov 15, 2006 12:19 am |

![]() | Permalink for this message Paste this link in email or IM: |
![]() | Permalink for this thread Paste this link in email or IM: |
| Atom feed for this thread Paste this URL into your reader: |
| Subject: | Re: [PHP-DEV] [PATCH] Scalar type hinting ;) | Actions... |
|---|---|---|
| From: | Richard Quadling (rqua...@googlemail.com) | |
| Date: | Nov 7, 2006 1:26:19 am | |
| List: | net.php.lists.internals | |
Not in direct reply to any message.
Type hinting is on for classes and arrays (maybe resources too - not sure - but certainly a good idea if not). Why? From my perspective, it allows me to not deal with potential errors either in the data or my coding or another developers coding.
Type hinting is part of the documentation. Sure, hungarian notation of variable names (where the type is represented within the variable name itself) is a good start, but when you get to things like a 4d array of string and integer pairs, you get more notation than variable name.
Extending type hinting to scalars is the next step. The loose typing of PHP is great, but as mentioned by Richard Lynch, we have to more or less move away from it for user input and DB input.
Even when we store data in the session it is stored in type, so, pretty much after getting the source data to operate on, the type is fixed.
You don't store a number in the session and get it back as a string to convert back to a number in the next session usage. You store a number, you get a number back.
So, where is the use for loose type? You can't loose type objects or arrays or resource. You no longer need to loose type user input or DB input (cause you are now using SOME sort of input filtering mechanism).
An issue is very much where you have mixed types (which many of the PHP functions support). How do you hint this? You could either used mixed or blank, but maybe you can supply multiple types which the function will support.
Maybe for V6 type hinting for scalars could be available, but output purely E_NOTICE. Really make them just a hint. A suggestion. This will allow auto documentors get to grips with things, allow code complete editors deal with user defined functions, etc.
Sometime after that the facility to make the hints become enforcers. There would be a published list of conversion mechanisms (the equivalent PHP function in effect). You could potentially allow user defined conversions for user defined types though I would see this as a WIBNI, rather than a MH.
If you don't have any hints then nothing changes. If you do have hints, then you would have to accept the hit in the additional checking. If you have the enforcement, then you would have to deal with the NULLs that would result in failed conversions (I would recommend NULL rather than any other value for failed conversions).
-- ----- Richard Quadling Zend Certified Engineer : http://zend.com/zce.php?c=ZEND002498&r=213474731 "Standing on the shoulders of some very clever giants!"








.txt