2002-05-14 02:58:22 +04:00
|
|
|
#ifndef LIBTCC_H
|
|
|
|
#define LIBTCC_H
|
|
|
|
|
2009-04-18 15:17:38 +04:00
|
|
|
#ifdef LIBTCC_AS_DLL
|
|
|
|
#define LIBTCCAPI __declspec(dllexport)
|
|
|
|
#else
|
|
|
|
#define LIBTCCAPI
|
|
|
|
#endif
|
|
|
|
|
2003-04-27 00:51:42 +04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2002-05-14 02:58:22 +04:00
|
|
|
struct TCCState;
|
|
|
|
|
|
|
|
typedef struct TCCState TCCState;
|
|
|
|
|
|
|
|
/* create a new TCC compilation context */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI TCCState *tcc_new(void);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
|
|
|
/* free a TCC compilation context */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI void tcc_delete(TCCState *s);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
|
|
|
/* add debug information in the generated code */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI void tcc_enable_debug(TCCState *s);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2002-11-02 17:14:08 +03:00
|
|
|
/* set error/warning display callback */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI void tcc_set_error_func(TCCState *s, void *error_opaque,
|
2002-11-02 17:14:08 +03:00
|
|
|
void (*error_func)(void *opaque, const char *msg));
|
|
|
|
|
2003-04-27 00:51:42 +04:00
|
|
|
/* set/reset a warning */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_set_warning(TCCState *s, const char *warning_name, int value);
|
2003-04-27 00:51:42 +04:00
|
|
|
|
2010-04-05 23:21:58 +04:00
|
|
|
/* set linker option */
|
2010-04-06 00:56:33 +04:00
|
|
|
LIBTCCAPI const char * tcc_set_linker(TCCState *s, char *option, int multi);
|
2010-04-05 23:21:58 +04:00
|
|
|
|
2002-05-14 02:58:22 +04:00
|
|
|
/*****************************/
|
|
|
|
/* preprocessor */
|
|
|
|
|
|
|
|
/* add include path */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_add_include_path(TCCState *s, const char *pathname);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2002-08-18 17:24:03 +04:00
|
|
|
/* add in system include path */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_add_sysinclude_path(TCCState *s, const char *pathname);
|
2002-08-18 17:24:03 +04:00
|
|
|
|
2002-05-14 02:58:22 +04:00
|
|
|
/* define preprocessor symbol 'sym'. Can put optional value */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI void tcc_define_symbol(TCCState *s, const char *sym, const char *value);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
|
|
|
/* undefine preprocess symbol 'sym' */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI void tcc_undefine_symbol(TCCState *s, const char *sym);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
|
|
|
/*****************************/
|
|
|
|
/* compiling */
|
|
|
|
|
2002-07-25 02:12:38 +04:00
|
|
|
/* add a file (either a C file, dll, an object, a library or an ld
|
2002-11-02 17:14:08 +03:00
|
|
|
script). Return -1 if error. */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_add_file(TCCState *s, const char *filename);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2002-07-25 02:12:38 +04:00
|
|
|
/* compile a string containing a C source. Return non zero if
|
|
|
|
error. */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_compile_string(TCCState *s, const char *buf);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
|
|
|
/*****************************/
|
|
|
|
/* linking commands */
|
|
|
|
|
2002-08-18 17:24:03 +04:00
|
|
|
/* set output type. MUST BE CALLED before any compilation */
|
2002-07-25 02:12:38 +04:00
|
|
|
#define TCC_OUTPUT_MEMORY 0 /* output will be ran in memory (no
|
|
|
|
output file) (default) */
|
|
|
|
#define TCC_OUTPUT_EXE 1 /* executable file */
|
|
|
|
#define TCC_OUTPUT_DLL 2 /* dynamic library */
|
|
|
|
#define TCC_OUTPUT_OBJ 3 /* object file */
|
2006-10-16 23:44:00 +04:00
|
|
|
#define TCC_OUTPUT_PREPROCESS 4 /* preprocessed file (used internally) */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_set_output_type(TCCState *s, int output_type);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2004-10-24 02:49:08 +04:00
|
|
|
#define TCC_OUTPUT_FORMAT_ELF 0 /* default output format: ELF */
|
|
|
|
#define TCC_OUTPUT_FORMAT_BINARY 1 /* binary image output */
|
|
|
|
#define TCC_OUTPUT_FORMAT_COFF 2 /* COFF */
|
|
|
|
|
2002-07-25 02:12:38 +04:00
|
|
|
/* equivalent to -Lpath option */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_add_library_path(TCCState *s, const char *pathname);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2002-07-25 02:12:38 +04:00
|
|
|
/* the library name is the same as the argument of the '-l' option */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_add_library(TCCState *s, const char *libraryname);
|
2002-07-25 02:12:38 +04:00
|
|
|
|
|
|
|
/* add a symbol to the compiled program */
|
2010-01-14 22:56:04 +03:00
|
|
|
LIBTCCAPI int tcc_add_symbol(TCCState *s, const char *name, const void *val);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2002-11-02 17:14:08 +03:00
|
|
|
/* output an executable, library or object file. DO NOT call
|
|
|
|
tcc_relocate() before. */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_output_file(TCCState *s, const char *filename);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2002-11-02 17:14:08 +03:00
|
|
|
/* link and run main() function and return its value. DO NOT call
|
|
|
|
tcc_relocate() before. */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI int tcc_run(TCCState *s, int argc, char **argv);
|
2002-05-14 02:58:22 +04:00
|
|
|
|
2009-12-20 00:11:12 +03:00
|
|
|
/* Do all relocations (needed before using tcc_get_symbol())
|
|
|
|
Returns -1 on error. */
|
|
|
|
LIBTCCAPI int tcc_relocate(TCCState *s1);
|
2002-09-09 02:46:32 +04:00
|
|
|
|
2009-04-16 23:50:43 +04:00
|
|
|
/* return symbol value or NULL if not found */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI void *tcc_get_symbol(TCCState *s, const char *name);
|
2002-09-09 02:46:32 +04:00
|
|
|
|
2009-04-18 15:17:27 +04:00
|
|
|
/* set CONFIG_TCCDIR at runtime */
|
2009-04-18 15:17:38 +04:00
|
|
|
LIBTCCAPI void tcc_set_lib_path(TCCState *s, const char *path);
|
2009-04-18 15:17:27 +04:00
|
|
|
|
2010-06-20 19:49:58 +04:00
|
|
|
|
|
|
|
/*****************************/
|
|
|
|
/* Miscellaneous */
|
|
|
|
|
|
|
|
/* Get default target filename for this compilation */
|
|
|
|
LIBTCCAPI const char *tcc_default_target(TCCState *s);
|
|
|
|
|
tcc: Draft suppoprt for -MD/-MF options
In build systems, this is used to automatically collect target
dependencies, e.g.
---- 8< (hello.c) ----
#include "hello.h"
#include <stdio.h>
int main()
{
printf("Hello World!\n");
return 0;
}
$ tcc -MD -c hello.c # -> hello.o, hello.d
$ cat hello.d
hello.o : \
hello.c \
hello.h \
/usr/include/stdio.h \
/usr/include/features.h \
/usr/include/bits/predefs.h \
/usr/include/sys/cdefs.h \
/usr/include/bits/wordsize.h \
/usr/include/gnu/stubs.h \
/usr/include/bits/wordsize.h \
/usr/include/gnu/stubs-32.h \
/home/kirr/local/tcc/lib/tcc/include/stddef.h \
/usr/include/bits/types.h \
/usr/include/bits/wordsize.h \
/usr/include/bits/typesizes.h \
/usr/include/libio.h \
/usr/include/_G_config.h \
/usr/include/wchar.h \
/home/kirr/local/tcc/lib/tcc/include/stdarg.h \
/usr/include/bits/stdio_lim.h \
/usr/include/bits/sys_errlist.h \
NOTE: gcc supports -MD only for .c -> .o, but in tcc, we generate
dependencies for whatever action is being taken. E.g. for .c -> exe, the
result will be:
$ tcc -MD -o hello hello.c # -> hello, hello.d
hello: \
/usr/lib/crt1.o \
/usr/lib/crti.o \
hello.c \
hello.h \
/usr/include/stdio.h \
/usr/include/features.h \
/usr/include/bits/predefs.h \
/usr/include/sys/cdefs.h \
/usr/include/bits/wordsize.h \
/usr/include/gnu/stubs.h \
/usr/include/bits/wordsize.h \
/usr/include/gnu/stubs-32.h \
/home/kirr/local/tcc/lib/tcc/include/stddef.h \
/usr/include/bits/types.h \
/usr/include/bits/wordsize.h \
/usr/include/bits/typesizes.h \
/usr/include/libio.h \
/usr/include/_G_config.h \
/usr/include/wchar.h \
/home/kirr/local/tcc/lib/tcc/include/stdarg.h \
/usr/include/bits/stdio_lim.h \
/usr/include/bits/sys_errlist.h \
/usr/lib/libc.so \
/lib/libc.so.6 \
/usr/lib/ld-linux.so.2 \
/lib/ld-linux.so.2 \
/usr/lib/libc_nonshared.a \
/lib/libc.so.6 \
/usr/lib/libc_nonshared.a \
/home/kirr/local/tcc/lib/tcc/libtcc1.a \
/usr/lib/crtn.o \
So tcc dependency generator is a bit more clever than one used in gcc :)
Also, I've updated TODO and Changelog (in not-yet-released section).
v2:
(Taking inputs from grischka and me myself)
- put code to generate deps file into a function.
- used tcc_fileextension() instead of open-coding
- generate deps only when compilation/preprocessing was successful
v3:
- use pstrcpy instead of snprintf(buf, sizeof(buf), "%s", ...)
2010-06-20 20:08:12 +04:00
|
|
|
/* Generate make dependencies for target and store them into file
|
|
|
|
*
|
|
|
|
* !target - use default target name
|
|
|
|
* !filename - use (target.o -> target.d)
|
|
|
|
*/
|
|
|
|
LIBTCCAPI void tcc_gen_makedeps(TCCState *s, const char *target, const char *filename);
|
|
|
|
|
2003-04-27 00:51:42 +04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2002-05-14 02:58:22 +04:00
|
|
|
#endif
|