blob: bf3e705cd26e4d93179cd99b31b80a56d9cccd2f [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2011 - 2013 ACIN, Profactor GmbH
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Monika Wenger, Alois Zoitl, Matthias Plasch, Gerhard Ebenhofer
* - initial API and implementation and/or initial documentation
*******************************************************************************/
#ifndef _F_LIMIT_H_
#define _F_LIMIT_H_
#include <funcbloc.h>
class FORTE_F_LIMIT : public CFunctionBlock{
DECLARE_FIRMWARE_FB(FORTE_F_LIMIT)
private:
static const CStringDictionary::TStringId scm_anDataInputNames[];
static const CStringDictionary::TStringId scm_anDataInputTypeIds[];
CIEC_ANY_ELEMENTARY &MN(){
return *static_cast<CIEC_ANY_ELEMENTARY*>(getDI(0));
}
;
CIEC_ANY_ELEMENTARY &st_IN(){
return *static_cast<CIEC_ANY_ELEMENTARY*>(getDI(1));
}
;
CIEC_ANY_ELEMENTARY &MX(){
return *static_cast<CIEC_ANY_ELEMENTARY*>(getDI(2));
}
;
static const CStringDictionary::TStringId scm_anDataOutputNames[];
static const CStringDictionary::TStringId scm_anDataOutputTypeIds[];
CIEC_ANY_ELEMENTARY &st_OUT(){
return *static_cast<CIEC_ANY_ELEMENTARY*>(getDO(0));
}
;
static const TEventID scm_nEventREQID = 0;
static const TForteInt16 scm_anEIWithIndexes[];
static const TDataIOID scm_anEIWith[];
static const CStringDictionary::TStringId scm_anEventInputNames[];
static const TEventID scm_nEventCNFID = 0;
static const TForteInt16 scm_anEOWithIndexes[];
static const TDataIOID scm_anEOWith[];
static const CStringDictionary::TStringId scm_anEventOutputNames[];
static const SFBInterfaceSpec scm_stFBInterfaceSpec;
FORTE_FB_DATA_ARRAY(1, 3, 1, 0)
;
void executeEvent(int pa_nEIID);
public:
FUNCTION_BLOCK_CTOR(FORTE_F_LIMIT){
};
template<typename T> void calculateValue(){
T oMin;
T oMax;
oMin.saveAssign(MN());
oMax.saveAssign(MX());
st_OUT().saveAssign(LIMIT<T> (oMin, static_cast<T &> (st_IN()), oMax));
}
template<typename T> void calculateValueString() const {
//TODO fill this function
}
virtual ~FORTE_F_LIMIT(){};
};
#endif //close the ifdef sequence from the beginning of the file