oracular (7) mawk-code.7.gz

Provided by: mawk_1.3.4.20240622-2_amd64 bug

NAME

       mawk-code - dumping mawk's byte-code

SYNOPSIS

       At  startup,  mawk  compiles  the  script  into  byte-code.  After that, it interprets the
       compiled byte-code.  Use the -Wdump option to show the byte-code.

PROGRAM CODES

       As mawk executes the program, it maintains a reference to the command to execute  in  cdp.
       After that there may be data and/or references in cdp[0], cdp[1], etc.

       When  an  operation requires operands, mawk pushes the values (or array/string references)
       onto the stack, which updates the stack pointer sp.  When the  operation  completes,  mawk
       consumes those entries on the stack, pushing the result (if any) onto the stack.

       While  executing  user-defined functions, mawk maintains a frame pointer fp to address the
       function's local variables.

   a_cat
       Concatenate array-indices.

       Usage:
            Forms a multiple array index by concatenating the elements of sp[1-cnt..0], with each
            element separated by SUBSEP.

       Parameters:

            cdp[0]
                 cnt, the number of elements to concatenate follows the command.

            sp[0]..sp[1-cnt]
                 hold reference to the elements to concatenate.
       Returns the index in sp[0].

   a_del
       Delete an array item.

       Usage:
            delete array[expr]

       Parameters:

            sp[0]
                 points to array

            sp[-1]
                 is an expr

   a_length
       Find the length of an array.

       Usage:
            length(array)

       Parameters:

            sp[0]
                 points to array.

       Returns the length of the array in sp[0].

   a_pusha
       Push array address onto stack.

       Usage:
            This is used to set up a calling argument for a function.

       Parameters:

            cdp[0]
                 array reference follows the command.

       Returns the array in sp[0].

   a_test
       Test if an expression is present in an array.

       Usage:
            (expression in array)

       Parameters:

            sp[0]
                 points to an array.

            sp[-1]
                 is an expression.

       Returns 1 in sp[0] if the expression is found, 0 otherwise.

   add
       Add two numbers.

       Usage:
            first + second

       Parameters:

            sp[0]
                 holds the second value.

            sp[-1]
                 holds the first value.

       Returns the sum in sp[0].

   add_asg
       Combined addition/assignment.

       Usage:
            target += source

       Parameters:

            sp[0]
                 is the source expression

            sp[-1]
                 points to the target

       Stores the sum in the target, leaving sp[0] pointing to the target.

   ae_pusha
       Push reference to array cell, given expression for its index.

       Usage:
            arrayname[expression]

       Parameters:

            cdp[0]
                 an array reference follows the command.

            sp[0]
                 has an expression, used for the index of a cell in the array.

       Returns a reference to the addressed cell in sp[0].

   ae_pushi
       Push contents of array cell, given expression for its index.

       Usage:
            arrayname[expression]

       Parameters:

            sp[0]
                 has an expression, used for the index of a cell in the array.

       Returns contents of the addressed cell in sp[0].

   aloop
       Update reference to next cell for array loop.

       Usage:
            for ( i in arrayname )  statement

       Parameters:

            none

       Mawk  maintains  a stack of array-loop state.  It updates the array/cell references in the
       current loop's state.

   assign
       Assigns a value.

       Usage:
            target = source

       Parameters:

            sp[0]
                 is the source expression

            sp[-1]
                 points to the target

            Stores the sum in the target, leaving sp[0] pointing to the target.

   atan2
       Compute arc-tangent of two values.

       Usage:
            atan2( first, second )

       Parameters:

            sp[0]
                 holds the second value

            sp[-1]
                 holds the first value

       Returns the result in sp[0].

   call
       Call a function.

       Usage:
            function()

       Parameters:

            cdp[0]
                 is a reference to the function block

            cdp[1]
                 holds number of input arguments

       Returns function value in sp[0].

   cat
       Concatenate two strings.

       Usage:
            first second

       Parameters:

            sp[0]
                 is the second string.

            sp[-1]
                 is the first string.

       Returns the result in sp[0].

   close
       Close the file or pipe associated with an expression.

       Usage:
            close( expression )

       Parameters:

            sp[0]
                 holds the expression identifying the file to close

       Returns the status from closing the file, 0 on success or -1 on failure.

   cos
       Compute the cosine of a value in radians.

       Usage:
            cos( value )

       Parameters:

            sp[0]
                 is the value.

       Returns the result in sp[0].

   del_a
       Delete an array.

       Usage:
            delete(array)

       Parameters:

            sp[0]
                 is the array to delete.

   div
       Divide one number by another.

       Usage:
            first / second

       Parameters:

            sp[0]
                 is the second value.

            sp[-1]
                 is the first value.

       Returns the quotient in sp[0].

   div_asg
       Combined division/assignment.

       Usage:
            target /= source

       Parameters:

            sp[0]
                 is the source

            sp[-1]
                 points to the target

       Stores the quotient in the target, leaving sp[0] pointing to the target.

   eq
       Compare two values.

       Usage:
            first == second

       Parameters:

            sp[0]
                 is the second value

            sp[-1]
                 is the first value

       Returns 1 in sp[0] if the values are equal, otherwise 0.

   exit
       Exits mawk with a specific exit-code.

       Usage:
            exit(exit_code)

       Parameters:

            sp[0]
                 is the exit_code

   exit0
       Exits mawk with success

       Usage:
            exit

       Parameters:
            none

   exp
       Compute base-e exponential function of a value.

       Usage:
            exp( value )

       Parameters:

            sp[0]
                 is the value

       Returns the result in sp[0].

   f_add_asg
       Combination addition/assignment to NF.

       Usage:
            NF += expression

       Parameters:

            sp[0]
                 is the expression to add

   f_assign
       Assign an expression to NF.

       Usage:
            NF = expression

       Parameters:

            sp[0]
                 is the expression

   f_div_asg
       Combination division/assignment to NF.

       Usage:
            NF /= expression

       Parameters:

            sp[0]
                 is the expression

   f_mod_asg
       Combination modulus/assignment to NF.

       Usage:
            NF %= expression

       Parameters:

            sp[0]
                 is the expression

   f_mul_asg
       Combination multiplication/assignment to NF.

       Usage:
            NF *= expression

       Parameters:

            sp[0]
                 is the expression

   f_post_dec
       Post-decrement using NF.

       Usage:

            NF--
       Parameters:
            holds a reference to the field to use

   f_post_inc
       Post-increment using NF.

       Usage:
            NF++

       Parameters:
            holds a reference to the field to use

   f_pow_asg
       Exponentiation using NF.

       Usage:
            NF ^= expression

       Parameters:

            sp[0]
                 is the expression to use

   f_pre_dec
       Predecrement using NF.

       Usage:
            --NF

       Parameters:

            sp[0]
                 holds a reference to the field to use

   f_pre_inc
       Preincrement using NF.

       Usage:
            ++NF

       Parameters:

            sp[0]
                 holds a reference to the field to use

   f_pusha
       Push array reference to data split-up as fields..

       Usage:
            $0 = expression
            getline

       Parameters:

            cdp[0]
                 is a reference to the data to be split/assigned.

       Returns the resulting array reference in sp[0].

   f_pushi
       Push contents of numbered field.

       Usage:
            $expression

       Parameters:

            cdp[0]
                 holds a reference to $expression

            cdp[1]
                 holds expression

       Returns the field's value in sp[0].

   f_sub_asg
       Combination subtraction/assignment to NF.

       Usage:
            NF -= expression

       Parameters:

            sp[0]
                 holds a reference to the field to use

   fe_pusha
       Push reference to numbered field.

       Usage:
            $number

       Parameters:

            sp[0]
                 holds the field number

       Returns a reference to the field in sp[0].

   fe_pushi
       Push content of numbered field.

       Usage:
            $number

       Parameters:

            sp[0]
                 holds the field number

       Returns the field's content in sp[0].

   fflush
       Flush the output file or pipe associated with an expression.

       Usage:
            fflush( expression )

       Parameters:

            sp[0]
                 is the expression value

       Returns the result in sp[0].

   gt
       Test if first value is greater than the second.

       Usage:
            first > second

       Parameters:

            sp[0]
                 holds the second value.

            sp[-1]
                 holds the first value.

       Returns 1 in sp[0] if the first value is greater than, otherwise 0.

   gte
       Test if first value is greater than or equal to the second.

       Usage:
            first >= second

       Parameters:

            sp[0]
                 holds the second value.

            sp[-1]
                 holds the first value.

       Returns 1 in sp[0] if the first value is greater than or equal, otherwise 0.

   index
       Find the position of the second string in the first.

       Usage:
            index( first, second )

       Parameters:

            sp[0]
                 is the second string

            sp[0]
                 is the first string

       Returns the position in sp[0] starting at 1 if found, 0 if not found.

   int
       Returns a value truncated towards zero..

       Usage:
            int( value )

       Parameters:

            sp[0]
                 is the value

       Returns the result in sp[0].

   jmain
       Go from BEGIN code to MAIN code.

       Usage:
            (internal state)

       Parameters:

            none

   jmp
       Jump to a new byte-code position, by a given number of bytes.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 holds the (signed) number of bytes by which to jump.

   jnz
       Jump to a new byte-code position if sp[0] is nonzero, by a given number of bytes.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                   holds the (signed) number of bytes by which to jump.

            sp[0]
                 holds a value to compare against 0.

   jz
       Jump to a new byte-code position if sp[0] is zero, by a given number of bytes.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                   holds the (signed) number of bytes by which to jump.

            sp[0]
                 holds a value to compare against 0.

   l_pusha
       Push a local address onto the evaluation stack.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 holds the offset from the frame pointer fp.

       Returns the address in sp[0].

   l_pushi
       Push contents of a local variable onto the evaluation stack.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 holds the offset from the frame pointer fp.

       Returns the contents of the local variable in sp[0].

   la_pusha
       Pushes a reference to an array onto the evaluation stack.

       Usage:
            arrayname

       Parameters:

            cdp[0]
                 holds the offset from the frame pointer fp of a reference to an array.

       Returns a reference to the array in sp[0].

   lae_pusha
       Pushes a reference to a given array cell onto the evaluation stack.

       Usage:
            arrayname[expression]

       Parameters:

            cdp[0]
                 holds the offset from the frame pointer fp of a reference to an array.

            sp[0]
                 holds an expression

       Returns a reference to the specified array cell in sp[0].

   lae_pushi
       Pushes the contents of a given array cell onto the evaluation stack.

       Usage:
            arrayname[expression]

       Parameters:

            cdp[0]
                 holds the offset from the frame pointer fp of a reference to an array.

            sp[0]
                 holds an expression

       Returns the contents of the specified array cell in sp[0].

   length
       Returns the length of a string or array value.

       Usage:
            length( value )

       Parameters:

            sp[0]
                 is the string or array reference

       Returns the length in sp[0].

   ljnz
       Special jump for logical-OR, always preceded by test.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 holds the (signed) number of bytes by which to jump if the value is nonzero.

            sp[0]
                 holds a value to compare against 0.

   ljz
       Special jump for logical-OR, always preceded by test.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 holds the (signed) number of bytes by which to jump if the value is zero.

            sp[0]
                 holds a value to compare against 0.

   log
       Compute the natural logarithm of a value.

       Usage:
            log( value )

       Parameters:

            sp[0]
                 is the value

       Returns the result in sp[0].

   lt
       Test if first value is less than the second.

       Usage:
            first < second

       Parameters:

            sp[0]
                 holds the second value.

            sp[-1]
                 holds the first value.

       Returns 1 in sp[0] if the first value is less than, otherwise 0.

   lte
       Test if first value is less than or equal to the second.

       Usage:
            first <= second

       Parameters:

            sp[0]
                 holds the second value.

            sp[-1]
                 holds the first value.

       Returns 1 in sp[0] if the first value is less than or equal, otherwise 0.

   match0
       Test if $0 matches a given regular expression.

       Usage:
            $0 ~ regex

       Parameters:

            cdp[0]
                 holds a reference to a regular expression.

       Returns 1 in sp[0] if $0 matches the regular expression, 0 otherwise.

   match1
       Test if a given expression matches a given regular expression.

       Usage:
            expression ~ regex

       Parameters:

            cdp[0]
                 holds a reference to a regular expression.

            sp[0]
                 holds an expression to test.

       Returns 1 in sp[0] if the expression matches the regular expression, 0 otherwise.

   match2
       Test if an expression in sp[-1] matches the regular expression in sp[0].

       Usage:
            expression ~ regex

       Parameters:

            sp[0]
                 holds a reference to a regular expression.

            sp[-1]
                 holds an expression to test.

       Returns 1 in sp[0] if the expression matches the regular expression, 0 otherwise.

   mktime
       Converts  a date specification in systime format to a timestamp.

       Usage:
            mktime( string )

       Parameters:

            sp[0]
                 holds the date-specification string

       Returns the result in sp[0].

   mod
       Compute modulus/remainder with two operands.

       Usage:
            first % second

       Parameters:

            sp[0]
                 holds the second operand

            sp[-1]
                 holds the first operand

       Returns the remainder in sp[0].

   mod_asg
       Assign modulus/remainder with two operands.

       Usage:
            first %= second

       Parameters:

            sp[0]
                 holds the second operand

            cdp[0]
                 holds the first operand

       Returns the remainder in sp[0] as well as replacing the first value.

   mul
       Compute product with two operands.

       Usage:
            first * second

       Parameters:

            sp[0]
                 holds the second value

            sp[-1]
                 holds the first value

       Returns the product in sp[0].

   mul_asg
       Assign product with two operands.

       Usage:
            first *= second

       Parameters:

            sp[0]
                 holds the second value

            sp[-1]
                 holds the first value

       Returns the product in sp[0] as well as replacing the first value.

   neq
       Compare two values.

       Usage:
            first != second

       Parameters:

            sp[0]
                 is the second value

            sp[-1]
                 is the first value

       Returns 1 in sp[0] if the values are not equal, otherwise 0.

   next
       Read the next record, restart pattern testing.

       Usage:
            next

       Parameters:

            none

   nextfile
       Begin processing the next file listed on the command line.

       Usage:
            nextfile

       Parameters:

            none

   nf_pushi
       Push the number of fields (NF) onto the evaluation stack.

       Usage:
            (internal state)

       Parameters:

            none

   not
       Compute a logical negation.

       Usage:
            ! value

       Parameters:

            sp[0]
                 holds a value to negate.

       Returns the result on the evaluation stack,  i.e.,  0  if  the  value  is  nonzero  and  1
       otherwise.

   ol_gl
       Read into $0 using getline.

       Usage:
            getline

       Parameters:

            none

   ol_gl_nr
       Read into $0 using getline, updating NR and FNR.

       Usage:
            getline < file

       Parameters:

            none

   omain
       Start executing the main section of the script (between BEGIN and END).

       Usage:
            (internal state)

       Parameters:

            none

   pop
       Pop the evaluation stack, discarding the value.

       Usage:
            (internal state)

       Parameters:

            none

   pop_al
       Finish an array “in” loop, deallocating the state information.

       Usage:
            (internal state)

       Parameters:

            none

   post_dec
       Post-decrement a value.

       Usage:
            value --

       Parameters:

            sp[0]
                 holds the value to decrement

       Returns the updated value in sp[0].

   post_inc
       Post-increment a value.

       Usage:
            value ++

       Parameters:

            sp[0]
                 holds the value to increment

       Returns the updated value in sp[0].

   pow
       Compute the first value raised to the power of the second value.

       Usage:
            first ^ second

       Parameters:

            sp[0]
                 holds the second value

            sp[-1]
                 holds the first value

       Returns the result in sp[0].

   pow_asg
       Assign the first value raised to the power of the second value.

       Usage:
            variable = first ^ second

       Parameters:

            cdp[0]
                 is a reference to the variable which will be assigned the result

            sp[0]
                 holds the second value

            sp[-1]
                 holds the first value

   pre_dec
       Pre-decrement a value.

       Usage:
            -- value

       Parameters:

            sp[0]
                 holds the value to decrement.

       Returns the updated value in sp[0];.

   pre_inc
       Pre-increment a value.

       Usage:
            ++ value

       Parameters:

            sp[0]
                 holds the value to decrement.

       Returns the updated value in sp[0];.

   pusha
       Push array address onto stack.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 array reference follows the command.

       Returns the array in sp[0].

   pushc
       Push a data cell onto the evaluation stack.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 is a reference to the data to push

       Returns a reference to the result in sp[0].

   pushd
       Push a double floating value onto the evaluation stack.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 is a reference to the data to push

       Returns a reference to the result in sp[0].

   pushi
       Push contents of next referenced variable onto the evaluation stack.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 is a reference to the data cell to copy.

       Returns a reference to the result in sp[0].

   pushint
       Reserve the next slot on the evaluation stack, setting its type.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 holds the type to set in the new slot, e.g., for data via I/O redirection

       Returns a reference to the result in sp[0].

   pushs
       Push a reference to a string value onto the evaluation stack.

       Usage:
            (internal state)

       Parameters:

            cdp[0]
                 holds a reference to the string value

       Returns a reference to the result in sp[0].

   rand
       Returns a random number between zero and one..

       Usage:
            rand()

       Parameters:

            none

       Returns the result in sp[0].

   range
       Test a range pattern:  pat1, pat2 { action }.

       Usage:
            (internal state)

       Parameters:

            cdp[0].op
                 a flag, test pat1 if on else pat2

            cdp[1].op
                 offset of pat2 code from cdp

            cdp[2].op
                 offset of action code from cdp

            cdp[3].op
                 offset of code after the action from cdp

            cdp[4]
                 start of pat1 code

            sp[0]
                 holds arguments for the action.

   ret
       Return a function value.

       Usage:
            return value

       Parameters:

            sp[0]
                 holds the return value

       When  calling  a  function,  mawk saves the current stack, creating a new one.  On return,
       mawk restores the previous stack and returns the function value in sp[0].

   ret0
       Return from a function without providing a return-value.

       Usage:
            return

       Parameters:

            sp[0]
                 is modified to make the value uninitialized.

       As in the ret operation, mawk restores the previous stack.  After the return, sp[0] is  an
       uninitialized value.

   set_al
       Begin an array “in” loop.

       Usage:
            for ( iterator in arrayname )  statement

       Parameters:

            sp[0]
                 holds a reference to the array

            sp[-1]
                 holds a reference to the iteration variable

       Mawk  pushes  a  new  entry  onto  the  array  loop stack, and updates cdp to point to the
       statement to execute.

   sin
       Compute the sine of a value in radians.

       Usage:
            sin( value )

       Parameters:

            sp[0]
                 holds the value

       Returns the result in sp[0].

   sprintf
       Returns a string constructed from expression-list according to format.

       Usage:
            sprintf( format [, value1 [,... ] ] )

       Parameters:

            sp[0]
                 is the last parameter value; there can be up to 255.
       Returns the resulting string in sp[0].

   sqrt
       Returns the square root of a value.

       Usage:
            sqrt( value 0

       Parameters:

            sp[0]
                 is the value

       Returns the result in sp[0].

   srand
       Seeds the random number generator.

       Usage:
            srand( value )
            srand( )

       Parameters:

            sp[0]
                 is the seed value, which may be uninitialized

       Returns the previous seed value in sp[0].

   stop
       Finish a range pattern.

       Usage:
            (internal state)

       Parameters:

            none

   strftime
       Formats the given timestamp using the given format.

       Usage:
            strftime( format , timestamp , utc )
            strftime( format , timestamp )
            strftime( format )
            strftime( )

       Parameters:

            Zero to three parameters may be on the stack.  If all three are  used,  they  are  as
            follows:

            sp[0]
                 is the utc flag

            sp[-1]
                 is the timestamp value

            sp[-2]
                 is the format

       Returns the result in sp[0].

   sub
       Subtract the second value from the first.

       Usage:
            first - second

       Parameters:

            sp[0]
                 holds the second value

            sp[-1]
                 holds the first value

            Returns the result in sp[0].

   sub_asg
       Assign the difference of two values to a variable.

       Usage:
            target = first - second

       Parameters:

            cdp[0]
                 holds a reference to the variable to which to assign the result

            sp[0]
                 holds the second value

            sp[-1]
                 holds the first value

       Stores the difference in the target, leaving sp[0] pointing to the target.

   substr
       eturns the substring of string s, starting at index i, of length n.

       Usage:
            substr(s,i,n)
            substr(s,i)

       Parameters:

            Two  or  three  parameters  may  be on the stack.  If all three are used, they are as
            follows:

            sp[0]
                 holds the length n.

            sp[0]
                 holds the index i.

            sp[0]
                 holds the string s.

   system
       Executes a command, returning the wait-status.

       Usage:
            status = system( command )

       Parameters:

            sp[0]
                 is the command to execute

       Returns the wait-status in sp[0].

   systime
       Returns the current time of day as the number of seconds since the Epoch.

       Usage:
            systime( )

       Parameters:

            none

       Returns the result in sp[0].

   test
       Test a logical expression.

       Usage:
            value

       Parameters:

            sp[0]
                 holds a value to test.

       Returns the result on the evaluation stack,  i.e.,  1  if  the  value  is  nonzero  and  0
       otherwise.

   tolower
       Copy a string, converting to lowercase.

       Usage:
            tolower( value )

       Parameters:

            sp[0]
                 is the value to convert

       Returns the result in sp[0].

   toupper
       Copy a string, converting to uppercase.

       Usage:
            toupper( value )

       Parameters:

            sp[0]
                 is the value to convert

       Returns the result in sp[0].

   uminus
       Unitary minus.

       Usage:
            - value

       Parameters:

            sp[0]
                 contains  a  value to negate.  As a side-effect, if the value is a string, it is
                 cast to double floating point.

       Returns the result in sp[0].

   uplus
       Unitary plus.

       Usage:
            + value

       Parameters:

            sp[0]
                 contains a value to use.  As a side-effect, if the value is a string, it is cast
                 to double floating point.

            Returns the result in sp[0].

REGULAR EXPRESSIONS

   M_1J
       mandatory jump

   M_2JA
       optional (undesirable) jump

   M_2JB
       optional (desirable) jump

   M_2JC
       pop pos'n, optional jump if advanced

   M_ACCEPT
       end of match

   M_ANY
       arbitrary character (.)

   M_CLASS
       character class

   M_END
       end of string ($)

   M_SAVE_POS
       push position onto stack

   M_START
       start of string (^)

   M_STR
       matching a literal string

   M_U
       arbitrary string (.*)