source: src/SynTree/Constant.cc @ fa16264

ADTaaron-thesisarm-ehast-experimentalcleanup-dtorsdeferred_resndemanglerenumforall-pointer-decayjacob/cs343-translationjenkins-sandboxnew-astnew-ast-unique-exprnew-envno_listpersistent-indexerpthread-emulationqualifiedEnumresolv-newwith_gc
Last change on this file since fa16264 was a2dbad10, checked in by Thierry Delisle <tdelisle@…>, 7 years ago

Added compound statement constructor which takes in a statment list.
Added constant constructor for chars

  • Property mode set to 100644
File size: 2.7 KB
Line 
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//
7// Constant.cc --
8//
9// Author           : Richard C. Bilson
10// Created On       : Mon May 18 07:44:20 2015
11// Last Modified By : Andrew Beach
12// Last Modified On : Fri Jul 14 14:50:00 2017
13// Update Count     : 29
14//
15
16#include <cassert>   // for strict_dynamic_cast, assertf
17#include <iostream>  // for operator<<, ostream, basic_ostream
18#include <string>    // for to_string, string, char_traits, operator<<
19
20#include "Constant.h"
21#include "Type.h"    // for BasicType, Type, Type::Qualifiers, PointerType
22
23Constant::Constant( Type * type, std::string rep, unsigned long long val ) : type( type ), rep( rep ), val( val ) {}
24Constant::Constant( Type * type, std::string rep, double val ) : type( type ), rep( rep ), val( val ) {}
25
26Constant::Constant( const Constant &other ) : rep( other.rep ), val( other.val ) {
27        type = other.type->clone();
28}
29
30Constant::~Constant() { delete type; }
31
32Constant Constant::from_bool( bool b ) {
33        return Constant( new BasicType( Type::Qualifiers(), BasicType::Bool ), b ? "1" : "0" , (unsigned long long int)b );
34}
35
36Constant Constant::from_char( char c ) {
37        return Constant( new BasicType( Type::Qualifiers(), BasicType::Char ), std::to_string( c ), (unsigned long long int)c );
38}
39
40Constant Constant::from_int( int i ) {
41        return Constant( new BasicType( Type::Qualifiers(), BasicType::SignedInt ), std::to_string( i ), (unsigned long long int)i );
42}
43
44Constant Constant::from_ulong( unsigned long i ) {
45        return Constant( new BasicType( Type::Qualifiers(), BasicType::LongUnsignedInt ), std::to_string( i ), (unsigned long long int)i );
46}
47
48Constant Constant::from_double( double d ) {
49        return Constant( new BasicType( Type::Qualifiers(), BasicType::Double ), std::to_string( d ), d );
50}
51
52Constant Constant::null( Type * ptrtype ) {
53        if ( nullptr == ptrtype ) {
54                ptrtype = new PointerType(
55                        Type::Qualifiers(),
56                        new VoidType( Type::Qualifiers() )
57                        );
58        }
59
60        return Constant( ptrtype, "0", (unsigned long long int)0 );
61}
62
63unsigned long long Constant::get_ival() const {
64        assertf( strict_dynamic_cast<BasicType*>(type)->isInteger(), "Attempt to retrieve ival from non-integer constant." );
65        return val.ival;
66}
67
68double Constant::get_dval() const {
69        assertf( ! strict_dynamic_cast<BasicType*>(type)->isInteger(), "Attempt to retrieve dval from integer constant." );
70        return val.dval;
71}
72
73void Constant::print( std::ostream &os ) const {
74        os << "(" << rep << " " << val.ival;
75        if ( type ) {
76                os << ": ";
77                type->print( os );
78        } // if
79  os << ")";
80}
81
82// Local Variables: //
83// tab-width: 4 //
84// mode: c++ //
85// compile-command: "make install" //
86// End: //
Note: See TracBrowser for help on using the repository browser.