X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=include%2Flibfirm%2Ffirm_common.h;h=6e3105382f07691d4090491330c53f4b4decced0;hb=1553e92153d3b718a7f5575dcbbe8abbffc579c0;hp=db88412719aa4ebce93ffdc824547145fda79b49;hpb=3646e58f46f85a17537e89483d6b0c279df4a4d2;p=libfirm diff --git a/include/libfirm/firm_common.h b/include/libfirm/firm_common.h index db8841271..6e3105382 100644 --- a/include/libfirm/firm_common.h +++ b/include/libfirm/firm_common.h @@ -27,57 +27,64 @@ #define FIRM_COMMON_FIRM_COMMON_H #include "firm_types.h" +#include "begin.h" /** * libFirm initialization parameters. + * @deprecated */ -struct _firm_parameter_t { - /** - * The size of this structure. init_firm() will only initialize - * this amount of data. This allows to add more fields to this structure - * without breaking compatibility to older source. - */ - unsigned int size; - - /** - * Statistic options. If statistic function where enabled, these - * flags configure it, see enum firmstat_options_t. - */ - unsigned enable_statistics; - - /** - * This function is called, whenever a local variable is - * used before definition. The function should insert a default value, - * and/or raise a compiler error/warning. Note that returning - * an Unknown is allowed here. - */ - uninitialized_local_variable_func_t *initialize_local_func; - - /** - * The interface functions for the type identification module. - * If not set, the default implementation with compare_strict() and - * firm_hash_name() will be used. - */ - type_identify_if_t *ti_if; - - /** - * The interface for the ident module. - * If not set, the default libFirm ident module (using hash sets). - */ - ident_if_t *id_if; - - /** - * The default calling convention. - */ - unsigned cc_mask; - - /** - * The debug info that should be used for "builtin" objects. - */ - dbg_info *builtin_dbg; +struct firm_parameter_t { + /** + * The size of this structure. init_firm() will only initialize + * this amount of data. This allows to add more fields to this structure + * without breaking compatibility to older source. + */ + unsigned int size; + + /** + * Statistic options. If statistic function where enabled, these + * flags configure it, see enum firmstat_options_t. + * @deprecated call firm_init_stat(options) instead + */ + unsigned enable_statistics; + + /** + * This function is called, whenever a local variable is + * used before definition. The function should insert a default value, + * and/or raise a compiler error/warning. Note that returning + * an Unknown is allowed here. + * @deprecated call ir_set_uninitialized_local_variable_func() instead + */ + uninitialized_local_variable_func_t *initialize_local_func; + + /** + * The interface functions for the type identification module. + * If not set, the default implementation with compare_strict() and + * firm_hash_name() will be used. + */ + type_identify_if_t *ti_if; + + /** + * dummy parameter + * (this used to hold an identifier module structure) + */ + void *id_if; + + /** + * dummy parameter + * (this used to hold a default calling convention, but this concept is no + * more. You should always set the calling convention manually after + * creating the method entity if you need something else) + */ + unsigned cc_mask; + + /** + * dummy (here was dbg_info *builtin_dbg before) + */ + void *dummy; }; -typedef struct _firm_parameter_t firm_parameter_t; +typedef struct firm_parameter_t firm_parameter_t; /** * Initialize the firm library. @@ -85,31 +92,34 @@ typedef struct _firm_parameter_t firm_parameter_t; * Initializes the firm library. Allocates default data structures. * Initializes configurable behavior of the library. * - * @param params A structure containing the parameters of the libFirm. - * - * The parameter struct may be NULL. In that case, the original FIRM behavior - * is conserved. + * @param params should be NULL (you can pass a structure containing + * initial parameters but this is deprecated) */ -void ir_init(const firm_parameter_t *params); +FIRM_API void ir_init(const firm_parameter_t *params); /** * Frees all memory occupied by the firm library. */ -void ir_finish(void); +FIRM_API void ir_finish(void); /** returns the libFirm major version number */ -unsigned ir_get_version_major(void); +FIRM_API unsigned ir_get_version_major(void); /** returns libFirm minor version number */ -unsigned ir_get_version_minor(void); +FIRM_API unsigned ir_get_version_minor(void); /** returns string describing libFirm revision */ -const char *ir_get_version_revision(void); +FIRM_API const char *ir_get_version_revision(void); /** returns string describing libFirm build */ -const char *ir_get_version_build(void); +FIRM_API const char *ir_get_version_build(void); -/** a list of firm kinds - @@@ not all datatypes are tagged yet. */ +/** + * a list of firm kinds + * Most important datastructures in firm contain a firm_kind field at the + * beginning so given void* pointer you can usually still guess the kind + * of thing the pointer points to. + * This is used in debug helper functions and printers. + */ typedef enum { k_BAD = 0, /**< An invalid firm node. */ k_entity, /**< An entity. */ @@ -136,12 +146,8 @@ typedef enum { * * @param firm_thing pointer representing a firm object */ -firm_kind get_kind(const void *firm_thing); - -/** Returns the kind of a thing as a string. */ -const char *print_firm_kind(void *firm_thing); +FIRM_API firm_kind get_kind(const void *firm_thing); -/** Print an identification of a firm thing. */ -void firm_identify_thing(void *X); +#include "end.h" #endif