Log In | Get Help   
Home My Page Projects Code Snippets Project Openings Mareframe
Summary Activity Forums Tracker Lists Tasks Docs Surveys News SCM Files
[mareframe] View of /trunk/gadget/modelvariablevector.cc
[mareframe] / trunk / gadget / modelvariablevector.cc Repository:
ViewVC logotype

View of /trunk/gadget/modelvariablevector.cc

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1 - (download) (annotate)
Mon Feb 10 17:09:07 2014 UTC (10 years, 4 months ago) by agomez
File size: 1640 byte(s)
Initial version based on Gadget 2.2.00
#include "modelvariablevector.h"
#include "keeper.h"
#include "commentstream.h"
#include "gadget.h"

void ModelVariableVector::setsize(int sz) {
  size = (sz > 0 ? sz : 0);
  if (v != 0) {
    delete[] v;
    v = 0;
  }
  if (size > 0)
    v = new ModelVariable[size];
  else
    v = 0;
}

void ModelVariableVector::resize(int addsize, Keeper* const keeper) {
  if (addsize <= 0)
    return;
  int i;
  if (v == 0) {
    size = addsize;
    v = new ModelVariable[size];
  } else {
    ModelVariable* vnew = new ModelVariable[addsize + size];
    for (i = 0; i < size; i++)
      v[i].Interchange(vnew[i], keeper);
    delete[] v;
    v = vnew;
    size += addsize;
  }
}

ModelVariableVector::~ModelVariableVector() {
  if (v != 0) {
    delete[] v;
    v = 0;
  }
}

void ModelVariableVector::resize(const ModelVariable& mvar, Keeper* const keeper) {
  int i;
  if (v == 0) {
    v = new ModelVariable[1];
  } else {
    ModelVariable* vnew = new ModelVariable[size + 1];
    for (i = 0; i < size; i++)
      v[i].Interchange(vnew[i], keeper);
    delete[] v;
    v = vnew;
  }
  mvar.Interchange(v[size], keeper);
  size++;
}

int ModelVariableVector::didChange(const TimeClass* const TimeInfo) const {
  int i;
  for (i = 0; i < size; i++)
    if (v[i].didChange(TimeInfo))
      return 1;

  return 0;
}

void ModelVariableVector::Update(const TimeClass* const TimeInfo) {
  int i;
  for (i = 0; i < size; i++)
    v[i].Update(TimeInfo);
}

void ModelVariableVector::read(CommentStream& infile,
  const TimeClass* const TimeInfo, Keeper* const keeper) {

  int i;
  for (i = 0; i < size; i++)
    v[i].read(infile, TimeInfo, keeper);
}

root@forge.cesga.es
ViewVC Help
Powered by ViewVC 1.0.0  

Powered By FusionForge