bingo/postgres/sql/9.3/bingo_am.sql.in (171 lines of code) (raw):

CREATE OR REPLACE FUNCTION bingo_build(internal, internal, internal) RETURNS internal AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_buildempty(internal) RETURNS internal AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_insert(internal, internal, internal, internal, internal) RETURNS boolean AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_beginscan(internal, internal, internal) RETURNS internal AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_gettuple(internal, internal) RETURNS boolean AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_rescan(internal, internal) RETURNS void AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_endscan(internal) RETURNS void AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_markpos(internal) RETURNS void AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_restrpos(internal) RETURNS void AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_bulkdelete(internal, internal, internal, internal) RETURNS internal AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_vacuumcleanup(internal, internal) RETURNS internal AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_options(_text, bool) RETURNS bytea AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; CREATE OR REPLACE FUNCTION bingo_costestimate(internal, internal, internal, internal, internal, internal, internal, internal) RETURNS void AS 'BINGO_PATHNAME' LANGUAGE C STRICT VOLATILE; --delete from pg_am where amname='bingo_idx' INSERT INTO pg_am( amname, aminsert, ambeginscan, amgettuple, amgetbitmap, amrescan, amendscan, ammarkpos, amrestrpos, ambuild, ambulkdelete, amvacuumcleanup, amcostestimate, amoptions, ambuildempty, amstrategies, amsupport, amcanorder, amcanbackward, amcanunique, amcanmulticol, amoptionalkey, amsearcharray, amsearchnulls, amstorage, amclusterable, amkeytype, amcanorderbyop, ampredlocks, amcanreturn ) VALUES ( 'bingo_idx', 'bingo_insert(internal, internal, internal, internal, internal)'::regprocedure::oid, 'bingo_beginscan(internal, internal, internal)'::regprocedure::oid, 'bingo_gettuple(internal, internal)'::regprocedure::oid, 0, 'bingo_rescan(internal, internal)'::regprocedure::oid, 'bingo_endscan(internal)'::regprocedure::oid, 'bingo_markpos(internal)'::regprocedure::oid, 'bingo_restrpos(internal)'::regprocedure::oid, 'bingo_build(internal, internal, internal)'::regprocedure::oid, 'bingo_bulkdelete(internal, internal, internal, internal)'::regprocedure::oid, 'bingo_vacuumcleanup(internal, internal)'::regprocedure::oid, 'bingo_costestimate(internal, internal, internal, internal, internal, internal, internal, internal)'::regprocedure::oid, 'bingo_options(_text, bool)'::regprocedure::oid, 'bingo_buildempty(internal)'::regprocedure::oid, 7, 7, false, true, false, false, false, false, false, false, false, 23, false, false, 0 ); --**************************** MANGO OPERATOR CLASS ********************* CREATE OPERATOR CLASS molecule FOR TYPE text USING bingo_idx AS OPERATOR 1 public.@ (text, sub), OPERATOR 2 public.@ (text, exact), OPERATOR 3 public.@ (text, smarts), OPERATOR 4 public.@ (text, gross), OPERATOR 5 public.< (text, mass), OPERATOR 6 public.> (text, mass), OPERATOR 7 public.@ (text, sim), FUNCTION 1 matchSub(text, sub), FUNCTION 2 matchExact(text, exact), FUNCTION 3 matchSmarts(text, smarts), FUNCTION 4 matchGross(text, gross), FUNCTION 5 _match_mass_less(text, mass), FUNCTION 6 _match_mass_great(text, mass), FUNCTION 7 matchSim(text, sim); CREATE OPERATOR CLASS bmolecule FOR TYPE bytea USING bingo_idx AS OPERATOR 1 public.@ (bytea, sub), OPERATOR 2 public.@ (bytea, exact), OPERATOR 3 public.@ (bytea, smarts), OPERATOR 4 public.@ (bytea, gross), OPERATOR 5 public.< (bytea, mass), OPERATOR 6 public.> (bytea, mass), OPERATOR 7 public.@ (bytea, sim), FUNCTION 1 matchSub(bytea, sub), FUNCTION 2 matchExact(bytea, exact), FUNCTION 3 matchSmarts(bytea, smarts), FUNCTION 4 matchGross(bytea, gross), FUNCTION 5 _match_mass_less(bytea, mass), FUNCTION 6 _match_mass_great(bytea, mass), FUNCTION 7 matchSim(bytea, sim); --**************************** RINGO OPERATOR CLASS ********************* CREATE OPERATOR CLASS reaction FOR TYPE text USING bingo_idx AS OPERATOR 1 public.@ (text, rsub), OPERATOR 2 public.@ (text, rexact), OPERATOR 3 public.@ (text, rsmarts), FUNCTION 1 matchRSub(text, rsub), FUNCTION 2 matchRExact(text, rexact), FUNCTION 3 matchRSmarts(text, rsmarts); CREATE OPERATOR CLASS breaction FOR TYPE bytea USING bingo_idx AS OPERATOR 1 public.@ (bytea, rsub), OPERATOR 2 public.@ (bytea, rexact), OPERATOR 3 public.@ (bytea, rsmarts), FUNCTION 1 matchRSub(bytea, rsub), FUNCTION 2 matchRExact(bytea, rexact), FUNCTION 3 matchRSmarts(bytea, rsmarts);