summaryrefslogtreecommitdiffstats
path: root/src/proto.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 13:18:03 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 13:18:03 +0000
commitafce081b90c1e2c50c3507758c7558a0dfa1f33e (patch)
tree3fb840f0bd9de41b463443ddf17131a0ad77f226 /src/proto.h
parentInitial commit. (diff)
downloadvim-afce081b90c1e2c50c3507758c7558a0dfa1f33e.tar.xz
vim-afce081b90c1e2c50c3507758c7558a0dfa1f33e.zip
Adding upstream version 2:8.2.2434.upstream/2%8.2.2434upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/proto.h')
-rw-r--r--src/proto.h365
1 files changed, 365 insertions, 0 deletions
diff --git a/src/proto.h b/src/proto.h
new file mode 100644
index 0000000..686a3d6
--- /dev/null
+++ b/src/proto.h
@@ -0,0 +1,365 @@
+/* vi:set ts=8 sts=4 sw=4 noet:
+ *
+ * VIM - Vi IMproved by Bram Moolenaar
+ *
+ * Do ":help uganda" in Vim to read copying and usage conditions.
+ * Do ":help credits" in Vim to see a list of people who contributed.
+ */
+
+/*
+ * proto.h: include the (automatically generated) function prototypes
+ */
+
+/*
+ * Don't include these while generating prototypes. Prevents problems when
+ * files are missing.
+ */
+#if !defined(PROTO) && !defined(NOPROTO)
+
+/*
+ * Machine-dependent routines.
+ */
+// avoid errors in function prototypes
+# if !defined(FEAT_X11) && !defined(FEAT_GUI_GTK)
+# define Display int
+# define Widget int
+# endif
+# ifndef FEAT_GUI_GTK
+# define GdkEvent int
+# define GdkEventKey int
+# endif
+# ifndef FEAT_X11
+# define XImage int
+# endif
+
+# ifdef AMIGA
+# include "os_amiga.pro"
+# endif
+# if defined(UNIX) || defined(VMS)
+# include "os_unix.pro"
+# endif
+# ifdef MSWIN
+# include "os_win32.pro"
+# include "os_mswin.pro"
+# include "winclip.pro"
+# if (defined(__GNUC__) && !defined(__MINGW32__))
+extern int _stricoll(char *a, char *b);
+# endif
+# endif
+# ifdef VMS
+# include "os_vms.pro"
+# endif
+# ifdef __QNX__
+# include "os_qnx.pro"
+# endif
+
+# ifdef FEAT_CRYPT
+# include "blowfish.pro"
+# include "crypt.pro"
+# include "crypt_zip.pro"
+# endif
+# include "arglist.pro"
+# include "autocmd.pro"
+# include "buffer.pro"
+# include "bufwrite.pro"
+# include "change.pro"
+# include "charset.pro"
+# include "cindent.pro"
+# include "clientserver.pro"
+# include "clipboard.pro"
+# include "cmdexpand.pro"
+# include "cmdhist.pro"
+# include "if_cscope.pro"
+# include "debugger.pro"
+# include "dict.pro"
+# include "diff.pro"
+# include "digraph.pro"
+# include "drawline.pro"
+# include "drawscreen.pro"
+# include "edit.pro"
+# include "eval.pro"
+# include "evalbuffer.pro"
+# include "evalfunc.pro"
+# include "evalvars.pro"
+# include "evalwindow.pro"
+# include "ex_cmds.pro"
+# include "ex_cmds2.pro"
+# include "ex_docmd.pro"
+# include "ex_eval.pro"
+# include "ex_getln.pro"
+# include "fileio.pro"
+# include "filepath.pro"
+# include "findfile.pro"
+# include "fold.pro"
+# include "getchar.pro"
+# include "gui_xim.pro"
+# include "hardcopy.pro"
+# include "hashtab.pro"
+# include "help.pro"
+# include "highlight.pro"
+# include "indent.pro"
+# include "insexpand.pro"
+# include "json.pro"
+# include "list.pro"
+# include "locale.pro"
+# include "blob.pro"
+# include "main.pro"
+# include "map.pro"
+# include "mark.pro"
+# include "match.pro"
+# include "memfile.pro"
+# include "memline.pro"
+# ifdef FEAT_MENU
+# include "menu.pro"
+# endif
+# ifdef FEAT_ARABIC
+# include "arabic.pro"
+# endif
+# ifdef FEAT_VIMINFO
+# include "viminfo.pro"
+# endif
+
+// These prototypes cannot be produced automatically.
+int smsg(const char *, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 1, 2)))
+# endif
+ ;
+
+int smsg_attr(int, const char *, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 2, 3)))
+# endif
+ ;
+
+int smsg_attr_keep(int, const char *, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 2, 3)))
+# endif
+ ;
+
+// These prototypes cannot be produced automatically.
+int semsg(const char *, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 1, 2)))
+# endif
+ ;
+
+// These prototypes cannot be produced automatically.
+void siemsg(const char *, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 1, 2)))
+# endif
+ ;
+
+int vim_snprintf_add(char *, size_t, const char *, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 3, 4)))
+# endif
+ ;
+
+int vim_snprintf(char *, size_t, const char *, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 3, 4)))
+# endif
+ ;
+
+int vim_vsnprintf(char *str, size_t str_m, const char *fmt, va_list ap);
+int vim_vsnprintf_typval(char *str, size_t str_m, const char *fmt, va_list ap, typval_T *tvs);
+
+# include "message.pro"
+# include "misc1.pro"
+# include "misc2.pro"
+# ifndef HAVE_STRPBRK // not generated automatically from misc2.c
+char_u *vim_strpbrk(char_u *s, char_u *charset);
+# endif
+# ifndef HAVE_QSORT
+// Use our own qsort(), don't define the prototype when not used.
+void qsort(void *base, size_t elm_count, size_t elm_size, int (*cmp)(const void *, const void *));
+# endif
+# include "mouse.pro"
+# include "move.pro"
+# include "mbyte.pro"
+# ifdef VIMDLL
+// Function name differs when VIMDLL is defined
+int mbyte_im_get_status(void);
+void mbyte_im_set_active(int active_arg);
+# endif
+# include "normal.pro"
+# include "ops.pro"
+# include "option.pro"
+# include "optionstr.pro"
+# include "popupmenu.pro"
+# if defined(FEAT_PROFILE) || defined(FEAT_RELTIME)
+# include "profiler.pro"
+# endif
+# include "quickfix.pro"
+# include "regexp.pro"
+# include "register.pro"
+# include "scriptfile.pro"
+# include "screen.pro"
+# include "session.pro"
+# if defined(FEAT_CRYPT) || defined(FEAT_PERSISTENT_UNDO)
+# include "sha256.pro"
+# endif
+# include "search.pro"
+# ifdef FEAT_SIGNS
+# include "sign.pro"
+# endif
+# include "sound.pro"
+# include "spell.pro"
+# include "spellfile.pro"
+# include "spellsuggest.pro"
+# include "syntax.pro"
+# include "tag.pro"
+# include "term.pro"
+# ifdef FEAT_TERMINAL
+# include "terminal.pro"
+# endif
+# if defined(HAVE_TGETENT) && (defined(AMIGA) || defined(VMS))
+# include "termlib.pro"
+# endif
+# ifdef FEAT_PROP_POPUP
+# include "popupwin.pro"
+# include "textprop.pro"
+# endif
+# include "testing.pro"
+# include "textobject.pro"
+# include "textformat.pro"
+# include "time.pro"
+# include "typval.pro"
+# include "ui.pro"
+# include "undo.pro"
+# include "usercmd.pro"
+# include "userfunc.pro"
+# include "version.pro"
+# include "vim9script.pro"
+# ifdef FEAT_EVAL
+# include "vim9compile.pro"
+# include "vim9execute.pro"
+# include "vim9type.pro"
+# endif
+# include "window.pro"
+
+# ifdef FEAT_LUA
+# include "if_lua.pro"
+# endif
+
+# ifdef FEAT_MZSCHEME
+# include "if_mzsch.pro"
+# endif
+
+# ifdef FEAT_PYTHON
+# include "if_python.pro"
+# endif
+
+# ifdef FEAT_PYTHON3
+# include "if_python3.pro"
+# endif
+
+# ifdef FEAT_TCL
+# include "if_tcl.pro"
+# endif
+
+# ifdef FEAT_RUBY
+# include "if_ruby.pro"
+# endif
+
+// Ugly solution for "BalloonEval" not being defined while it's used in some
+// .pro files.
+# ifndef FEAT_BEVAL
+# define BalloonEval int
+# endif
+# if defined(FEAT_BEVAL) || defined(FEAT_PROP_POPUP)
+# include "beval.pro"
+# endif
+
+# ifdef FEAT_NETBEANS_INTG
+# include "netbeans.pro"
+# endif
+# ifdef FEAT_JOB_CHANNEL
+# include "job.pro"
+# include "channel.pro"
+
+// Not generated automatically, to add extra attribute.
+void ch_log(channel_T *ch, const char *fmt, ...)
+# ifdef USE_PRINTF_FORMAT_ATTRIBUTE
+ __attribute__((format(printf, 2, 3)))
+# endif
+ ;
+
+# endif
+
+# if defined(FEAT_GUI) || defined(FEAT_JOB_CHANNEL)
+# if defined(UNIX) || defined(MACOS_X) || defined(VMS)
+# include "pty.pro"
+# endif
+# endif
+
+# ifdef FEAT_GUI
+# include "gui.pro"
+# if !defined(HAVE_SETENV) && !defined(HAVE_PUTENV) && !defined(VMS)
+extern int putenv(const char *string); // in misc2.c
+# ifdef USE_VIMPTY_GETENV
+extern char_u *vimpty_getenv(const char_u *string); // in misc2.c
+# endif
+# endif
+# ifdef FEAT_GUI_MSWIN
+# include "gui_w32.pro"
+# endif
+# ifdef FEAT_GUI_GTK
+# include "gui_gtk.pro"
+# include "gui_gtk_x11.pro"
+# endif
+# ifdef FEAT_GUI_MOTIF
+# include "gui_motif.pro"
+# include "gui_xmdlg.pro"
+# endif
+# ifdef FEAT_GUI_ATHENA
+# include "gui_athena.pro"
+# ifdef FEAT_BROWSE
+extern char *vim_SelFile(Widget toplevel, char *prompt, char *init_path, int (*show_entry)(), int x, int y, guicolor_T fg, guicolor_T bg, guicolor_T scroll_fg, guicolor_T scroll_bg);
+# endif
+# endif
+# ifdef FEAT_GUI_HAIKU
+# include "gui_haiku.pro"
+# endif
+# ifdef FEAT_GUI_X11
+# include "gui_x11.pro"
+# endif
+# ifdef FEAT_GUI_PHOTON
+# include "gui_photon.pro"
+# endif
+# endif // FEAT_GUI
+
+# ifdef FEAT_OLE
+# include "if_ole.pro"
+# endif
+# if defined(FEAT_CLIENTSERVER) && defined(FEAT_X11)
+# include "if_xcmdsrv.pro"
+# endif
+
+/*
+ * The perl include files pollute the namespace, therefore proto.h must be
+ * included before the perl include files. But then CV is not defined, which
+ * is used in if_perl.pro. To get around this, the perl prototype files are
+ * not included here for the perl files. Use a dummy define for CV for the
+ * other files.
+ */
+# if defined(FEAT_PERL) && !defined(IN_PERL_FILE)
+# define CV void
+# include "if_perl.pro"
+# include "if_perlsfio.pro"
+# endif
+
+# ifdef MACOS_CONVERT
+# include "os_mac_conv.pro"
+# endif
+# if defined(MACOS_X_DARWIN) && defined(FEAT_CLIPBOARD) && !defined(FEAT_GUI)
+// functions in os_macosx.m
+void clip_mch_lose_selection(Clipboard_T *cbd);
+int clip_mch_own_selection(Clipboard_T *cbd);
+void clip_mch_request_selection(Clipboard_T *cbd);
+void clip_mch_set_selection(Clipboard_T *cbd);
+# endif
+#endif // !PROTO && !NOPROTO