Skip to content

Commit

Permalink
Merge pull request #45 from DavidAguilo/main
Browse files Browse the repository at this point in the history
Made parser capable of handling USEMINSPACING and MASKS in rectangles
  • Loading branch information
dan-fritchman authored Jun 18, 2024
2 parents adc117a + 255356b commit efc5aa4
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 8 deletions.
5 changes: 3 additions & 2 deletions lef21/src/data.rs
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ pub struct LefLibrary {
/// "Use Min Spacing" Option
#[serde(default, skip_serializing)]
#[builder(default)]
pub use_min_spacing: Option<Unsupported>,
pub use_min_spacing: Option<LefOnOff>,
/// Clearance Measure
#[serde(default, skip_serializing)]
#[builder(default)]
Expand Down Expand Up @@ -426,7 +426,7 @@ pub enum LefGeometry {
/// rectangles, polygons, and paths.
#[derive(Clone, Debug, Deserialize, Serialize, JsonSchema, PartialEq, Eq)]
pub enum LefShape {
Rect(LefPoint, LefPoint),
Rect(Option<LefDecimal>, LefPoint, LefPoint),
Polygon(Vec<LefPoint>),
Path(Vec<LefPoint>),
}
Expand Down Expand Up @@ -610,6 +610,7 @@ enumstr!(
DesignRuleWidth: "DESIGNRULEWIDTH",
Spacing: "SPACING",
Bump: "BUMP",
Mask: "MASK",

// UNITS Fields
Units: "UNITS",
Expand Down
19 changes: 15 additions & 4 deletions lef21/src/read.rs
Original file line number Diff line number Diff line change
Expand Up @@ -503,9 +503,15 @@ impl<'src> LefParser<'src> {
self.expect_key(LefKey::Library)?; // Expect END LIBRARY
break;
}
LefKey::UseMinSpacing => {
self.advance()?;
self.expect_key(LefKey::Obs)?;
let e = self.parse_enum::<LefOnOff>()?;
self.expect(TokenType::SemiColon)?;
lib.use_min_spacing(e)
}
LefKey::BeginExtension
| LefKey::ManufacturingGrid
| LefKey::UseMinSpacing
| LefKey::ClearanceMeasure
| LefKey::PropertyDefinitions
| LefKey::MaxViaStack
Expand Down Expand Up @@ -831,16 +837,21 @@ impl<'src> LefParser<'src> {
match self.peek_key()? {
LefKey::Rect => {
self.advance()?;
let mut mask = None;
if self.matches(TokenType::Name) {
// The ITERATE construction would go here, but is not supported.
self.fail(LefParseErrorType::Unsupported)?;
if self.get_key()? == LefKey::Mask {
mask = Some(self.parse_number()?);
} else {
// The ITERATE construction would go here, but is not supported.
self.fail(LefParseErrorType::Unsupported)?;
}
}
// Parse the two points
let p1 = self.parse_point()?;
let p2 = self.parse_point()?;
self.expect(TokenType::SemiColon)?;
// And return the Rect
Ok(LefGeometry::Shape(LefShape::Rect(p1, p2)))
Ok(LefGeometry::Shape(LefShape::Rect(mask, p1, p2)))
}
LefKey::Polygon => {
self.advance()?;
Expand Down
9 changes: 7 additions & 2 deletions lef21/src/write.rs
Original file line number Diff line number Diff line change
Expand Up @@ -294,8 +294,13 @@ impl<'wr> LefWriter<'wr> {
match geom {
LefGeometry::Iterate { .. } => unimplemented!(),
LefGeometry::Shape(ref shape) => match shape {
LefShape::Rect(p0, p1) => {
self.write_line(format_args_f!("{Rect} {p0} {p1} ; "))?;
LefShape::Rect(mask, p0, p1) => {
let mut line = format!("{Rect} ");
match mask {
Some(mask) => line.push_str(&format!("MASK {mask} ")),
None => (),
};
self.write_line(format_args_f!("{line}{p0} {p1} ; "))?;
}
LefShape::Polygon(pts) => {
let ptstr = pts
Expand Down

0 comments on commit efc5aa4

Please sign in to comment.