CreateBondsAttributes.h 7.14 KB
Newer Older
hrchilds's avatar
hrchilds committed
1 2
/*****************************************************************************
*
3
* Copyright (c) 2000 - 2014, Lawrence Livermore National Security, LLC
hrchilds's avatar
hrchilds committed
4
* Produced at the Lawrence Livermore National Laboratory
5
* LLNL-CODE-442911
hrchilds's avatar
hrchilds committed
6 7
* All rights reserved.
*
8
* This file is  part of VisIt. For  details, see https://visit.llnl.gov/.  The
hrchilds's avatar
hrchilds committed
9 10 11 12 13 14 15 16 17 18
* full copyright notice is contained in the file COPYRIGHT located at the root
* of the VisIt distribution or at http://www.llnl.gov/visit/copyright.html.
*
* Redistribution  and  use  in  source  and  binary  forms,  with  or  without
* modification, are permitted provided that the following conditions are met:
*
*  - Redistributions of  source code must  retain the above  copyright notice,
*    this list of conditions and the disclaimer below.
*  - Redistributions in binary form must reproduce the above copyright notice,
*    this  list of  conditions  and  the  disclaimer (as noted below)  in  the
19 20 21
*    documentation and/or other materials provided with the distribution.
*  - Neither the name of  the LLNS/LLNL nor the names of  its contributors may
*    be used to endorse or promote products derived from this software without
hrchilds's avatar
hrchilds committed
22 23 24 25 26
*    specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT  HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR  IMPLIED WARRANTIES, INCLUDING,  BUT NOT  LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND  FITNESS FOR A PARTICULAR  PURPOSE
27 28 29
* ARE  DISCLAIMED. IN  NO EVENT  SHALL LAWRENCE  LIVERMORE NATIONAL  SECURITY,
* LLC, THE  U.S.  DEPARTMENT OF  ENERGY  OR  CONTRIBUTORS BE  LIABLE  FOR  ANY
* DIRECT,  INDIRECT,   INCIDENTAL,   SPECIAL,   EXEMPLARY,  OR   CONSEQUENTIAL
hrchilds's avatar
hrchilds committed
30 31 32 33 34 35 36 37 38 39 40 41 42 43
* DAMAGES (INCLUDING, BUT NOT  LIMITED TO, PROCUREMENT OF  SUBSTITUTE GOODS OR
* SERVICES; LOSS OF  USE, DATA, OR PROFITS; OR  BUSINESS INTERRUPTION) HOWEVER
* CAUSED  AND  ON  ANY  THEORY  OF  LIABILITY,  WHETHER  IN  CONTRACT,  STRICT
* LIABILITY, OR TORT  (INCLUDING NEGLIGENCE OR OTHERWISE)  ARISING IN ANY  WAY
* OUT OF THE  USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
*****************************************************************************/

#ifndef CREATEBONDSATTRIBUTES_H
#define CREATEBONDSATTRIBUTES_H
#include <string>
#include <AttributeSubject.h>

44

hrchilds's avatar
hrchilds committed
45 46 47 48 49 50 51 52 53
// ****************************************************************************
// Class: CreateBondsAttributes
//
// Purpose:
//    Attributes for the CreateBondsOperator
//
// Notes:      Autogenerated by xml2atts.
//
// Programmer: xml2atts
54
// Creation:   omitted
hrchilds's avatar
hrchilds committed
55 56 57 58 59 60 61 62
//
// Modifications:
//   
// ****************************************************************************

class CreateBondsAttributes : public AttributeSubject
{
public:
63
    // These constructors are for objects of this class
hrchilds's avatar
hrchilds committed
64 65
    CreateBondsAttributes();
    CreateBondsAttributes(const CreateBondsAttributes &obj);
66 67 68 69 70
protected:
    // These constructors are for objects derived from this class
    CreateBondsAttributes(private_tmfs_t tmfs);
    CreateBondsAttributes(const CreateBondsAttributes &obj, private_tmfs_t tmfs);
public:
hrchilds's avatar
hrchilds committed
71 72 73 74 75
    virtual ~CreateBondsAttributes();

    virtual CreateBondsAttributes& operator = (const CreateBondsAttributes &obj);
    virtual bool operator == (const CreateBondsAttributes &obj) const;
    virtual bool operator != (const CreateBondsAttributes &obj) const;
76 77 78 79
private:
    void Init();
    void Copy(const CreateBondsAttributes &obj);
public:
hrchilds's avatar
hrchilds committed
80 81 82 83 84 85 86 87 88 89 90 91 92

