{ ************************************************************************* }
{                                                                           }
{  Licensed Materials - Property of IBM and/or HCL                                     }
{                                                                           }
{  IBM Informix Dynamic Server                                              }
{  (c) Copyright IBM Corporation 2015 All rights reserved.                  }
{  (c) Copyright HCL Technologies Ltd. 2017.  All Rights Reserved.                  }
{                                                                           }
{   Title:      boot1110.sql                                                }
{                                                                           }
{   Description:                                                            }
{       Bootstrapping script for a 11.10 database                           }
{                                                                           }
{ ************************************************************************* }
{                                                                           }
{  ** IMPORTANT - PLEASE READ                                               } 
{                                                                           }
{     All types and routines referenced in this file must be prefixed       }
{     with the user name "informix". E.g., use "informix.boolean"           }
{     and not "boolean"                                                     }
{									    }
{     Also, please follow the formatting conventions!!!                     }
{                                                                           }
{     Please ensure that the identifiers that you choose are <= 18          }
{     characters in length. Otherwise the changes would affect database     }
{     reversion.                                                            }
{                                                                           }
{ ************************************************************************* }

{  --- Create CDR exposed checksum functions  }

create dba function informix.ifx_checksum(informix.lvarchar, informix.integer)
 returns informix.integer
 with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
 external name '(lvarchar_checksum)'
 language C;

grant execute on function informix.ifx_checksum(informix.lvarchar, informix.integer) to public as informix;

