summaryrefslogtreecommitdiffstats
path: root/src/os_mac.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-10 20:09:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-10 20:09:20 +0000
commit029f72b1a93430b24b88eb3a72c6114d9f149737 (patch)
tree765d5c2041967f9c6fef195fe343d9234a030e90 /src/os_mac.h
parentInitial commit. (diff)
downloadvim-029f72b1a93430b24b88eb3a72c6114d9f149737.tar.xz
vim-029f72b1a93430b24b88eb3a72c6114d9f149737.zip
Adding upstream version 2:9.1.0016.upstream/2%9.1.0016
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/os_mac.h')
-rw-r--r--src/os_mac.h299
1 files changed, 299 insertions, 0 deletions
diff --git a/src/os_mac.h b/src/os_mac.h
new file mode 100644
index 0000000..34fe1f1
--- /dev/null
+++ b/src/os_mac.h
@@ -0,0 +1,299 @@
+/* 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.
+ */
+
+#ifndef OS_MAC__H
+#define OS_MAC__H
+
+// Before Including the MacOS specific files,
+// let's set the OPAQUE_TOOLBOX_STRUCTS to 0 so we
+// can access the internal structures.
+// (Until fully Carbon compliant)
+// TODO: Can we remove this? (Dany)
+#if 0
+# define OPAQUE_TOOLBOX_STRUCTS 0
+#endif
+
+// Include MAC_OS_X_VERSION_* macros
+#ifdef HAVE_AVAILABILITYMACROS_H
+# include <AvailabilityMacros.h>
+#endif
+
+/*
+ * Unix interface
+ */
+#if defined(__APPLE_CC__) // for Project Builder and ...
+# include <unistd.h>
+// Get stat.h or something similar. Comment: How come some OS get in vim.h
+# include <sys/stat.h>
+// && defined(HAVE_CURSE)
+// The curses.h from MacOS X provides by default some BACKWARD compatibility
+// definition which can cause us problem later on. So we undefine a few of them.
+# include <curses.h>
+# undef reg
+# undef ospeed
+// OK defined to 0 in MacOS X 10.2 curses! Remove it, we define it to be 1.
+# undef OK
+#endif
+#include <signal.h>
+#include <errno.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <time.h>
+#include <dirent.h>
+
+/*
+ * MacOS specific #define
+ */
+
+// This will go away when CMD_KEY fully tested
+#define USE_CMD_KEY
+// On MacOS X use the / not the :
+// TODO: Should file such as ~/.vimrc reside instead in
+// ~/Library/Vim or ~/Library/Preferences/org.vim.vim/ ? (Dany)
+// When compiled under MacOS X (including CARBON version)
+// we use the Unix File path style. Also when UNIX is defined.
+#define USE_UNIXFILENAME
+
+
+/*
+ * Generic Vim #define for Mac
+ */
+
+#define FEAT_SOURCE_FFS
+#define FEAT_SOURCE_FF_MAC
+
+#define USE_EXE_NAME // to find $VIM
+#define CASE_INSENSITIVE_FILENAME // ignore case when comparing file names
+#define SPACE_IN_FILENAME
+
+#define USE_FNAME_CASE // make ":e os_Mac.c" open the file in its
+ // original case, as "os_mac.c"
+#define BINARY_FILE_IO
+#define EOL_DEFAULT EOL_MAC
+#define HAVE_AVAIL_MEM
+
+#ifndef HAVE_CONFIG_H
+# define HAVE_STRING_H
+# define HAVE_STRCSPN
+# define HAVE_MEMSET
+# define USE_TMPNAM // use tmpnam() instead of mktemp()
+# define HAVE_FCNTL_H
+# define HAVE_QSORT
+# define HAVE_ST_MODE // have stat.st_mode
+# define HAVE_MATH_H
+
+# if defined(__DATE__) && defined(__TIME__)
+# define HAVE_DATE_TIME
+# endif
+# define HAVE_STRFTIME
+#endif
+
+/*
+ * Names for the EXRC, HELP and temporary files.
+ * Some of these may have been defined in the makefile.
+ */
+
+#ifndef SYS_VIMRC_FILE
+# define SYS_VIMRC_FILE "$VIM/vimrc"
+#endif
+#ifndef SYS_GVIMRC_FILE
+# define SYS_GVIMRC_FILE "$VIM/gvimrc"
+#endif
+#ifndef SYS_MENU_FILE
+# define SYS_MENU_FILE "$VIMRUNTIME/menu.vim"
+#endif
+#ifndef SYS_OPTWIN_FILE
+# define SYS_OPTWIN_FILE "$VIMRUNTIME/optwin.vim"
+#endif
+#ifndef VIM_DEFAULTS_FILE
+# define VIM_DEFAULTS_FILE "$VIMRUNTIME/defaults.vim"
+#endif
+#ifndef EVIM_FILE
+# define EVIM_FILE "$VIMRUNTIME/evim.vim"
+#endif
+
+#ifdef FEAT_GUI
+# ifndef USR_GVIMRC_FILE
+# define USR_GVIMRC_FILE "~/.gvimrc"
+# endif
+# ifndef GVIMRC_FILE
+# define GVIMRC_FILE "_gvimrc"
+# endif
+#endif
+#ifndef USR_VIMRC_FILE
+# define USR_VIMRC_FILE "~/.vimrc"
+#endif
+
+#ifndef USR_EXRC_FILE
+# define USR_EXRC_FILE "~/.exrc"
+#endif
+
+#ifndef VIMRC_FILE
+# define VIMRC_FILE "_vimrc"
+#endif
+
+#ifndef EXRC_FILE
+# define EXRC_FILE "_exrc"
+#endif
+
+#ifndef DFLT_HELPFILE
+# define DFLT_HELPFILE "$VIMRUNTIME/doc/help.txt"
+#endif
+
+#ifndef SYNTAX_FNAME
+# define SYNTAX_FNAME "$VIMRUNTIME/syntax/%s.vim"
+#endif
+
+#ifdef FEAT_VIMINFO
+# ifndef VIMINFO_FILE
+# define VIMINFO_FILE "~/.viminfo"
+# endif
+#endif // FEAT_VIMINFO
+
+#ifndef DFLT_BDIR
+# define DFLT_BDIR "." // default for 'backupdir'
+#endif
+
+#ifndef DFLT_DIR
+# define DFLT_DIR "." // default for 'directory'
+#endif
+
+#ifndef DFLT_VDIR
+# define DFLT_VDIR "$VIM/vimfiles/view" // default for 'viewdir'
+#endif
+
+#define DFLT_ERRORFILE "errors.err"
+
+#ifndef DFLT_RUNTIMEPATH
+# define DFLT_RUNTIMEPATH "~/.vim,$VIM/vimfiles,$VIMRUNTIME,$VIM/vimfiles/after,~/.vim/after"
+#endif
+#ifndef CLEAN_RUNTIMEPATH
+# define CLEAN_RUNTIMEPATH "$VIM/vimfiles,$VIMRUNTIME,$VIM/vimfiles/after"
+#endif
+
+/*
+ * Macintosh has plenty of memory, use large buffers
+ */
+#define CMDBUFFSIZE 1024 // size of the command processing buffer
+
+#ifndef DFLT_MAXMEM
+# define DFLT_MAXMEM 512 // use up to 512 Kbyte for buffer
+#endif
+
+#ifndef DFLT_MAXMEMTOT
+# define DFLT_MAXMEMTOT 2048 // use up to 2048 Kbyte for Vim
+#endif
+
+#define WILDCHAR_LIST "*?[{`$"
+
+/**************/
+#define mch_rename(src, dst) rename(src, dst)
+#define mch_remove(x) unlink((char *)(x))
+#ifndef mch_getenv
+# if defined(__APPLE_CC__)
+# define mch_getenv(name) ((char_u *)getenv((char *)(name)))
+# define mch_setenv(name, val, x) setenv(name, val, x)
+# else
+ // vim_getenv() is in pty.c
+# define USE_VIMPTY_GETENV
+# define mch_getenv(x) vimpty_getenv(x)
+# define mch_setenv(name, val, x) setenv(name, val, x)
+# endif
+#endif
+
+#ifndef HAVE_CONFIG_H
+# ifdef __APPLE_CC__
+// Assuming compiling for MacOS X
+// Trying to take advantage of the prebinding
+# define HAVE_TGETENT
+# define OSPEED_EXTERN
+# define UP_BC_PC_EXTERN
+# endif
+#endif
+
+// Some "prep work" definition to be able to compile the MacOS X
+// version with os_unix.c instead of os_mac.c. Based on the result
+// of ./configure for console MacOS X.
+
+#ifndef SIGPROTOARG
+# define SIGPROTOARG (int)
+#endif
+#ifndef SIGDEFARG
+# define SIGDEFARG(s) (s) int s UNUSED;
+#endif
+#ifndef SIGDUMMYARG
+# define SIGDUMMYARG 0
+#endif
+#undef HAVE_AVAIL_MEM
+#ifndef HAVE_CONFIG_H
+//# define USE_SYSTEM // Output ship do debugger :(, but not compile
+# define HAVE_SYS_WAIT_H 1 // Attempt
+# define HAVE_TERMIOS_H 1
+# define SYS_SELECT_WITH_SYS_TIME 1
+# define HAVE_SELECT 1
+# define HAVE_SYS_SELECT_H 1
+# define HAVE_PUTENV
+# define HAVE_SETENV
+# define HAVE_RENAME
+#endif
+
+#if !defined(HAVE_CONFIG_H)
+# define HAVE_PUTENV
+#endif
+
+// A Mac constant causing big problem to syntax highlighting
+#define UNKNOWN_CREATOR '\?\?\?\?'
+
+#ifdef FEAT_RELTIME
+
+# include <dispatch/dispatch.h>
+
+# if !defined(MAC_OS_X_VERSION_10_12) \
+ || (MAC_OS_X_VERSION_MAX_ALLOWED < MAC_OS_X_VERSION_10_12)
+typedef int clockid_t;
+# endif
+# ifndef CLOCK_REALTIME
+# define CLOCK_REALTIME 0
+# endif
+# ifndef CLOCK_MONOTONIC
+# define CLOCK_MONOTONIC 1
+# endif
+
+struct itimerspec
+{
+ struct timespec it_interval; // timer period
+ struct timespec it_value; // initial expiration
+};
+
+struct sigevent;
+
+struct macos_timer
+{
+ dispatch_queue_t tim_queue;
+ dispatch_source_t tim_timer;
+ void (*tim_func)(union sigval);
+ void *tim_arg;
+};
+
+typedef struct macos_timer *timer_t;
+
+extern int timer_create(
+ clockid_t clockid,
+ struct sigevent *sevp,
+ timer_t *timerid);
+
+extern int timer_delete(timer_t timerid);
+
+extern int timer_settime(
+ timer_t timerid, int flags,
+ const struct itimerspec *new_value,
+ struct itimerspec *unused);
+
+#endif // FEAT_RELTIME
+
+#endif // OS_MAC__H