    virtual const std::string TypeName() const;
    virtual bool CopyAttributes(const AttributeGroup *);
    virtual AttributeSubject *CreateCompatible(const std::string &) const;
    virtual AttributeSubject *NewInstance(bool) const;

    // Property selection methods
    virtual void SelectAll();
    void SelectElementVariable();
    void SelectAtomicNumber1();
    void SelectAtomicNumber2();
    void SelectMinDist();
    void SelectMaxDist();
93 94 95
    void SelectXVector();
    void SelectYVector();
    void SelectZVector();
hrchilds's avatar
hrchilds committed
96 97 98 99 100 101 102 103

    // Property setting methods
    void SetElementVariable(const std::string &elementVariable_);
    void SetAtomicNumber1(const intVector &atomicNumber1_);
    void SetAtomicNumber2(const intVector &atomicNumber2_);
    void SetMinDist(const doubleVector &minDist_);
    void SetMaxDist(const doubleVector &maxDist_);
    void SetMaxBondsClamp(int maxBondsClamp_);
104 105 106 107 108 109 110 111
    void SetAddPeriodicBonds(bool addPeriodicBonds_);
    void SetUseUnitCellVectors(bool useUnitCellVectors_);
    void SetPeriodicInX(bool periodicInX_);
    void SetPeriodicInY(bool periodicInY_);
    void SetPeriodicInZ(bool periodicInZ_);
    void SetXVector(const double *xVector_);
    void SetYVector(const double *yVector_);
    void SetZVector(const double *zVector_);
hrchilds's avatar
hrchilds committed
112 113 114 115 116 117 118 119 120 121 122 123 124

    // Property getting methods
    const std::string  &GetElementVariable() const;
          std::string  &GetElementVariable();
    const intVector    &GetAtomicNumber1() const;
          intVector    &GetAtomicNumber1();
    const intVector    &GetAtomicNumber2() const;
          intVector    &GetAtomicNumber2();
    const doubleVector &GetMinDist() const;
          doubleVector &GetMinDist();
    const doubleVector &GetMaxDist() const;
          doubleVector &GetMaxDist();
    int                GetMaxBondsClamp() const;
125 126 127 128 129 130 131 132 133 134 135
    bool               GetAddPeriodicBonds() const;
    bool               GetUseUnitCellVectors() const;
    bool               GetPeriodicInX() const;
    bool               GetPeriodicInY() const;
    bool               GetPeriodicInZ() const;
    const double       *GetXVector() const;
          double       *GetXVector();
    const double       *GetYVector() const;
          double       *GetYVector();
    const double       *GetZVector() const;
          double       *GetZVector();
hrchilds's avatar
hrchilds committed
136 137 138 139 140 141 142 143 144 145 146 147

    // Persistence methods
    virtual bool CreateNode(DataNode *node, bool completeSave, bool forceAdd);
    virtual void SetFromNode(DataNode *node);


    // Keyframing methods
    virtual std::string               GetFieldName(int index) const;
    virtual AttributeGroup::FieldType GetFieldType(int index) const;
    virtual std::string               GetFieldTypeName(int index) const;
    virtual bool                      FieldsEqual(int index, const AttributeGroup *rhs) const;

148 149 150 151 152 153 154 155

    // IDs that can be used to identify fields in case statements
    enum {
        ID_elementVariable = 0,
        ID_atomicNumber1,
        ID_atomicNumber2,
        ID_minDist,
        ID_maxDist,
156 157 158 159 160 161 162 163 164 165
        ID_maxBondsClamp,
        ID_addPeriodicBonds,
        ID_useUnitCellVectors,
        ID_periodicInX,
        ID_periodicInY,
        ID_periodicInZ,
        ID_xVector,
        ID_yVector,
        ID_zVector,
        ID__LAST
166 167
    };

hrchilds's avatar
hrchilds committed
168 169 170 171 172 173 174
private:
    std::string  elementVariable;
    intVector    atomicNumber1;
    intVector    atomicNumber2;
    doubleVector minDist;
    doubleVector maxDist;
    int          maxBondsClamp;
175 176 177 178 179 180 181 182
    bool         addPeriodicBonds;
    bool         useUnitCellVectors;
    bool         periodicInX;
    bool         periodicInY;
    bool         periodicInZ;
    double       xVector[3];
    double       yVector[3];
    double       zVector[3];
183 184 185

    // Static class format string for type map.
    static const char *TypeMapFormatString;
186
    static const private_tmfs_t TmfsStruct;
hrchilds's avatar
hrchilds committed
187
};
188
#define CREATEBONDSATTRIBUTES_TMFS "si*i*d*d*ibbbbbDDD"
hrchilds's avatar
hrchilds committed
189 190

#endif