Skip to content

Commit

Permalink
fix: confict typmod for _vectors_cast_array_to_vecf32 (#617)
Browse files Browse the repository at this point in the history
Signed-off-by: cutecutecat <[email protected]>
  • Loading branch information
cutecutecat authored Nov 21, 2024
1 parent 21656e4 commit 06e1c76
Showing 1 changed file with 38 additions and 14 deletions.
52 changes: 38 additions & 14 deletions sql/upgrade/vectors--0.3.0--0.4.0.sql
Original file line number Diff line number Diff line change
Expand Up @@ -907,16 +907,40 @@ IMMUTABLE STRICT PARALLEL SAFE
LANGUAGE c /* Rust */
AS 'MODULE_PATHNAME', '_vectors_cast_bvector_to_vecf32_wrapper';

-- src/datatype/casts.rs:10
-- vectors::datatype::casts::_vectors_cast_array_to_vecf32
CREATE OR REPLACE FUNCTION "_vectors_cast_array_to_vecf32"(
"array" real[], /* pgrx::datum::array::Array<f32> */
"typmod" INT, /* i32 */
"_explicit" bool /* bool */
) RETURNS vector /* vectors::datatype::memory_vecf32::Vecf32Output */
IMMUTABLE STRICT PARALLEL SAFE
LANGUAGE c /* Rust */
AS 'MODULE_PATHNAME', '_vectors_cast_array_to_vecf32_wrapper';
-- There might be a conflict of `typmod` or `_typmod`
DO $$
DECLARE
func_arg_2 TEXT;
BEGIN
SELECT parameter_name INTO func_arg_2
FROM information_schema.routines
LEFT JOIN information_schema.parameters ON routines.specific_name=parameters.specific_name
WHERE routines.specific_schema='vectors' AND routines.routine_name='_vectors_cast_array_to_vecf32' AND parameters.ordinal_position=2
ORDER BY routines.routine_name, parameters.ordinal_position;
IF func_arg_2 = '_typmod' THEN
-- src/datatype/casts.rs:10
-- vectors::datatype::casts::_vectors_cast_array_to_vecf32
CREATE OR REPLACE FUNCTION "_vectors_cast_array_to_vecf32"(
"array" real[], /* pgrx::datum::array::Array<f32> */
"_typmod" INT, /* i32 */
"_explicit" bool /* bool */
) RETURNS vector /* vectors::datatype::memory_vecf32::Vecf32Output */
IMMUTABLE STRICT PARALLEL SAFE
LANGUAGE c /* Rust */
AS 'MODULE_PATHNAME', '_vectors_cast_array_to_vecf32_wrapper';
ELSE
-- src/datatype/casts.rs:10
-- vectors::datatype::casts::_vectors_cast_array_to_vecf32
CREATE OR REPLACE FUNCTION "_vectors_cast_array_to_vecf32"(
"array" real[], /* pgrx::datum::array::Array<f32> */
"typmod" INT, /* i32 */
"_explicit" bool /* bool */
) RETURNS vector /* vectors::datatype::memory_vecf32::Vecf32Output */
IMMUTABLE STRICT PARALLEL SAFE
LANGUAGE c /* Rust */
AS 'MODULE_PATHNAME', '_vectors_cast_array_to_vecf32_wrapper';
END IF;
END $$;

-- src/datatype/subscript_bvector.rs:10
-- vectors::datatype::subscript_bvector::_vectors_bvector_subscript
Expand Down Expand Up @@ -1239,10 +1263,10 @@ DROP FUNCTION _vectors_bvecf32_operator_cosine;
DO $$
DECLARE
depcount_veci8 INT;
depcount_in INT;
depcount_out INT;
depcount_recv INT;
depcount_send INT;
depcount_in INT;
depcount_out INT;
depcount_recv INT;
depcount_send INT;
BEGIN
SELECT COUNT(*) INTO depcount_veci8 FROM pg_depend d WHERE d.refobjid = 'vectors.veci8'::regtype;
SELECT COUNT(*) INTO depcount_in FROM pg_depend d WHERE d.refobjid = 'vectors._vectors_veci8_in(cstring,oid,integer)'::regprocedure;
Expand Down

0 comments on commit 06e1c76

Please sign in to comment.