[SR-Dev] operators and variables
Andrei Pelinescu-Onciul
andrei at iptel.org
Fri Dec 12 19:15:29 CET 2008
On Dec 12, 2008 at 16:41, Jan Janak <jan at ryngle.com> wrote:
> On 11-12 22:01, Andrei Pelinescu-Onciul wrote:
> >
> > It would be better to have different operators for strings and for
> > integers. Right now we have '+', '==' and '!=' that can be used both for
> > strings and integers. The problem with this approach is that it makes
> > some optimizations impossible, especially when combined with dynamic
> > typed variables (avps or pvars). '+' is especially bad because one
> > can tell what type ($v + x) has only at runtime.
>
> I would like to preserve the original behaviour for strings. They are used
> much more often than integers. If you need to change anything then, please,
> consider changing the behaviour of integer operators.
>
> > I think having perl like operators would help a lot:
> >
> > - '.' for string concatenation (instead of reusing '+'), e.g.:
> > $v= "foo" . "bar"
>
> Yes, I like this one.
>
> > - 'eq' instead of == for strings, e.g.: $v eq "bar"
> > - 'ne' instead of != for strings, e.g.: $v ne "bar"
>
> I don't like this. If there really is a need to have separate operators then
> use 'eq' and 'ne' for integers and keep == and != for strings. Test (see man
> test) has string and integer operators this way.
I was using perl as a guideline (since we already have perl like stuff,
like ~=).
>
> > We could support them right now in parallel with the old ones and
> > obsolete +, == and != for strings in the future (but that means we
> > still cannot optimize '+' in all the cases) or switch right now
> > (maybe with some old compat switch which will support old scripts
> > style).
> > The question is how much are they used right now. While I think '==' and
> > '!=' are used quite often, I'm not sure about '+' for strings (and '+'
> > is the most important anyway).
>
> I guess == and != are used most often with strings.
>
> > Note: we can still support '==' and '!=' for condition tests not
> > involving variables (e.g. method=="INVITE", uri=="sip:foo" a.s.o.).
>
> That would be inconsistent. if (method=="INVITE") would work, but
> if ($abc=="foo") would not work if strings operators are replaced with 'eq'
> and 'ne'.
Yes, it would be, but I was thinking that most people use it only this
way and hence the change would not affect them immediately.
Andrei
More information about the sr-dev
mailing list