#include "UNKNOWN.h"



int Cd_graph::check_alternation_params(  )
{
  DEM_TRACE("Cd_graph","int Cd_graph::check_alternation_params()");
  int return_val =  1 ;

  this->check_alternation_params_( return_val );
  return return_val;
}
//  Cd_graph  = <adjacencies > Adjacency_Nlist 
//            [ <terminal_sets > Vertex_Comma_list  ] .
void Cd_graph::check_alternation_params_( int& return_val )
{
  DEM_TRACE("Cd_graph","void Cd_graph::check_alternation_params_(int& return_val)");
  // variables for carrying in and out

  // assignments for carrying in

  // prefix class wrappers
 cout << endl
                     << "Checking that every alternative of a parameterized"
                     << endl
                     << "\talternation class has to use all its formal"
                     << endl
                     << "\tparameters in the same order ..." << endl;
              

  // outgoing calls
  // construction edge prefix wrappers
  this->get_adjacencies()->check_alternation_params_( return_val );
  // construction edge suffix wrappers

  // suffix class wrappers

  // assignments for carrying out
}

//  Adjacency  = <source > Vertex 
//             [ <parameters > Vertex_Comma_list  ] 
//            <ns > Neighbors 
//            "." 
//            *l.
void Adjacency::check_alternation_params_( int& return_val )
{
  DEM_TRACE("Adjacency","void Adjacency::check_alternation_params_(int& return_val)");
  // variables for carrying in and out
  Vertex_Comma_list*  params =  this->get_parameters() ;

  // assignments for carrying in

  // prefix class wrappers

  // outgoing calls
  // construction edge prefix wrappers
  this->get_ns()->check_alternation_params_( return_val, params  );
  // construction edge suffix wrappers

  // suffix class wrappers

  // assignments for carrying out
}

//  Neighbors  : Neighbors_wc   |
//            Repetit_n 
//           *common* .
void Neighbors::check_alternation_params_( int& return_val, Vertex_Comma_list*  params )
{
  DEM_TRACE("Neighbors","void Neighbors::check_alternation_params_(int& return_val,Vertex_Comma_list*  params)");
#ifndef NOTRACE
   DemTrace demTraceEmptyMethod(__FILE__,__LINE__,"Neighbors",form(" at %s , ***  PREMATURELY TERMINATED *** ", this->get_type()));
#endif

}

//  Neighbors_wc  : Construct_ns   |
//               Alternat_ns 
//           *common* +
//                    <construct_ns > Any_vertex_List 
//                    -.
void Neighbors_wc::check_alternation_params_( int& return_val, Vertex_Comma_list*  params )
{
  DEM_TRACE("Neighbors_wc","void Neighbors_wc::check_alternation_params_(int& return_val,Vertex_Comma_list*  params)");
#ifndef NOTRACE
   DemTrace demTraceEmptyMethod(__FILE__,__LINE__,"Neighbors_wc",form(" at %s , ***  PREMATURELY TERMINATED *** ", this->get_type()));
#endif

}

//  Alternat_ns  = ":" 
//              +
//              <alternat_ns > Term_Bar_list 
//              -
//               [ <common > Common  ] .
void Alternat_ns::check_alternation_params_( int& return_val, Vertex_Comma_list*  params )
{
  DEM_TRACE("Alternat_ns","void Alternat_ns::check_alternation_params_(int& return_val,Vertex_Comma_list*  params)");
  // variables for carrying in and out

  // assignments for carrying in



  // prefix class wrappers

  // outgoing calls
  // construction edge prefix wrappers
  this->get_alternat_ns()->check_alternation_params_( return_val, params  );
  // construction edge suffix wrappers

  // suffix class wrappers

  // assignments for carrying out


}

//  Term  : Normal   |
//       CppTerm 
//           *common* <vertex > Vertex 
//                    <moduleRef > TermRef 
//                     [ <actual_parameters > Term_Comma_list  ] .
void Term::check_alternation_params_( int& return_val, Vertex_Comma_list*  params )
{
  DEM_TRACE("Term","void Term::check_alternation_params_(int& return_val,Vertex_Comma_list*  params)");
  // variables for carrying in and out

  // assignments for carrying in

  // prefix class wrappers
 int error_flag = 0;
                if ((params != NULL) && 
                    (this->get_actual_parameters() != NULL)) {
                  Term_list_iterator next_Term(*this->get_actual_parameters());
                  Term* each_Term;
                  Vertex_list_iterator next_Vertex(*params);
                  Vertex* each_Vertex;

                  while(1) {
                    each_Vertex = next_Vertex();
                    each_Term   = next_Term();
                    if ((each_Vertex != NULL) && (each_Term != NULL)) {
                      if (!each_Vertex->g_equal(each_Term->get_vertex())) {
                        error_flag = 1;
                        break;
                      }
                    }
                    else if ((each_Vertex != NULL) || (each_Term != NULL)) {
                      error_flag = 1;
                      break;
                    }
                    else break;
                  }
                }
                else if ((params != NULL) || 
                         (this->get_actual_parameters() != NULL)) 
                  error_flag = 1;

                if (error_flag) {
                      cout << "sem-check: error: on line "
                           << this->find_line_number()
                           << " parameters of '";
                      this->g_print();
                      cout << "' mismatch with its superclass's" << endl;
                      return_val = 0;
                }

              


  // suffix class wrappers

  // assignments for carrying out
}

//  Adjacency_Nlist  ~ Adjacency  { Adjacency  }. .
void Adjacency_Nlist::check_alternation_params_( int& return_val )
{
  DEM_TRACE("Adjacency_Nlist","void Adjacency_Nlist::check_alternation_params_(int& return_val)");
  // variables for carrying in and out

  // assignments for carrying in

  // prefix class wrappers

  // outgoing calls
  Adjacency_list_iterator	next_Adjacency(*this);
  Adjacency*		each_Adjacency;

  while ( each_Adjacency = next_Adjacency() )
  {
  // repetition edge prefix wrappers
    each_Adjacency->check_alternation_params_( return_val );
  // repetition edge suffix wrappers
  }

  // suffix class wrappers

  // assignments for carrying out
}

//  Term_Bar_list  ~ Term  { Term  }. .
void Term_Bar_list::check_alternation_params_( int& return_val, Vertex_Comma_list*  params )
{
  DEM_TRACE("Term_Bar_list","void Term_Bar_list::check_alternation_params_(int& return_val,Vertex_Comma_list*  params)");
  // variables for carrying in and out

  // assignments for carrying in

  // prefix class wrappers

  // outgoing calls
  Term_list_iterator	next_Term(*this);
  Term*		each_Term;

  while ( each_Term = next_Term() )
  {
  // repetition edge prefix wrappers
    each_Term->check_alternation_params_( return_val, params  );
  // repetition edge suffix wrappers
  }

  // suffix class wrappers

  // assignments for carrying out
}


