X-Git-Url: https://ginac.de/ginac.git//ginac.git?a=blobdiff_plain;f=ginac%2Fex.h;h=861bf730de695ba023e3bd9979bf2ccad4533098;hb=aed514f534cc6b4438822c1fcf80c203a828a94c;hp=dd3cfe0530ae51f33e72db25bde99fac7760f2e2;hpb=fe3af74fb8c8af4c8ab008c4788a7755b602db08;p=ginac.git diff --git a/ginac/ex.h b/ginac/ex.h index dd3cfe05..861bf730 100644 --- a/ginac/ex.h +++ b/ginac/ex.h @@ -3,7 +3,7 @@ * Interface to GiNaC's light-weight expression handles. */ /* - * GiNaC Copyright (C) 1999-2019 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2022 Johannes Gutenberg University Mainz, Germany * * 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 @@ -43,7 +43,7 @@ namespace GiNaC { * of this class in every object file that makes use of our flyweights in * order to guarantee proper initialization. Hence we put it into this * file which is included by every relevant file anyways. This is modeled - * after section 27.4.2.1.6 of the C++ standard, where cout and friends are + * after section [ios::Init] of the C++ standard, where cout and friends are * set up. * * @see utils.cpp */ @@ -87,6 +87,8 @@ public: ex(unsigned int i); ex(long i); ex(unsigned long i); + ex(long long i); + ex(unsigned long long i); ex(double const d); /** Construct ex from string and a list of symbols. The input grammar is @@ -132,8 +134,8 @@ public: // operand access size_t nops() const { return bp->nops(); } ex op(size_t i) const { return bp->op(i); } - ex operator[](const ex & index) const { return (*bp)[index]; } - ex operator[](size_t i) const { return (*bp)[i]; } + ex operator[](const ex & index) const { return (const_cast(*bp))[index]; } + ex operator[](size_t i) const { return (const_cast(*bp))[i]; } ex & let_op(size_t i); ex & operator[](const ex & index); ex & operator[](size_t i); @@ -236,6 +238,8 @@ private: static basic & construct_from_uint(unsigned int i); static basic & construct_from_long(long i); static basic & construct_from_ulong(unsigned long i); + static basic & construct_from_longlong(long long i); + static basic & construct_from_ulonglong(unsigned long long i); static basic & construct_from_double(double d); static ptr construct_from_string_and_lst(const std::string &s, const ex &l); void makewriteable(); @@ -290,6 +294,18 @@ ex::ex(unsigned long i) : bp(construct_from_ulong(i)) GINAC_ASSERT(bp->flags & status_flags::dynallocated); } +inline +ex::ex(long long i) : bp(construct_from_longlong(i)) +{ + GINAC_ASSERT(bp->flags & status_flags::dynallocated); +} + +inline +ex::ex(unsigned long long i) : bp(construct_from_ulonglong(i)) +{ + GINAC_ASSERT(bp->flags & status_flags::dynallocated); +} + inline ex::ex(double const d) : bp(construct_from_double(d)) {