webmcp
annotate framework/env/param/get.lua @ 3:795b764629ca
Version 1.0.3
Important bugfix related to internal forwards (Bug was introduced by the restriction of views with underscore prefix in Version 1.0.2)
Important bugfix related to internal forwards (Bug was introduced by the restriction of views with underscore prefix in Version 1.0.2)
| author | jbe | 
|---|---|
| date | Thu Dec 10 12:00:00 2009 +0100 (2009-12-10) | 
| parents | 9fdfb27f8e67 | 
| children | 32ec28229bb5 | 
| rev | line source | 
|---|---|
| jbe/bsw@0 | 1 --[[-- | 
| jbe/bsw@0 | 2 value = -- value of the parameter casted to the chosen param_type | 
| jbe/bsw@0 | 3 param.get( | 
| jbe/bsw@0 | 4 key, -- name of the parameter | 
| jbe/bsw@0 | 5 param_type -- desired type of the returned value | 
| jbe/bsw@0 | 6 ) | 
| jbe/bsw@0 | 7 | 
| jbe/bsw@0 | 8 Either a GET or POST request parameter is returned by this function, or if param.exchange(...) was called before, one of the exchanged parameters is returned. You can specify which type the returned value shall have. If an external request parameter was used and there is another GET or POST parameter with the same name but a "__format" suffix, the parser with the name of the specified format will be automatically used to parse and convert the input value. | 
| jbe/bsw@0 | 9 | 
| jbe/bsw@0 | 10 --]]-- | 
| jbe/bsw@0 | 11 | 
| jbe/bsw@0 | 12 function param.get(key, param_type) | 
| jbe/bsw@0 | 13 local param_type = param_type or atom.string | 
| jbe/bsw@0 | 14 if param._exchanged then | 
| jbe/bsw@0 | 15 local value = param._exchanged.params[key] | 
| jbe/bsw@0 | 16 if value ~= nil and not atom.has_type(value, param_type) then | 
| jbe/bsw@0 | 17 error("Parameter has unexpected type.") | 
| jbe/bsw@0 | 18 end | 
| jbe/bsw@0 | 19 return value | 
| jbe/bsw@0 | 20 else | 
| jbe/bsw@0 | 21 local str = cgi.params[key] | 
| jbe/bsw@0 | 22 local format_info = cgi.params[key .. "__format"] | 
| jbe/bsw@0 | 23 if not str then | 
| jbe/bsw@0 | 24 if not format_info then | 
| jbe/bsw@0 | 25 return nil | 
| jbe/bsw@0 | 26 end | 
| jbe/bsw@0 | 27 str = "" | 
| jbe/bsw@0 | 28 end | 
| jbe/bsw@0 | 29 return param._get_parser(format_info, param_type)(str) | 
| jbe/bsw@0 | 30 end | 
| jbe/bsw@0 | 31 end |