source: src/SynTree/Constant.cc@ ba70330

ADT arm-eh ast-experimental enum forall-pointer-decay jacob/cs343-translation new-ast-unique-expr pthread-emulation qualifiedEnum
Last change on this file since ba70330 was c36298d, checked in by Michael Brooks <mlbrooks@…>, 6 years ago

Fixed handling of "literals.cfa" string-detail test cases by simplifying constant analysis. Now a ConstantExpr is a minial passthrough from parser to code generator, with special-case analysis only for integer values. Awareness of how to build a string-constant type is back in ExpressionNode.cc; now, this knowlede is only needed there. AST conversion no longer specializes string-int-float constants; it just converts types and passes values through. Unused constant API features are removed, notably from-to-float and from-string.

  • Property mode set to 100644
File size: 2.3 KB
RevLine 
[0dd3a2f]1//
2// Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
[62423350]7// Constant.cc --
[0dd3a2f]8//
9// Author : Richard C. Bilson
10// Created On : Mon May 18 07:44:20 2015
[aac99da]11// Last Modified By : Peter A. Buhr
[e15853c]12// Last Modified On : Wed Feb 13 18:11:22 2019
13// Update Count : 32
[0dd3a2f]14//
15
[e3e16bc]16#include <cassert> // for strict_dynamic_cast, assertf
[ea6332d]17#include <iostream> // for operator<<, ostream, basic_ostream
18#include <string> // for to_string, string, char_traits, operator<<
[51b73452]19
20#include "Constant.h"
[6c89ecc]21#include "Expression.h" // for ConstantExpr
[ea6332d]22#include "Type.h" // for BasicType, Type, Type::Qualifiers, PointerType
[51b73452]23
[c36298d]24Constant::Constant( Type * type, std::string rep, std::optional<unsigned long long> ival ) : type( type ), rep( rep ), ival( ival ) {}
[51b73452]25
[c36298d]26Constant::Constant( const Constant &other ) : BaseSyntaxNode( other ), rep( other.rep ), ival( other.ival ) {
[7f5566b]27 type = other.type->clone();
28}
29
30Constant::~Constant() { delete type; }
[51b73452]31
[2c37f34]32Constant Constant::from_bool( bool b ) {
[e15853c]33 return Constant( new BasicType( Type::Qualifiers(), BasicType::Bool ), b ? "1" : "0" , (unsigned long long int)b );
[2c37f34]34}
35
[cb4c607]36Constant Constant::from_int( int i ) {
[d56e5bc]37 return Constant( new BasicType( Type::Qualifiers(), BasicType::SignedInt ), std::to_string( i ), (unsigned long long int)i );
[9d7b3ea]38}
39
[cb4c607]40Constant Constant::from_ulong( unsigned long i ) {
[d56e5bc]41 return Constant( new BasicType( Type::Qualifiers(), BasicType::LongUnsignedInt ), std::to_string( i ), (unsigned long long int)i );
[9d7b3ea]42}
43
[6ea87486]44Constant Constant::null( Type * ptrtype ) {
45 if ( nullptr == ptrtype ) {
46 ptrtype = new PointerType(
47 Type::Qualifiers(),
48 new VoidType( Type::Qualifiers() )
49 );
50 }
51
52 return Constant( ptrtype, "0", (unsigned long long int)0 );
53}
54
[62423350]55unsigned long long Constant::get_ival() const {
[e3e16bc]56 assertf( strict_dynamic_cast<BasicType*>(type)->isInteger(), "Attempt to retrieve ival from non-integer constant." );
[c36298d]57 return ival.value();
[62423350]58}
59
[bb9d8e8]60void Constant::print( std::ostream &os, Indenter ) const {
[c36298d]61 os << "(" << rep << " " << (ival ? toString(ival.value()) : "") ;
[0dd3a2f]62 if ( type ) {
[ea9b9d3]63 os << ": ";
[0dd3a2f]64 type->print( os );
65 } // if
[ea9b9d3]66 os << ")";
[51b73452]67}
68
[0dd3a2f]69// Local Variables: //
70// tab-width: 4 //
71// mode: c++ //
72// compile-command: "make install" //
73// End: //
Note: See TracBrowser for help on using the repository browser.