|
9 | 9 | #include <memory> |
10 | 10 |
|
11 | 11 | #include "odb/db.h" |
| 12 | +#include "odb/dbShape.h" |
12 | 13 | #include "odb/dbWireCodec.h" |
13 | 14 | #include "odb/lefin.h" |
14 | 15 | #include "tst/fixture.h" |
@@ -36,6 +37,40 @@ class OdbMultiPatternedTest : public tst::Fixture |
36 | 37 | odb::dbBlock* block_; |
37 | 38 | }; |
38 | 39 |
|
| 40 | +TEST_F(OdbMultiPatternedTest, NdrWidth) |
| 41 | +{ |
| 42 | + dbTechLayer* met1 = lib_->getTech()->findLayer("met1"); |
| 43 | + ASSERT_NE(met1, nullptr); |
| 44 | + |
| 45 | + // Setup an NDR |
| 46 | + dbTechNonDefaultRule* ndr = dbTechNonDefaultRule::create(block_, "ndr"); |
| 47 | + dbTechLayerRule* rule = dbTechLayerRule::create(ndr, met1); |
| 48 | + const int width = 42; |
| 49 | + rule->setWidth(width); |
| 50 | + |
| 51 | + // Apply it to some routing |
| 52 | + dbNet* net = dbNet::create(block_, "net"); |
| 53 | + dbWire* wire = dbWire::create(net); |
| 54 | + dbWireEncoder encoder; |
| 55 | + encoder.begin(wire); |
| 56 | + encoder.newPath(met1, dbWireType::ROUTED, rule); |
| 57 | + encoder.addPoint(0, 0); |
| 58 | + encoder.addPoint(0, 100000); |
| 59 | + encoder.addPoint(100000, 100000); |
| 60 | + encoder.end(); |
| 61 | + |
| 62 | + // Check the width in both directions is correct |
| 63 | + int shape_cnt = 0; |
| 64 | + odb::dbWireShapeItr it; |
| 65 | + it.begin(wire); |
| 66 | + odb::dbShape shape; |
| 67 | + while (it.next(shape)) { |
| 68 | + EXPECT_EQ(shape.getBox().minDXDY(), width); |
| 69 | + ++shape_cnt; |
| 70 | + } |
| 71 | + EXPECT_EQ(shape_cnt, 2); |
| 72 | +} |
| 73 | + |
39 | 74 | TEST_F(OdbMultiPatternedTest, CanColorColoredLayer) |
40 | 75 | { |
41 | 76 | // Arrange |
|
0 commit comments