Reorder lisp.h to declare types before using them
commitf5b9c1e59653ac687806f6f84181fc3f5020e6ba
authorPaul Eggert <eggert@cs.ucla.edu>
Sun, 25 Dec 2016 17:17:02 +0000 (25 09:17 -0800)
committerPaul Eggert <eggert@cs.ucla.edu>
Sun, 25 Dec 2016 17:17:50 +0000 (25 09:17 -0800)
tree316a0b30906c467aed07e031d6108cba194a5636
parente5ef59b87da5c2ddfa22f7342efe29b3eea6ed97
Reorder lisp.h to declare types before using them

This puts basic functions for types to be after the corresponding
type definitions.  This is a more-common programming style in C,
and will make it easier to port Emacs to gcc
-fcheck-pointer-bounds, since the functions now have access to the
corresponding types' sizes.  This patch does not change the code;
it just moves declarations and definitions and removes
no-longer-needed forward declarations (Bug#25128).
* src/buffer.c, src/data.c, src/image.c:
Include process.h, for PROCESSP.
* src/buffer.h (BUFFERP, CHECK_BUFFER, XBUFFER):
* src/process.h (PROCESSP, CHECK_PROCESS, XPROCESS):
* src/termhooks.h (TERMINALP, XTERMINAL):
* src/window.h (WINDOWP, CHECK_WINDOW, XWINDOW):
* src/thread.h (THREADP, CHECK_THREAD, XTHREAD, MUTEXP, CHECK_MUTEX)
(XMUTEX, CONDVARP, CHECK_CONDVAR, XCONDVAR):
Move here from lisp.h.
* src/intervals.h: Include buffer.h, for BUFFERP.
Include lisp.h, for Lisp_Object.
* src/lisp.h: Reorder declarations and definitions as described
above.  Move thread includes to be later, so that they can use the
reordered definitions.  Move some symbols to other headers (noted
elsewhere).  Remove forward decls that are no longer needed.
* src/thread.h: Include systhread.h here, not in lisp.h,
since lisp.h itself does not need systhread.h.
src/buffer.c
src/buffer.h
src/data.c
src/image.c
src/intervals.h
src/lisp.h
src/process.h
src/termhooks.h
src/thread.h
src/window.h