| Documentation | Documentation.Script-Operators-1-7 HistoryHide minor edits - Show changes to output August 05, 2013, at 04:06 PM 
        by  -  Changed line 4 from: [- Page for other versions: [[Script-Operators|devel]] [[Script-Operators-1-9|1.9]] [[Script-Operators-1-8|1.8]] old versions: 1.7 [[Script-Operators-1-6|1.6]] [[Script-Operators-1-5|1.5]] [[Script-Operators-1-4|1.4]] -] to: (:allVersions Script-Operators 1.7:) May 29, 2013, at 12:52 AM 
        by  -  Changed line 21 from: Assignments can be done like in C, via '=' (equal) operator. Not that not all variables (from script) can be written, some are read-only. Check with [[Documentation/Script-CoreVar-1-9|listing of variables]] to see which ones can be written too. to: Assignments can be done like in C, via '=' (equal) operator. Not that not all variables (from script) can be written, some are read-only. Check with [[Documentation/Script-CoreVar-1-7|listing of variables]] to see which ones can be written too. May 29, 2013, at 12:51 AM 
        by  -  Added lines 1-73: !!!!!Documentation -> [[Documentation.Manuals|Manuals]] -> [[Documentation.Manual-1-7|Manual 1.7]] -> Script Operators (:title Script Operators - ver 1.7 :) ---- [- Page for other versions: [[Script-Operators|devel]] [[Script-Operators-1-9|1.9]] [[Script-Operators-1-8|1.8]] old versions: 1.7 [[Script-Operators-1-6|1.6]] [[Script-Operators-1-5|1.5]] [[Script-Operators-1-4|1.4]] -] \\ || %color=#185662%[+'''Script Operators v1.7'''+]%% || ||[[Script-Routes-1-7|Prev]] || [[Script-Statements-1-7|Next]]|| ---- (:toc-float Table of Content:) Assignments, string and arithmetic operations can be done directly in the configuration file. !!!!Assignment Assignments can be done like in C, via '=' (equal) operator. Not that not all variables (from script) can be written, some are read-only. Check with [[Documentation/Script-CoreVar-1-9|listing of variables]] to see which ones can be written too. [@ $var(a) = 123; $ru = "sip:user@domain"; @] There is a special assign operator ':=' (colon equal) that can be used with AVPs. If the right value is '''null''', all AVPs with that name are deleted. If different, the new value will overwrite any existing values for the AVPs with than name (on other words, delete existing AVPs with same name, add a new one with the right side value). [@ $avp(val) := 123; @] !!!!String operations For strings, '+' is available to concatenate. [@ $var(a) = "test"; $var(b) = "sip:" + $var(a) + "@" + $fd; @] !!!!Arithmetic and bitwise operations For numbers, one can use: * + : plus * - : minus * / : divide * * : multiply * % : modulo * | : bitwise OR * & : bitwise AND * ^ : bitwise XOR * ~ : bitwise NOT * << : bitwise left shift * >> : bitwise right shift Example: [@ $var(a) = 4 + ( 7 & ( ~2 ) ); @] NOTE: to ensure the priority of operands in expression evaluations do use __parenthesis__. Arithmetic expressions can be used in condition expressions via test operator ' [ ... ] '. [@ if( [ $var(a) & 4 ] ) log("var a has third bit set\n"); @] | 
 
  