/***********************************************************************
*
*       ELMER, A Computational Fluid Dynamics Program.
*
*       Copyright 1st April 1995 - , Center for Scientific Computing,
*                                    Finland.
*
*       All rights reserved. No part of this program may be used,
*       reproduced or transmitted in any form or by any means
*       without the written permission of CSC.
*
*                Address: Center for Scientific Computing
*                         Tietotie 6, P.O. BOX 405
*                         02101 Espoo, Finland
*                         Tel.     +358 0 457 2001
*                         Telefax: +358 0 457 2302
*                         EMail:   Jari.Jarvinen@csc.fi
************************************************************************/
 
/***********************************************************************
Program:    ELMER Front 
Module:     ecif_calculator.cpp
Language:   C++
Date:       24.01.01
Version:    1.00
Author(s):  Martti Verho
Revisions:  

Abstract:   Implementation

************************************************************************/

#include "ecif_model.h"
#include "ecif_parameterField.h"
#include "ecif_calculator.h"
#include "ecif_userinterface.h"

//Initialize static class variables.
int Calculator::last_id = 0;
Model* Calculator::model = NULL;


// Constructors
Calculator::Calculator()
{
}


Calculator::Calculator(int pid) : Parameter(pid)
{
}


Calculator::Calculator(int pid, char* data_string, char* param_name)
{
  setData(pid, data_string, param_name);
}


void
Calculator::initClass(Model* mdl)
{
  Calculator::model = mdl;
  Calculator::last_id = 0;
}


// Calculator section  specific output-method for Solver input file
ostream&
Calculator::output_sif(ostream& out, short indent_size, short indent_level, SifOutputControl& soc)
{
  UserInterface* gui = (UserInterface*)model->getGui();

  static char gui_value_buffer[1025];
  static char value_buffer[1025];
  static char variable_buffer[1025];

  char QM = '\"';

  ParameterField* order_fld = getFieldBySifName("Solving Order");
  
  // Parameter type and order number as the id!
  if (soc.outputType) {

    LibFront::output_string(out, indent_size, indent_level++, getSifName(), false);
    
    out << ' ';
    
    // Solving order as id!
    if (soc.outputId) {
      if (order_fld != NULL)
        out << order_fld->getDataStrings()[0];
      else
        out << id;
    }

    out << endl;

  } else {
    indent_level++;
  }

  char* fld_name;

  // Fields
  for (short i = 0; i < nofFields; i++) {

    ParameterField* pf = fields[i];
    char* fld_name = (char*)fields[i]->getSifName();

    // Check that field exists and it should be output
    if ( !pf->isActiveInstance() ||
         pf->getNofDataStrings() == 0 ||
         ( !soc.outputAll && !pf->isSifOutputField() )
       )
      continue;

    // We don't output SOLVING_ORDER field (it is used as the id!)
    if ( LibFront::in(fld_name, "Solving Order") ) {
      continue;
    }

    pf->output_sif(out, indent_size, indent_level, soc.sectionName);

  }

  return out;
}


void
Calculator::setName(char* param_name)
{
  Parameter::setName(param_name, "Calculator");
}


syntax highlighted by Code2HTML, v. 0.9.1