another test
[cparser] / type.h
diff --git a/type.h b/type.h
index 2cd6c28..e9fcb5e 100644 (file)
--- a/type.h
+++ b/type.h
@@ -45,17 +45,6 @@ typedef enum {
        ATOMIC_TYPE_DOUBLE,
        ATOMIC_TYPE_LONG_DOUBLE,
        ATOMIC_TYPE_BOOL,
-       /* microsoft extensions */
-       ATOMIC_TYPE_INT8,
-       ATOMIC_TYPE_INT16,
-       ATOMIC_TYPE_INT32,
-       ATOMIC_TYPE_INT64,
-       ATOMIC_TYPE_INT128,
-       ATOMIC_TYPE_UINT8,
-       ATOMIC_TYPE_UINT16,
-       ATOMIC_TYPE_UINT32,
-       ATOMIC_TYPE_UINT64,
-       ATOMIC_TYPE_UINT128,
 
        ATOMIC_TYPE_FLOAT_COMPLEX,
        ATOMIC_TYPE_DOUBLE_COMPLEX,
@@ -67,6 +56,15 @@ typedef enum {
        ATOMIC_TYPE_LAST = ATOMIC_TYPE_LONG_DOUBLE_IMAGINARY
 } atomic_type_kind_t;
 
+typedef enum {
+       ATOMIC_TYPE_FLAG_NONE       = 0,
+       ATOMIC_TYPE_FLAG_SIGNED     = 1 << 0,
+       ATOMIC_TYPE_FLAG_INTEGER    = 1 << 1,
+       ATOMIC_TYPE_FLAG_FLOAT      = 1 << 2,
+       ATOMIC_TYPE_FLAG_ARITHMETIC = 1 << 3,
+       ATOMIC_TYPE_FLAG_COMPLEX    = 1 << 4,
+} atomic_type_flag_t;
+
 typedef struct type_base_t           type_base_t;
 typedef struct atomic_type_t         atomic_type_t;
 typedef struct pointer_type_t        pointer_type_t;
@@ -153,6 +151,24 @@ unsigned get_atomic_type_size(atomic_type_kind_t kind);
 /**
  * returns alignment of an atomic type kind in bytes
  */
-unsigned get_atomic_type_align(atomic_type_kind_t kind);
+unsigned get_atomic_type_alignment(atomic_type_kind_t kind);
+
+/**
+ * returns flags of an atomic type kind
+ */
+unsigned get_atomic_type_flags(atomic_type_kind_t kind);
+
+atomic_type_kind_t get_intptr_kind(void);
+atomic_type_kind_t get_uintptr_kind(void);
+
+/**
+ * Find the atomic type kind representing a given size (signed).
+ */
+atomic_type_kind_t find_signed_int_atomic_type_kind_for_size(unsigned size);
+
+/**
+ * Find the atomic type kind representing a given size (unsigned).
+ */
+atomic_type_kind_t find_unsigned_int_atomic_type_kind_for_size(unsigned size);
 
 #endif