/* * Copyright (c) 2013 Stephen Williams (steve@icarus.com) * Copyright CERN 2013 / Stephen Williams (steve@icarus.com) * * This source code is free software; you can redistribute it * and/or modify it in source code form 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ # include "vtype.h" bool VType::type_match(const VType*that) const { if(this == that) return true; if(const VTypeDef*tdef = dynamic_cast(that)) { if(type_match(tdef->peek_definition())) return true; } return false; } bool VTypeDef::type_match(const VType*that) const { if(VType::type_match(that)) return true; return type_->type_match(that); } bool VTypePrimitive::type_match(const VType*that) const { if(VType::type_match(that)) return true; if(const VTypePrimitive*prim = dynamic_cast(that)) { // TODO it is not always true, but works for many cases type_t that_type = prim->type(); return ((type_ == NATURAL || type_ == INTEGER) && (that_type == NATURAL || that_type == INTEGER)); } if(const VTypeRangeConst*range = dynamic_cast(that)) { if (type_ == INTEGER) return true; if (type_ == NATURAL && range->start() >= 0 && range->end() >= 0) return true; } return false; } bool VTypeArray::type_match(const VType*that) const { if(VType::type_match(that)) return true; // Check if both arrays are of the same size if(const VTypeArray*arr = dynamic_cast(that)) { if(!element_type()->type_match(arr->element_type())) return false; int this_width = get_width(NULL); int that_width = arr->get_width(NULL); // Either one of the sizes is undefined, or both are the same size if(this_width > 0 && that_width > 0 && this_width != that_width) return false; return true; } return false; } bool VTypeRange::type_match(const VType*that) const { if(VType::type_match(that)) return true; if(base_->type_match(that)) return true; return false; }