summaryrefslogtreecommitdiffstats
path: root/src/proto/vim9type.pro
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/proto/vim9type.pro38
1 files changed, 38 insertions, 0 deletions
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 : */