1 ///////////////////////////////////////////////////////////////////////////////
2 // BSD 3-Clause License
3 //
4 // Copyright (c) 2020, The Regents of the University of California
5 // All rights reserved.
6 //
7 // Redistribution and use in source and binary forms, with or without
8 // modification, are permitted provided that the following conditions are met:
9 //
10 // * Redistributions of source code must retain the above copyright notice, this
11 //   list of conditions and the following disclaimer.
12 //
13 // * Redistributions in binary form must reproduce the above copyright notice,
14 //   this list of conditions and the following disclaimer in the documentation
15 //   and/or other materials provided with the distribution.
16 //
17 // * Neither the name of the copyright holder nor the names of its
18 //   contributors may be used to endorse or promote products derived from
19 //   this software without specific prior written permission.
20 //
21 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
25 // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31 // POSSIBILITY OF SUCH DAMAGE.
32 
33 // Generator Code Begin Header
34 #pragma once
35 
36 #include "dbCore.h"
37 #include "odb.h"
38 
39 // User Code Begin Includes
40 #include <string>
41 // User Code End Includes
42 
43 namespace odb {
44 
45 class dbIStream;
46 class dbOStream;
47 class dbDiff;
48 class _dbDatabase;
49 // User Code Begin Classes
50 // User Code End Classes
51 
52 struct dbTechLayerEolKeepOutRuleFlags
53 {
54   bool class_valid_ : 1;
55   bool corner_only_ : 1;
56   bool except_within_ : 1;
57   uint spare_bits_ : 29;
58 };
59 // User Code Begin Structs
60 // User Code End Structs
61 
62 class _dbTechLayerEolKeepOutRule : public _dbObject
63 {
64  public:
65   // User Code Begin Enums
66   // User Code End Enums
67 
68   dbTechLayerEolKeepOutRuleFlags flags_;
69   int eol_width_;
70   int backward_ext_;
71   int forward_ext_;
72   int side_ext_;
73   int within_low_;
74   int within_high_;
75   std::string class_name_;
76 
77   // User Code Begin Fields
78   // User Code End Fields
79   _dbTechLayerEolKeepOutRule(_dbDatabase*, const _dbTechLayerEolKeepOutRule& r);
80   _dbTechLayerEolKeepOutRule(_dbDatabase*);
81   ~_dbTechLayerEolKeepOutRule();
82   bool operator==(const _dbTechLayerEolKeepOutRule& rhs) const;
83   bool operator!=(const _dbTechLayerEolKeepOutRule& rhs) const
84   {
85     return !operator==(rhs);
86   }
87   bool operator<(const _dbTechLayerEolKeepOutRule& rhs) const;
88   void differences(dbDiff& diff,
89                    const char* field,
90                    const _dbTechLayerEolKeepOutRule& rhs) const;
91   void out(dbDiff& diff, char side, const char* field) const;
92   // User Code Begin Methods
93   // User Code End Methods
94 };
95 dbIStream& operator>>(dbIStream& stream, _dbTechLayerEolKeepOutRule& obj);
96 dbOStream& operator<<(dbOStream& stream, const _dbTechLayerEolKeepOutRule& obj);
97 // User Code Begin General
98 // User Code End General
99 }  // namespace odb
100    // Generator Code End Header
101