From aed8ce9da277f5ecffe968b324f242c41c3b752a Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 10:50:31 +0200 Subject: Adding upstream version 2:9.0.1378. Signed-off-by: Daniel Baumann --- src/proto/vim9type.pro | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 src/proto/vim9type.pro (limited to 'src/proto/vim9type.pro') diff --git a/src/proto/vim9type.pro b/src/proto/vim9type.pro new file mode 100644 index 0000000..d5e4d48 --- /dev/null +++ b/src/proto/vim9type.pro @@ -0,0 +1,38 @@ +/* vim9type.c */ +type_T *get_type_ptr(garray_T *type_gap); +type_T *copy_type(type_T *type, garray_T *type_gap); +void clear_type_list(garray_T *gap); +type_T *alloc_type(type_T *type); +void free_type(type_T *type); +void set_tv_type(typval_T *tv, type_T *type); +type_T *get_list_type(type_T *member_type, garray_T *type_gap); +type_T *get_dict_type(type_T *member_type, garray_T *type_gap); +type_T *alloc_func_type(type_T *ret_type, int argcount, garray_T *type_gap); +type_T *get_func_type(type_T *ret_type, int argcount, garray_T *type_gap); +int func_type_add_arg_types(type_T *functype, int argcount, garray_T *type_gap); +int type_any_or_unknown(type_T *type); +int need_convert_to_bool(type_T *type, typval_T *tv); +type_T *typval2type(typval_T *tv, int copyID, garray_T *type_gap, int flags); +int valid_declaration_type(type_T *type); +type_T *typval2type_vimvar(typval_T *tv, garray_T *type_gap); +int check_typval_arg_type(type_T *expected, typval_T *actual_tv, char *func_name, int arg_idx); +int check_typval_type(type_T *expected, typval_T *actual_tv, where_T where); +void arg_type_mismatch(type_T *expected, type_T *actual, int arg_idx); +void type_mismatch_where(type_T *expected, type_T *actual, where_T where); +int check_type(type_T *expected, type_T *actual, int give_msg, where_T where); +int check_type_maybe(type_T *expected, type_T *actual, int give_msg, where_T where); +int check_argument_types(type_T *type, typval_T *argvars, int argcount, typval_T *base_tv, char_u *name); +char_u *skip_type(char_u *start, int optional); +type_T *parse_type(char_u **arg, garray_T *type_gap, int give_error); +int equal_type(type_T *type1, type_T *type2, int flags); +void common_type(type_T *type1, type_T *type2, type_T **dest, garray_T *type_gap); +int push_type_stack(cctx_T *cctx, type_T *type); +int push_type_stack2(cctx_T *cctx, type_T *type, type_T *decl_type); +void set_type_on_stack(cctx_T *cctx, type_T *type, int offset); +type_T *get_type_on_stack(cctx_T *cctx, int offset); +type_T *get_decl_type_on_stack(cctx_T *cctx, int offset); +type_T *get_member_type_from_stack(int count, int skip, cctx_T *cctx); +char *vartype_name(vartype_T type); +char *type_name(type_T *type, char **tofree); +void f_typename(typval_T *argvars, typval_T *rettv); +/* vim: set ft=c : */ -- cgit v1.2.3