/*
* This file is part of cparser.
- * Copyright (C) 2007-2009 Matthias Braun <matze@braunis.de>
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2
- * of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
- * 02111-1307, USA.
+ * Copyright (C) 2012 Matthias Braun <matze@braunis.de>
*/
#include <config.h>
[TYPE_TYPEDEF] = sizeof(typedef_type_t),
[TYPE_TYPEOF] = sizeof(typeof_type_t),
};
- assert(lengthof(sizes) == (int)TYPE_TYPEOF + 1);
- assert(kind <= TYPE_TYPEOF);
+ assert((size_t)kind < lengthof(sizes));
assert(sizes[kind] != 0);
return sizes[kind];
}
const char *get_atomic_kind_name(atomic_type_kind_t kind)
{
- switch(kind) {
+ switch (kind) {
case ATOMIC_TYPE_VOID: return "void";
case ATOMIC_TYPE_WCHAR_T: return "wchar_t";
case ATOMIC_TYPE_BOOL: return c_mode & _CXX ? "bool" : "_Bool";
separator_t sep = { "", ", " };
if (parameters == NULL) {
function_parameter_t *parameter = type->parameters;
- for( ; parameter != NULL; parameter = parameter->next) {
+ for ( ; parameter != NULL; parameter = parameter->next) {
print_string(sep_next(&sep));
print_type(parameter->type);
}
change_indent(1);
entity_t *entry = enume->base.next;
- for( ; entry != NULL && entry->kind == ENTITY_ENUM_VALUE;
+ for ( ; entry != NULL && entry->kind == ENTITY_ENUM_VALUE;
entry = entry->base.next) {
print_indent();
change_indent(1);
entity_t *entity = compound->members.entities;
- for( ; entity != NULL; entity = entity->base.next) {
+ for ( ; entity != NULL; entity = entity->base.next) {
if (entity->kind != ENTITY_COMPOUND_MEMBER)
continue;
*/
static void intern_print_type_pre(const type_t *const type)
{
- switch(type->kind) {
+ switch (type->kind) {
case TYPE_ARRAY: print_array_type_pre( &type->array); return;
case TYPE_ATOMIC: print_atomic_type( &type->atomic); return;
case TYPE_COMPLEX: print_complex_type( &type->atomic); return;
*/
static void intern_print_type_post(const type_t *const type)
{
- switch(type->kind) {
+ switch (type->kind) {
case TYPE_FUNCTION:
print_function_type_post(&type->function, NULL);
return;
bool is_type_integer(const type_t *type)
{
assert(!is_typeref(type));
-
- if (type->kind == TYPE_ENUM)
- return true;
- if (type->kind != TYPE_ATOMIC)
+ if (!is_type_arithmetic(type))
return false;
-
return test_atomic_type_flag(type->atomic.akind, ATOMIC_TYPE_FLAG_INTEGER);
}
return test_atomic_type_flag(type->atomic.akind, ATOMIC_TYPE_FLAG_FLOAT);
}
-bool is_type_signed(const type_t *type)
+bool is_type_complex(const type_t *type)
{
assert(!is_typeref(type));
+ return type->kind == TYPE_COMPLEX;
+}
- /* enum types are int for now */
- if (type->kind == TYPE_ENUM)
- return true;
- if (type->kind != TYPE_ATOMIC)
+bool is_type_signed(const type_t *type)
+{
+ assert(!is_typeref(type));
+ if (!is_type_arithmetic(type))
return false;
-
return test_atomic_type_flag(type->atomic.akind, ATOMIC_TYPE_FLAG_SIGNED);
}
{
assert(!is_typeref(type));
- switch(type->kind) {
+ switch (type->kind) {
case TYPE_ENUM:
return true;
case TYPE_ATOMIC:
{
assert(!is_typeref(type));
- switch(type->kind) {
+ switch (type->kind) {
case TYPE_POINTER:
case TYPE_ENUM:
return true;
case TYPE_ATOMIC:
+ case TYPE_COMPLEX:
case TYPE_IMAGINARY:
return test_atomic_type_flag(type->atomic.akind, ATOMIC_TYPE_FLAG_ARITHMETIC);
default:
{
assert(!is_typeref(type));
- switch(type->kind) {
+ switch (type->kind) {
case TYPE_COMPOUND_STRUCT:
case TYPE_COMPOUND_UNION: {
const compound_type_t *compound_type = &type->compound;
decl_modifiers_t get_type_modifiers(const type_t *type)
{
- switch(type->kind) {
+ switch (type->kind) {
case TYPE_ERROR:
break;
case TYPE_COMPOUND_STRUCT: