projects
/
cparser
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Use create_Const_from_bool() instead of duplicating it.
[cparser]
/
entity_t.h
diff --git
a/entity_t.h
b/entity_t.h
index
d6d3702
..
401b8b6
100644
(file)
--- a/
entity_t.h
+++ b/
entity_t.h
@@
-28,8
+28,7
@@
#include "builtins.h"
typedef enum {
#include "builtins.h"
typedef enum {
- ENTITY_INVALID,
- ENTITY_VARIABLE,
+ ENTITY_VARIABLE = 1,
ENTITY_COMPOUND_MEMBER,
ENTITY_PARAMETER,
ENTITY_FUNCTION,
ENTITY_COMPOUND_MEMBER,
ENTITY_PARAMETER,
ENTITY_FUNCTION,
@@
-46,8
+45,7
@@
typedef enum {
typedef unsigned char entity_kind_t;
typedef enum namespace_tag_t {
typedef unsigned char entity_kind_t;
typedef enum namespace_tag_t {
- NAMESPACE_INVALID,
- NAMESPACE_NORMAL,
+ NAMESPACE_NORMAL = 1,
NAMESPACE_TAG,
NAMESPACE_LABEL
} namespace_tag_t;
NAMESPACE_TAG,
NAMESPACE_LABEL
} namespace_tag_t;
@@
-95,6
+93,14
@@
typedef enum decl_modifier_t {
DM_WEAK = 1 << 27,
} decl_modifier_t;
DM_WEAK = 1 << 27,
} decl_modifier_t;
+typedef enum elf_visibility_tag_t {
+ ELF_VISIBILITY_DEFAULT,
+ ELF_VISIBILITY_HIDDEN,
+ ELF_VISIBILITY_INTERNAL,
+ ELF_VISIBILITY_PROTECTED,
+ ELF_VISIBILITY_ERROR
+} elf_visibility_tag_t;
+
/**
* A scope containing entities.
*/
/**
* A scope containing entities.
*/
@@
-202,6
+208,8
@@
struct compound_member_t {
declaration_t base;
il_size_t offset; /**< the offset of this member in the compound */
unsigned char bit_offset; /**< extra bit offset for bitfield members */
declaration_t base;
il_size_t offset; /**< the offset of this member in the compound */
unsigned char bit_offset; /**< extra bit offset for bitfield members */
+ unsigned char bit_size; /**< bitsize for bitfield members */
+ bool bitfield : 1; /**< member is (part of) a bitfield */
bool read : 1;
bool address_taken : 1; /**< Set if the address of this
declaration was taken. */
bool read : 1;
bool address_taken : 1; /**< Set if the address of this
declaration was taken. */
@@
-212,13
+220,14
@@
struct compound_member_t {
struct variable_t {
declaration_t base;
struct variable_t {
declaration_t base;
- bool thread_local : 1; /**< GCC __thread */
- bool restricta : 1;
- bool deprecated : 1;
- bool noalias : 1;
+ bool thread_local
: 1; /**< GCC __thread */
+ bool restricta
: 1;
+ bool deprecated
: 1;
+ bool noalias
: 1;
- bool address_taken : 1; /**< Set if the address of this declaration was taken. */
- bool read : 1;
+ bool address_taken : 1; /**< Set if the address of this declaration was taken. */
+ bool read : 1;
+ unsigned elf_visibility : 2;
initializer_t *initializer;
initializer_t *initializer;
@@
-244,10
+253,11
@@
struct parameter_t {
struct function_t {
declaration_t base;
struct function_t {
declaration_t base;
- bool is_inline : 1;
+ bool is_inline
: 1;
- bool need_closure : 1; /**< Inner function needs closure. */
- bool goto_to_outer : 1; /**< Inner function has goto to outer function. */
+ bool need_closure : 1; /**< Inner function needs closure. */
+ bool goto_to_outer : 1; /**< Inner function has goto to outer function. */
+ unsigned elf_visibility : 2;
builtin_kind_t btk;
scope_t parameters;
builtin_kind_t btk;
scope_t parameters;
@@
-255,16
+265,18
@@
struct function_t {
symbol_t *actual_name; /**< gnu extension __REDIRECT */
/* ast2firm info */
symbol_t *actual_name; /**< gnu extension __REDIRECT */
/* ast2firm info */
- ir_entity *irentity;
- ir_node *static_link; /**< if need_closure is set, the node
- representing the static link. */
+ union {
+ ir_builtin_kind firm_builtin_kind;
+ unsigned chk_arg_pos;
+ } b;
+ ir_entity *irentity;
+ ir_node *static_link; /**< if need_closure is set, the node
+ representing the static link. */
};
union entity_t {
entity_kind_t kind;
entity_base_t base;
};
union entity_t {
entity_kind_t kind;
entity_base_t base;
- compound_t structe;
- compound_t unione;
compound_t compound;
enum_t enume;
enum_value_t enum_value;
compound_t compound;
enum_t enume;
enum_value_t enum_value;
@@
-278,16
+290,16
@@
union entity_t {
compound_member_t compound_member;
};
compound_member_t compound_member;
};
-#define DECLARATION_KIND_CASES
\
-
case ENTITY_FUNCTION:
\
- case ENTITY_VARIABLE:
\
- case ENTITY_PARAMETER:
\
- case ENTITY_COMPOUND_MEMBER
:
+#define DECLARATION_KIND_CASES \
+
ENTITY_FUNCTION:
\
+ case ENTITY_VARIABLE: \
+ case ENTITY_PARAMETER: \
+ case ENTITY_COMPOUND_MEMBER
static inline bool is_declaration(const entity_t *entity)
{
switch(entity->kind) {
static inline bool is_declaration(const entity_t *entity)
{
switch(entity->kind) {
- DECLARATION_KIND_CASES
+ case DECLARATION_KIND_CASES:
return true;
default:
return false;
return true;
default:
return false;
@@
-296,6
+308,10
@@
static inline bool is_declaration(const entity_t *entity)
const char *get_entity_kind_name(entity_kind_t kind);
const char *get_entity_kind_name(entity_kind_t kind);
-entity_t *allocate_entity_zero(entity_kind_t kind);
+entity_t *allocate_entity_zero(entity_kind_t, entity_namespace_t, symbol_t*);
+
+elf_visibility_tag_t get_elf_visibility_from_string(const char *string);
+
+entity_t *skip_unnamed_bitfields(entity_t*);
#endif
#endif