// Copyright 2012, Matthias Andreas Benkard.
//
// 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 3 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, see
// .
#include "cells.hpp"
#include
#include
#include
struct unit { };
using namespace cells;
using std::cout;
using std::endl;
typedef formula_cell fcell;
typedef shared_ptr sfcell;
typedef formula_cell ucell;
typedef shared_ptr sucell;
int main(int argc, char** argv) {
sfcell x0 = fcell::make();
sfcell x1 = fcell::make();
sfcell x2 = fcell::make();
sfcell y = fcell::make();
sfcell z = fcell::make();
sucell a = ucell::make();
sucell b = ucell::make();
with_transaction([=](){
x0->reset(10);
x1->reset([=](){ return *x0 + 5; });
x2->reset([=](){ return *x0 * 2; });
y->reset([=](){ return *x1 * *x2; });
z->reset([=](){ return *x0 * *y; });
a->reset([=]() -> unit { cout << "z is now " << *z << "." << endl; return unit(); });
b->reset([=]() -> unit { cout << "x2 is now " << *x2 << "." << endl; return unit(); });
});
x0->reset(15);
x0->reset(-20);
y->reset(-3);
x1->reset([=]() { return (double)*x0; });
y->reset([=]() { return *x1 + *x2; });
return EXIT_SUCCESS;
}
/*
* z
* |\
* | \
* | \
* | \
* | \
* | \
* | \
* | y
* | /|
* | / |
* | / |
* | x1 x2
* | / |
* | / |
* x0------+
*/