blob: 47be0b5e0701b6797d9a2011ebaf3ee2a8a3eb79 [file] [log] [blame]
/* ************************************************************************** */
/* ************************************************************************** */
/* ATTENTION: THIS IS AN AUTO-GENERATED FILE. DO NOT CHANGE IT! */
/* ************************************************************************** */
/* ************************************************************************** */
/* Copyright 2012 - 2013, Cadence Design Systems */
/* */
/* This file is part of the Cadence LEF/DEF Open Source */
/* Distribution, Product Version 5.8. */
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); */
/* you may not use this file except in compliance with the License. */
/* You may obtain a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or */
/* implied. See the License for the specific language governing */
/* permissions and limitations under the License. */
/* */
/* For updates, support, or to become part of the LEF/DEF Community, */
/* check www.openeda.org for details. */
/* */
/* $Author: dell $ */
/* $Revision: #1 $ */
/* $Date: 2017/06/06 $ */
/* $State: $ */
/* ************************************************************************** */
/* ************************************************************************** */
#ifndef CLEFIVIARULE_H
#define CLEFIVIARULE_H
#include <stdio.h>
#include "lefiTypedefs.h"
EXTERN int lefiViaRuleLayer_hasDirection (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_hasEnclosure (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_hasWidth (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_hasResistance (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_hasOverhang (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_hasMetalOverhang (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_hasSpacing (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_hasRect (const lefiViaRuleLayer* obj);
EXTERN char* lefiViaRuleLayer_name (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_isHorizontal (const lefiViaRuleLayer* obj);
EXTERN int lefiViaRuleLayer_isVertical (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_enclosureOverhang1 (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_enclosureOverhang2 (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_widthMin (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_widthMax (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_overhang (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_metalOverhang (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_resistance (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_spacingStepX (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_spacingStepY (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_xl (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_yl (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_xh (const lefiViaRuleLayer* obj);
EXTERN double lefiViaRuleLayer_yh (const lefiViaRuleLayer* obj);
/* Debug print */
EXTERN void lefiViaRuleLayer_print (const lefiViaRuleLayer* obj, FILE* f);
/* This should clear out all the old stuff. */
/* Add one of possibly many via names */
/* These routines set a part of the active layer. */
/* This routine sets and creates the active layer. */
EXTERN int lefiViaRule_hasGenerate (const lefiViaRule* obj);
EXTERN int lefiViaRule_hasDefault (const lefiViaRule* obj);
EXTERN char* lefiViaRule_name (const lefiViaRule* obj);
/* There are 2 or 3 layers in a rule. */
/* numLayers() tells how many. */
/* If a third layer exists then it is the cut layer. */
EXTERN int lefiViaRule_numLayers (const lefiViaRule* obj);
EXTERN const lefiViaRuleLayer* lefiViaRule_layer (const lefiViaRule* obj, int index);
EXTERN int lefiViaRule_numVias (const lefiViaRule* obj);
EXTERN char* lefiViaRule_viaName (const lefiViaRule* obj, int index);
EXTERN int lefiViaRule_numProps (const lefiViaRule* obj);
EXTERN const char* lefiViaRule_propName (const lefiViaRule* obj, int index);
EXTERN const char* lefiViaRule_propValue (const lefiViaRule* obj, int index);
EXTERN double lefiViaRule_propNumber (const lefiViaRule* obj, int index);
EXTERN const char lefiViaRule_propType (const lefiViaRule* obj, int index);
EXTERN int lefiViaRule_propIsNumber (const lefiViaRule* obj, int index);
EXTERN int lefiViaRule_propIsString (const lefiViaRule* obj, int index);
/* Debug print */
EXTERN void lefiViaRule_print (const lefiViaRule* obj, FILE* f);
#endif