A specification as described in the previous section is translated by code selector description translator (NONA) into code selector description (CS) interface and implementation files having the same names as one of specification file and correspondingly suffixes `.h' and `.c' for C or `.cpp' for C++ (see option `-c++').
C interface file of CS consists of the following definitions of generated type and functions:
           #define CS_NODE           struct IR_node_struct *
           #define CS_TYPE           CS_node
           typedef CS_NODE CS_node;
        `CS_cover CS_find_cover (CS_node node)'
        `int CS_it_is_axiom (CS_cover cover, int nonterminal)'
        `CS_TYPE CS_traverse_cover (CS_cover cover, int nonterminal)'
        `void CS_delete_cover (CS_cover cover)'
        `void CS_start (void)'
        `void CS_finish (void)'
C++ interface file (see option -c++) of CS consists of the following definitions of generated type and functions:
           #define CS_NODE           struct IR_node_struct *
           #define CS_TYPE           CS_node
           typedef CS_NODE CS_node;
            `CS_cover CS_find_cover (CS_node node)'
    
            `void CS_start (void)'
    
            `void CS_finish (void)'
    
            `int CS_it_is_axiom (int nonterminal)'
    
            `CS_TYPE CS_traverse_cover (int nonterminal)'
    
            `void CS_delete_cover (void)'
    
CS implementation file uses the following macros generated by NONA. These macros can be redefined (in any C/C++ declaration section).
        `CS_OPERAND_1_OF_1(node)',
        `CS_OPERAND_1_OF_2(node)',
        `CS_OPERAND_2_OF_2(node)', and so on.
        `integer_plus (register, const8)'
        `CS_STATE(node)',
        `CS_SET_STATE(node, state)'
    #define CS_OPERATION(node)        IR_NODE_MODE (node)
    #define CS_OPERAND_1_OF_1(node)   IR_operand (node)
    #define CS_OPERAND_1_OF_2(node)   IR_operand_1 (node)
    #define CS_OPERAND_2_OF_2(node)   IR_operand_2 (node)
    #define CS_OPERAND_1_OF_3(node)   IR_operand_1 (node)
    #define CS_OPERAND_2_OF_3(node)   IR_operand_2 (node)
    #define CS_OPERAND_3_OF_3(node)   IR_operand_3 (node)
    ...
    #define CS_STATE(node)            IR_state (node)
    #define CS_SET_STATE(node, state) IR_set_state (node, state)
    #define CS_ATTRIBUTE(node)        (node)
    #define CS_ERROR(str)             fprintf (stderr, "%s\012", str)
NONA completely automatically generates macros of storage management for the cover. Usually, the user does not have to care about it. The predefined storage management uses C standard functions for global storage with free lists. The user can create own storage manager by redefinition of one or more the following macros and placing them in a C declaration section. But the user should know that all functions generated by NONA believe that the storage can not change its place after the allocation.
    #define CS_START_ALLOC()
    #define CS_FINISH_ALLOC()
    #define CS_ALLOC(ptr, size, ptr_type) \
                           ((ptr) = (ptr_type) malloc (size))
    #define CS_FREE(ptr, size)  free (ptr)