X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Ftoken.h;h=e660a0cbb416af87cfaeef1452635a4a9eb1c5ce;hb=4368a446f8afc498138c9336b5d3cd86625f09ad;hp=fcf3f4e49f5b3ced600063831438944539db3cb3;hpb=2f5af21b263403997e154658635d6b6e6eaab453;p=m6w6%2Fext-psi diff --git a/src/token.h b/src/token.h index fcf3f4e..e660a0c 100644 --- a/src/token.h +++ b/src/token.h @@ -51,6 +51,52 @@ static inline size_t psi_offset_padding(size_t diff, size_t alignment) { typedef int token_t; +static inline int psi_num_exp_op_cmp(token_t op1, token_t op2) +{ + assert(!op1 || op1 == PSI_T_LPAREN || (op1 <= PSI_T_NOT && op1 >= PSI_T_PIPE)); + assert(!op2 || op2 == PSI_T_LPAREN || (op2 <= PSI_T_NOT && op2 >= PSI_T_PIPE)); + + if (PSI_T_LPAREN == op2) { + return -1; + } else if (PSI_T_LPAREN == op1) { + return 1; + } else if (op1 == op2) { + return 0; + } else if (!op1) { + return 1; + } else if (!op2) { + return -1; + } + + switch (op1) { + case PSI_T_PIPE: + return op2 > PSI_T_PIPE ? 1 : (op2 < PSI_T_PIPE ? -1 : 0); + case PSI_T_CARET: + return op2 > PSI_T_CARET ? 1 : (op2 < PSI_T_CARET ? -1 : 0); + case PSI_T_AMPERSAND: + return op2 > PSI_T_AMPERSAND ? 1 : (op2 < PSI_T_AMPERSAND ? -1 : 0); + + case PSI_T_LSHIFT: + case PSI_T_RSHIFT: + return op2 > PSI_T_RSHIFT ? 1 : (op2 < PSI_T_LSHIFT ? -1 : 0); + + case PSI_T_PLUS: + case PSI_T_MINUS: + return op2 > PSI_T_MINUS ? 1 : (op2 < PSI_T_PLUS ? -1 : 0); + + case PSI_T_ASTERISK: + case PSI_T_SLASH: + case PSI_T_MODULO: + return op2 > PSI_T_MODULO ? 1 : (op2 < PSI_T_ASTERISK ? -1 : 0); + + case PSI_T_NOT: + case PSI_T_TILDE: + return op2 > PSI_T_TILDE ? 1 : (op2 < PSI_T_NOT ? -1 : 0); + } + + return 0; +} + static inline size_t psi_t_alignment(token_t t) { #define PSI_ALIGNOF(T) case PSI_T_## T: return ALIGNOF_## T ##_T; @@ -94,13 +140,14 @@ static inline size_t psi_t_size(token_t t) return SIZEOF_FLOAT; case PSI_T_DOUBLE: return SIZEOF_DOUBLE; + case PSI_T_VOID: case PSI_T_POINTER: case PSI_T_FUNCTION: return SIZEOF_VOID_P; case PSI_T_ENUM: return SIZEOF_INT; default: - assert(0); + assert(!t); } return 0; } @@ -108,12 +155,12 @@ static inline size_t psi_t_size(token_t t) static inline const char *psi_t_indent(unsigned level) { static const char indent[] = "\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t"; - return &indent[32 - MAX(0, MIN(32, level))]; + return &indent[32 - MIN(32, level)]; } static inline const char *psi_t_indirection(unsigned pointer_level) { static const char indir[] = "********************************"; - return &indir[32 - MAX(0, MIN(32, pointer_level))]; + return &indir[32 - MIN(32, pointer_level)]; } struct psi_token {