create dba function informix.ifx_checksum(informix.integer, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(integer_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.integer, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.smallint, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(short_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.smallint, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(p1 references byte,informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(classicBlob_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.byte, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(p1 references text,informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(classicBlob_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.text, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.blob, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(sblob_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.blob, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.clob, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(sblob_checksum)'
    language C;


grant execute on function informix.ifx_checksum(informix.clob, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.int8, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(int8_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.int8, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.decimal, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(decimal_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.decimal, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.money, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(money_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.money, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.float, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(double_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.float, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.real, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(real_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.real, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.date, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(date_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.date, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(datetime year to fraction, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(datetime_checksum)'
    language C;

grant execute on function informix.ifx_checksum(datetime, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(interval year to month,informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(interval_checksum)'
    language C;

grant execute on function informix.ifx_checksum(interval, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.set, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(collection_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.set, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.multiset, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(collection_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.multiset, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(list, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(collection_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.list, informix.integer)
    to public as informix;

create dba function informix.ifx_checksum(informix.row, informix.integer)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(row_checksum)'
    language C;

grant execute on function informix.ifx_checksum(informix.row, informix.integer) to public as informix;

{ --- Create new systdist procedure  }
create dba procedure informix.systdist (table_id int, column_no int)
   returning int, datetime year to fraction (5), char(1), 
             smallfloat, smallfloat, float , stat, char(1);

   define v_tabauth      char(8);
   define v_colauth      char(3);
   define is_allowed     int;
   define search_columns int;
   define v_colno        smallint;
   define v_seqno        int;
   define v_constr_time  datetime year to fraction(5);
   define v_mode         char(1);
   define v_resolution   smallfloat;
   define v_confidence   smallfloat;
   define v_encdat       stat;
   define v_owner        char(8);
   define user           procedure;
   define v_stattype	 char(1);
   define v_smplsize	 float;
   define v_rolename	 varchar(32);

-- First verify that the current user has select privileges on this column

   let is_allowed = 0;
   let search_columns = 0;

   if user = 'informix' then
      let is_allowed = 1;
   else
      -- Check sysusers to see if the usertype is 'D', ie., the
      -- current user has dba privileges and may see any columns.
      select usertype
         into v_mode
         from informix.sysusers
         where username = user;
      if v_mode = 'D' then
         let is_allowed = 1;
      else
         -- See if the user owns the table, and therefore can see the columns.
         select owner
            into v_owner
	    from informix.systables
	    where tabid = table_id;
         if v_owner = user then
            let is_allowed = 1;
         end if
      end if
   end if

   if is_allowed = 0 then
      foreach 
         select tabauth 
            into v_tabauth
            from informix.systabauth
            where tabid = table_id and
                  (grantee = user or
                   grantee = 'public')
         if substr(v_tabauth, 1, 1) = 's' or substr(v_tabauth, 1, 1) = 'S' then
            let is_allowed = 1;
            exit foreach;
         elif substr(v_tabauth, 3, 1) = '*' then
            let search_columns = 1;
         end if
      end foreach
   end if

-- Search syscolauth only if user does not have select 
-- privileges on all columns.  If the user has no select
-- privileges on any column, then we need search no further.

   if is_allowed = 0 and search_columns = 1 then
      foreach
         select colauth
            into v_colauth
            from informix.syscolauth
            where tabid = table_id and
                  colno = column_no and
                  (grantee = user or
                   grantee = 'public')
         if substr(v_colauth, 1, 1) = 's' or substr(v_colauth, 1, 1) = 'S' then
            let is_allowed = 1;
            exit foreach;
         end if
      end foreach
   end if

-- Check user's current role for privileges on table and columns
   if is_allowed = 0 then
      select CURRENT_ROLE
         into v_rolename
         from informix.systables
         where tabid = 1;

      if v_rolename is NOT NULL then
         -- Check if user's current role has select privilege on table,
         -- and hence can see the columns
         foreach
            select tabauth 
               into v_tabauth
               from informix.systabauth
               where tabid = table_id and
                     grantee = v_rolename
               if substr(v_tabauth, 1, 1) = 's' or
                  substr(v_tabauth, 1, 1) = 'S' then
                  let is_allowed = 1;
                  exit foreach;
               elif substr(v_tabauth, 3, 1) = '*' then
                  let search_columns = 1;
               end if
         end foreach

         -- Search syscolauth only if user's current role does not have select 
         -- privileges on all columns. If the user's current role has no select
         -- privileges on any column, then we need search no further.

         if is_allowed = 0 and search_columns = 1 then
            foreach
               select colauth
                  into v_colauth
                  from informix.syscolauth
                  where tabid = table_id and
                        colno = column_no and
                        grantee = v_rolename
                  if substr(v_colauth, 1, 1) = 's' or
                     substr(v_colauth, 1, 1) = 'S' then
                     let is_allowed = 1;
                     exit foreach;
                  end if
            end foreach
         end if
      end if
   end if

-- Return with no rows found if not allowed to select from
-- the column designated by (tabid,colno).

   if is_allowed = 0 then
      raise exception -272;
   end if

-- Now find the distribution rows

   foreach
      select  seqno, constr_time, mode, 
              resolution, confidence, smplsize, encdat, type
         into v_seqno, v_constr_time, v_mode, 
              v_resolution, v_confidence, v_smplsize, v_encdat, v_stattype
         from informix.sysdistrib
         where tabid = table_id and
               colno = column_no
         order by seqno
      return v_seqno, v_constr_time, v_mode, 
             v_resolution, v_confidence, v_smplsize, v_encdat, v_stattype
         with resume;
   end foreach

-- Engine will return 100 to user

end procedure;

grant execute on informix.systdist to public as informix;

{ ********************** LBAC types, casts, functions *********************** }

{ Distinct types for LBAC }
create distinct type informix.IDSSECURITYLABEL as varchar(128);
create distinct type informix.IDSELEMENTENC as char(8);
create distinct type informix.IDSCOVERINGINFO as varchar(128);

{ Drop the explicit casts created for the LBAC distinct types }
drop cast (informix.IDSSECURITYLABEL as varchar(128));
drop cast (varchar(128) as informix.IDSSECURITYLABEL);
drop cast (informix.IDSELEMENTENC as char(8));
drop cast (char(8) as informix.IDSELEMENTENC);
drop cast (informix.IDSCOVERINGINFO as varchar(128));
drop cast (varchar(128) as informix.IDSCOVERINGINFO);

{ Create the implicit casts for the LBAC distinct types }
create function informix.SeclabelInput(informix.lvarchar) 
    returns informix.IDSSECURITYLABEL
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(seclabel_in)'
    language C;
grant execute on function informix.SeclabelInput(informix.lvarchar)
    to public as informix;
create implicit cast(informix.lvarchar as informix.IDSSECURITYLABEL 
    with informix.SeclabelInput);

create function informix.SeclabelOutput(informix.IDSSECURITYLABEL) 
    returns informix.lvarchar
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(seclabel_out)'
    language C;
grant execute on function informix.SeclabelOutput(informix.IDSSECURITYLABEL)
    to public as informix;
create implicit cast(informix.IDSSECURITYLABEL as informix.lvarchar 
    with informix.SeclabelOutput);

create function informix.ElementencInput(informix.lvarchar) 
    returns informix.IDSELEMENTENC
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(elementenc_in)'
    language C;
grant execute on function informix.ElementencInput(informix.lvarchar)
    to public as informix;
create implicit cast(informix.lvarchar as informix.IDSELEMENTENC 
    with informix.ElementencInput);

create function informix.ElementencOutput(informix.IDSELEMENTENC) 
    returns informix.lvarchar
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(elementenc_out)'
    language C;
grant execute on function informix.ElementencOutput(informix.IDSELEMENTENC)
    to public as informix;
create implicit cast(informix.IDSELEMENTENC as informix.lvarchar 
    with informix.ElementencOutput);

create function informix.CoveringinfoInput(informix.lvarchar) 
    returns informix.IDSCOVERINGINFO
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(coveringinfo_in)'
    language C;
grant execute on function informix.CoveringinfoInput(informix.lvarchar)
    to public as informix;
create implicit cast(informix.lvarchar as informix.IDSCOVERINGINFO 
    with informix.CoveringinfoInput);

create function informix.CoveringinfoOutput(informix.IDSCOVERINGINFO) 
    returns informix.lvarchar
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(coveringinfo_out)'
    language C;
grant execute on function informix.CoveringinfoOutput(informix.IDSCOVERINGINFO)
    to public as informix;
create implicit cast(informix.IDSCOVERINGINFO as informix.lvarchar 
    with informix.CoveringinfoOutput);

{ LBAC SQL function SECLABEL_BY_COMP }
create function informix.SECLABEL_BY_COMP(informix.lvarchar, 
    informix.lvarchar)
    returns informix.IDSSECURITYLABEL
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(ifx_seclabel_by_comp)'
    language C;
grant execute on function informix.SECLABEL_BY_COMP(informix.lvarchar,
    informix.lvarchar) to public as informix;

{ LBAC SQL function SECLABEL_BY_NAME }
create function informix.SECLABEL_BY_NAME(informix.lvarchar, 
    informix.lvarchar)
    returns informix.IDSSECURITYLABEL
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(ifx_seclabel_by_name)'
    language C;
grant execute on function informix.SECLABEL_BY_NAME(informix.lvarchar,
    informix.lvarchar) to public as informix;

{ LBAC SQL function SECLABEL_TO_CHAR }
create function informix.SECLABEL_TO_CHAR(informix.lvarchar, 
    informix.IDSSECURITYLABEL)
    returns informix.lvarchar
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(ifx_seclabel_to_char)'
    language C;
grant execute on function informix.SECLABEL_TO_CHAR(informix.lvarchar,
    informix.IDSSECURITYLABEL) to public as informix;

{ LBAC SQL function ELEMENTENC_TO_DECIMAL }
create function informix.ELEMENTENC_TO_DECIMAL(informix.IDSELEMENTENC)
    returns informix.decimal
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE)
    external name '(ifx_elementenc_to_decimal)'
    language C;
grant execute on function informix.ELEMENTENC_TO_DECIMAL(informix.IDSELEMENTENC)
    to public as informix;

{ *************************************************************************** }

create dba function informix.extract(informix.lvarchar,informix.lvarchar)
    returns informix.lvarchar(32739)
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlextract)'
    language C;

grant execute on function informix.extract(informix.lvarchar,informix.lvarchar)
to public as informix;

create dba function informix.extract(informix.clob,informix.lvarchar)
    returns informix.lvarchar(32739)
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlextractinputclob)'
    language C;

grant execute on function informix.extract(informix.clob,informix.lvarchar)
to public as informix;

create dba function informix.extractclob(informix.clob,informix.lvarchar)
    returns informix.clob
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlextractclob)'
    language C;

grant execute on function informix.extractclob(informix.clob,informix.lvarchar)
to public as informix;

create dba function informix.extractvalue(informix.lvarchar,informix.lvarchar)
    returns informix.lvarchar(32739)
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlextractvalue)'
    language C;

grant execute on function informix.extractvalue(informix.lvarchar,informix.lvarchar)
to public as informix;

create dba function informix.extractvalue(informix.clob,informix.lvarchar)
    returns informix.lvarchar(32739)
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlextractvalueinputclob)'
    language C;

grant execute on function informix.extractvalue(informix.clob,informix.lvarchar)
to public as informix;

create dba function informix.existsnode(informix.lvarchar,informix.lvarchar)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlexistnode)'
    language C;

grant execute on function informix.existsnode(informix.lvarchar,informix.lvarchar)
to public as informix;

create dba function informix.existsnode(informix.clob,informix.lvarchar)
    returns informix.integer
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlexistnodeinputclob)'
    language C;

grant execute on function informix.existsnode(informix.clob,informix.lvarchar)
to public as informix;

create dba function informix.idsxmlparse(informix.lvarchar)
    returns informix.lvarchar(32739)
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlparse)'
    language C;

grant execute on function informix.idsxmlparse(informix.lvarchar)
to public as informix;

create dba function informix.idsxmlparse(informix.clob)
    returns informix.clob
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlparseclob)'
    language C;

grant execute on function informix.idsxmlparse(informix.clob)
to public as informix;

create dba function informix.extractvalueclob(informix.clob,informix.lvarchar)
    returns informix.clob
    with (NOT VARIANT, HANDLESNULLS, PARALLELIZABLE, CLASS = 'idsxmlvp',
          PERCALL_COST = 32768 )
    external name '$INFORMIXDIR/lib/libxml.udr(xmlextractvalueclob)'
    language C;

grant execute on function informix.extractvalueclob(informix.clob,informix.lvarchar)
to public as informix;

create AGGREGATE informix.genxml
with (
      INIT = init_aggrxml,
      ITER = iter_aggrxml,
      COMBINE = comb_aggrxml,
      FINAL = final_aggrxml,
      HANDLESNULLS
      );

create dba function informix.init_aggrxml(informix.ROW, informix.lvarchar)
returns  informix.pointer
external name '(init_aggrxml)'
language C;
grant execute on function informix.init_aggrxml(informix.ROW, informix.lvarchar) to public as informix;
alter function informix.init_aggrxml (informix.ROW, informix.lvarchar)
        with (add handlesnulls);


create dba function informix.iter_aggrxml(informix.pointer, informix.ROW)
returns  informix.pointer
external name '(iter_aggrxml)'
language C;
grant execute on function informix.iter_aggrxml(informix.pointer, informix.ROW)
     to public as informix;
alter function informix.iter_aggrxml (informix.pointer, informix.ROW)
        with (add handlesnulls);


create dba function informix.comb_aggrxml(informix.pointer,informix.pointer)
returns  informix.pointer
external name '(comb_aggrxml)'
language C;
grant execute on function informix.comb_aggrxml(informix.pointer,informix.pointer)
     to public as informix;
alter function informix.comb_aggrxml (informix.pointer,informix.pointer)
        with (add handlesnulls);

create dba function informix.final_aggrxml(informix.pointer)
returns  informix.lvarchar(32739)
external name '(final_aggrxml)'
language C;
grant execute on function informix.final_aggrxml(informix.pointer)
     to public as informix;
alter function informix.final_aggrxml (informix.pointer)
        with (add handlesnulls);


create AGGREGATE informix.genxmlelem
with (
      INIT = init_aggrelem,
      ITER = iter_aggrelem,
      COMBINE = comb_aggrelem,
      FINAL = final_aggrelem,
      HANDLESNULLS
      );
create dba function informix.init_aggrelem(informix.ROW, informix.lvarchar)
returns informix.pointer
external name '(init_aggrelem)'
language C;
grant execute on function informix.init_aggrelem(informix.ROW, informix.lvarchar)
     to public as informix;
alter function informix.init_aggrelem (informix.ROW, informix.lvarchar)
        with (add handlesnulls);


create dba function informix.iter_aggrelem(informix.pointer, informix.ROW)
returns informix.pointer
external name '(iter_aggrelem)'
language C;
grant execute on function informix.iter_aggrelem(informix.pointer, informix.ROW)
     to public as informix;
alter function informix.iter_aggrelem (informix.pointer, informix.ROW)
        with (add handlesnulls);


create dba function informix.comb_aggrelem(informix.pointer,informix.pointer)
returns informix.pointer
external name '(comb_aggrelem)'
language C;
grant execute on function informix.comb_aggrelem(informix.pointer,informix.pointer)
     to public as informix;
alter function informix.comb_aggrelem (informix.pointer,informix.pointer)
        with (add handlesnulls);

create dba function informix.final_aggrelem(informix.pointer)
returns  informix.lvarchar(32739)
external name '(final_aggrelem)'
language C;
grant execute on function informix.final_aggrelem(informix.pointer)
     to public as informix;
alter function informix.final_aggrelem (informix.pointer)
        with (add handlesnulls);

create AGGREGATE informix.genxmlschema
with (
      INIT = init_aggrschema,
      ITER = iter_aggrschema,
      COMBINE = comb_aggrschema,
      FINAL = final_aggrschema,
      HANDLESNULLS
      );
create dba function informix.init_aggrschema(informix.ROW, informix.lvarchar)
returns informix.pointer
external name '(init_aggrschema)'
language C;
grant execute on function informix.init_aggrschema(informix.ROW, informix.lvarchar)
     to public as informix;
alter function informix.init_aggrschema (informix.ROW, informix.lvarchar)
        with (add handlesnulls);


create dba function informix.iter_aggrschema(informix.pointer, informix.ROW)
returns informix.pointer
external name '(iter_aggrschema)'
language C;
grant execute on function informix.iter_aggrschema(informix.pointer, informix.ROW)
     to public as informix;
alter function informix.iter_aggrschema (informix.pointer, informix.ROW)
        with (add handlesnulls);


create dba function informix.comb_aggrschema(informix.pointer,informix.pointer)
returns informix.pointer
external name '(comb_aggrschema)'
language C;
grant execute on function informix.comb_aggrschema(informix.pointer,informix.pointer)
     to public as informix;
alter function informix.comb_aggrschema (informix.pointer,informix.pointer)
        with (add handlesnulls);

create dba function informix.final_aggrschema(informix.pointer)
returns  informix.lvarchar(32739)
external name '(final_aggrschema)'
language C;
grant execute on function informix.final_aggrschema(informix.pointer)
     to public as informix;
alter function informix.final_aggrschema (informix.pointer)
        with (add handlesnulls);



create dba function informix.genxmlqueryhdr(informix.LVARCHAR, informix.LVARCHAR)
returns informix.lvarchar(32739)
with(NOT VARIANT)
external name '(genxmlqueryhdr)'
language C;
grant execute on function informix.genxmlqueryhdr(informix.LVARCHAR, informix.LVARCHAR)
    to public as informix;

create dba function informix.genxmlquery(informix.LVARCHAR, informix.lvarchar)
returns informix.lvarchar(32739)
with(NOT VARIANT)
external name '(genxmlquery)'
language C;
grant execute on function informix.genxmlquery(informix.LVARCHAR, informix.lvarchar)
    to public as informix;

create AGGREGATE informix.genxmlclob
with (
      INIT = init_aggrxmlc,
      ITER = iter_aggrxmlc,
      COMBINE = comb_aggrxmlc,
      FINAL = final_aggrxmlc,
      HANDLESNULLS
      );

create dba function informix.init_aggrxmlc(informix.ROW, informix.lvarchar)
returns  informix.pointer
external name '(init_aggrxmlc)'
language C;
grant execute on function informix.init_aggrxmlc(informix.ROW, informix.lvarchar) to public as informix;
alter function informix.init_aggrxmlc (informix.ROW, informix.lvarchar)
        with (add handlesnulls);


create dba function informix.iter_aggrxmlc(informix.pointer, informix.ROW)
returns  informix.pointer
external name '(iter_aggrxmlc)'
language C;
grant execute on function informix.iter_aggrxmlc(informix.pointer, informix.ROW)
     to public as informix;
alter function informix.iter_aggrxmlc (informix.pointer, informix.ROW)
        with (add handlesnulls);


create dba function informix.comb_aggrxmlc(informix.pointer,informix.pointer)
returns  informix.pointer
external name '(comb_aggrxmlc)'
language C;
grant execute on function informix.comb_aggrxmlc(informix.pointer,informix.pointer)
     to public as informix;
alter function informix.comb_aggrxmlc (informix.pointer,informix.pointer)
        with (add handlesnulls);

create dba function informix.final_aggrxmlc(informix.pointer)
returns  informix.clob
external name '(final_aggrxmlc)'
language C;
grant execute on function informix.final_aggrxmlc(informix.pointer)
     to public as informix;
alter function informix.final_aggrxmlc (informix.pointer)
        with (add handlesnulls);

create AGGREGATE informix.genxmlelemclob
with (
      INIT = init_aggrelemc,
      ITER = iter_aggrelemc,
      COMBINE = comb_aggrelemc,
      FINAL = final_aggrelemc,
      HANDLESNULLS
      );

create dba function informix.init_aggrelemc(informix.ROW, informix.lvarchar)
returns  informix.pointer
external name '(init_aggrelemc)'
language C;
grant execute on function informix.init_aggrelemc(informix.ROW, informix.lvarchar) to public as informix;
alter function informix.init_aggrelemc (informix.ROW, informix.lvarchar)
        with (add handlesnulls);


create dba function informix.iter_aggrelemc(informix.pointer, informix.ROW)
returns  informix.pointer
external name '(iter_aggrelemc)'
language C;
grant execute on function informix.iter_aggrelemc(informix.pointer, informix.ROW)
     to public as informix;
alter function informix.iter_aggrelemc (informix.pointer, informix.ROW)
        with (add handlesnulls);
create dba function informix.comb_aggrelemc(informix.pointer,informix.pointer)
returns  informix.pointer
external name '(comb_aggrelemc)'
language C;
grant execute on function informix.comb_aggrelemc(informix.pointer,informix.pointer)
     to public as informix;
alter function informix.comb_aggrelemc (informix.pointer,informix.pointer)
        with (add handlesnulls);

create dba function informix.final_aggrelemc(informix.pointer)
returns  informix.clob
external name '(final_aggrelemc)'
language C;
grant execute on function informix.final_aggrelemc(informix.pointer)
     to public as informix;
alter function informix.final_aggrelemc (informix.pointer)
        with (add handlesnulls);

create AGGREGATE informix.genxmlschemaclob
with (
      INIT = init_aggrschemac,
      ITER = iter_aggrschemac,
      COMBINE = comb_aggrschemac,
      FINAL = final_aggrschemac,
      HANDLESNULLS
      );

create dba function informix.init_aggrschemac(informix.ROW, informix.lvarchar)
returns  informix.pointer
external name '(init_aggrschemac)'
language C;
grant execute on function informix.init_aggrschemac(informix.ROW, informix.lvarchar) to public as informix;
alter function informix.init_aggrschemac (informix.ROW, informix.lvarchar)
        with (add handlesnulls);


create dba function informix.iter_aggrschemac(informix.pointer, informix.ROW)
returns  informix.pointer
external name '(iter_aggrschemac)'
language C;
grant execute on function informix.iter_aggrschemac(informix.pointer, informix.ROW)
     to public as informix;
alter function informix.iter_aggrschemac (informix.pointer, informix.ROW)
        with (add handlesnulls);
create dba function informix.comb_aggrschemac(informix.pointer,informix.pointer)
returns  informix.pointer
external name '(comb_aggrschemac)'
language C;
grant execute on function informix.comb_aggrschemac(informix.pointer,informix.pointer)
     to public as informix;
alter function informix.comb_aggrschemac (informix.pointer,informix.pointer)
        with (add handlesnulls);

create dba function informix.final_aggrschemac(informix.pointer)
returns  informix.clob
external name '(final_aggrschemac)'
language C;
grant execute on function informix.final_aggrschemac(informix.pointer)
     to public as informix;
alter function informix.final_aggrschemac (informix.pointer)
        with (add handlesnulls);

create dba function informix.genxmlqueryhdrclob(informix.LVARCHAR, informix.LVARCHAR)
returns informix.clob
with(NOT VARIANT)
external name '(genxmlqueryhdrclob)'
language C;
grant execute on function informix.genxmlqueryhdrclob(informix.LVARCHAR, informix.LVARCHAR)
    to public as informix;

create dba function informix.genxmlqueryclob(informix.LVARCHAR, informix.LVARCHAR)
returns informix.clob
with(NOT VARIANT)
external name '(genxmlqueryclob)'
language C;
grant execute on function informix.genxmlqueryclob(informix.LVARCHAR, informix.LVARCHAR)
    to public as informix;

{Changing the cast from explicit to implicit for bytetoblob and texttoclob routines. defect#134359}

drop cast (byte as blob);

create implicit cast (byte as informix.blob with informix.bytetoblob);

drop cast (text as clob);

create implicit cast (text as informix.clob with informix.texttoclob);