11#ifndef __Panzer_STK_ParameterListCallback_hpp__
12#define __Panzer_STK_ParameterListCallback_hpp__
14#include "PanzerAdaptersSTK_config.hpp"
15#ifdef PANZER_HAVE_TEKO
17#include "Teuchos_RCP.hpp"
18#include "Teuchos_ParameterList.hpp"
20#include "Teko_RequestCallback.hpp"
36class ParameterListCallback :
public Teko::RequestCallback<Teuchos::RCP<Teuchos::ParameterList> > {
38 ParameterListCallback(
const std::string & coordFieldName,
39 const std::map<std::string,Teuchos::RCP<const panzer::Intrepid2FieldPattern> > & fp,
40 const Teuchos::RCP<const panzer_stk::STKConnManager> & connManager,
41 const Teuchos::RCP<const panzer::GlobalIndexer> & ugi);
43 Teuchos::RCP<Teuchos::ParameterList> request(
const Teko::RequestMesg & rm);
45 bool handlesRequest(
const Teko::RequestMesg & rm);
47 void preRequest(
const Teko::RequestMesg & rm);
49 const std::vector<double> & getCoordsVector(
unsigned dim)
const
52 return getXCoordsVector();
54 return getYCoordsVector();
56 return getZCoordsVector();
58 TEUCHOS_ASSERT(
false);
60 TEUCHOS_ASSERT(
false);
63 const std::vector<double> & getXCoordsVector()
const {
return xcoords_; }
64 const std::vector<double> & getYCoordsVector()
const {
return ycoords_; }
65 const std::vector<double> & getZCoordsVector()
const {
return zcoords_; }
68 Teuchos::RCP<const panzer::ArrayToFieldVector> getArrayToFieldVector()
const
69 {
return arrayToVector_; }
71 void buildCoordinates();
72 void buildArrayToVector();
75 void storeExtraVector(
const Teuchos::RCP<
const std::vector<double> > & extra)
76 { extraVecs_.push_back(extra); }
80 void setFieldByKey(
const std::string & key,Teuchos::ParameterList & pl)
const;
82 std::string coordFieldName_;
83 std::map<std::string,Teuchos::RCP<const panzer::Intrepid2FieldPattern> > fieldPatterns_;
84 Teuchos::RCP<const panzer_stk::STKConnManager> connManager_;
85 Teuchos::RCP<const panzer::GlobalIndexer> ugi_;
86 bool coordinatesBuilt_;
88 std::vector<double> xcoords_;
89 std::vector<double> ycoords_;
90 std::vector<double> zcoords_;
92 mutable Teuchos::RCP<const panzer::ArrayToFieldVector> arrayToVector_;
93 std::vector<Teuchos::RCP<const std::vector<double> > > extraVecs_;