################################################################################
#
#  Copyright 2006 (c) Synopsys, Inc.
#
################################################################################
#
# Title        : SDC-parser commands declaration for SDC version 1.5
#
#              : Ibna Faruque
# Updated      : june 12, 2006
# Bug Fixes    : 
################################################################################

 declare all_clocks {
 }

 declare all_inputs {
  {-level_sensitive     Flag       }
  {-edge_triggered      Flag       }
  {-clock               List       }
 } {!(param(-level_sensitive) && param(-edge_triggered))}

 declare all_outputs {
  {-level_sensitive     Flag       }
  {-edge_triggered      Flag       }
  {-clock               List       }
 } {!(param(-level_sensitive) && param(-edge_triggered))}

 declare create_clock {
  {-period              Float      {$par>=0}}
  {-name                String     }
  {-waveform            List       {type_Float {length($length>=2 && ($length % 2)==0)} } }
  {port_pin_list        List       }
  {-add                 Flag       }
 } {param(-period) && (param(-name) || param(port_pin_list))}

 declare create_generated_clock {
 {-name                String     }
 {-source	       List       }
 {-edges	       List  {type_Float {length($length>=2} }	  }
 {-divide_by	       Int   {1 && $par>=0}  }
 {-multiply_by	       Int   {1 && $par>=0}  }
 {-edge_shift          List       }
 {-duty_cycle          Float {$par>=0 && $par <=100} }
 {-invert              Flag       }
 {port_pin_list        List       }
 {-add                 Flag       }
 {-master_clock        List       } 
} {param(-source) && param(port_pin_list) && !(param(-multiply_by) && param(-divide_by))}

 declare current_design {
 }

 declare current_instance {
  {-instance            String     }
 }

 declare get_cells {
  {-of_objects          List       }
  {patterns             List       }
  {-hierarchical        Flag       }
  {-regexp             Flag       }
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 # {                                }
 } {(param(patterns) && !param(-of_objects)) || \
    (param(-of_objects) && !param(patterns)) || !param(patterns)}
# && !param(-hierarchical))}

# get_cell synonym for get_cells
 declare get_cell {
  {-of_objects          List       }
  {patterns             List       }
  {-hierarchical        Flag       }
  {-regexp             Flag       }
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 # {                                }
 } {(param(patterns) && !param(-of_objects)) || \
    (param(-of_objects) && !param(patterns)) || !param(patterns)}



 declare get_clocks {
  {patterns             List       }
  {-regexp             Flag       }
  {-nocase              Flag       }
 } 
#} {param(patterns)}

 declare get_clock {
  {patterns             List       }
  {-regexp             Flag       }
  {-nocase              Flag       } 
}

 declare get_lib_cells {
  {patterns             List       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 } {param(patterns)}

 declare get_lib_cell {
  {patterns             List       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 } {param(patterns)}


 declare get_lib_pins {
  {patterns             List       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 } {param(patterns)}

 declare get_lib_pin {
  {patterns             List       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 } {param(patterns)}


 declare get_libs {
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {patterns             List       }
}
 #} {param(patterns)}

 declare get_nets {
  {patterns             List       }
  {-of_objects          List       }
  {-hierarchical        Flag       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
} {(param(patterns) && !param(-of_objects)) || \
    (param(-of_objects) && !param(patterns)) || !param(patterns)}


 declare get_net {
  {patterns             List       }
  {-of_objects          List       }
  {-hierarchical        Flag       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
} {(param(patterns) && !param(-of_objects)) || \
    (param(-of_objects) && !param(patterns)) || !param(patterns)}



 declare get_pins {
  {patterns             List       }
  {-hierarchical        Flag       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 } 

 declare get_pin {
  {patterns             List       }
  {-hierarchical        Flag       }
  {-regexp             Flag       } 
  {-nocase              Flag       }
  {-hsc                 Enum       {{/} {@} {^} {#} {.} {|}}}
 } 

 declare get_ports {
  {-hierarchical        Flag       }
  {-regexp             Flag       }
  {patterns             List       }
}
# } {param(patterns)}

 declare get_port {
  {-hierarchical        Flag       }
  {-regexp             Flag       }
  {patterns             List       }
}
# } {param(patterns)}


 declare set_case_analysis {
  {value                Enum        {0 1 rising falling zero one rise fall}}
  {port_pin_list        List        }
 } {param(value) && param(port_pin_list)}

 declare set_clock_gating_check {
  {-setup               Float       {$par>=0}}
  {-hold                Float       {$par>=0}}
  {-rise                Flag        }
  {-fall                Flag        }
  {-high                Flag        }
  {-low                 Flag        }
  {object_list          List        }
 } {(param(-setup) || param(-hold) || param(-high) || param(-low)) && \
   !(param(-high) && param(-low))}

 declare set_clock_latency {
  {delay                Float       {1}}
  {object_list          List        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-min                 Flag        }
  {-max                 Flag        }
  {-source              Flag        }
  {-early               Flag        }
  {-late                Flag        }
  {-clock		List        }
 } {param(delay) && param(object_list)}

 declare set_clock_transition {
  {transition           Float       {1}}
  {clock_list           List        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-min                 Flag        }
  {-max                 Flag        }
 } {param(transition) && param(clock_list) && \
   !(param(-rise) && param(-fall))}

 declare set_clock_uncertainty {
  {uncertainty          Float       {1}}
  {-from                List        }
  {-to                  List        }
  {-rise_to             List        }
  {-fall_to             List        }
  {-rise_from           List        }
  {-fall_from           List        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-setup               Flag        }
  {-hold                Flag        }
  {object_list          List        }
 } {param(uncertainty) && param(object_list) ^ \
   (((param(-from) ^ param(-rise_from) ^ param(-fall_from))) \
    && (param(-to) ^ param(-rise_to) ^ param(-fall_to)))}

 declare set_disable_timing {
  {object_list          List        }
  {-from                String      }
  {-to                  String      }
 } {param(object_list) && \
   !(param(-to) ^ param(-from))}

 declare set_drive {
  {resistance           Float       {$par>=0}}
  {port_list            List        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-min                 Flag        }
  {-max                 Flag        }
 } {param(resistance) && param(port_list)}

 declare set_driving_cell {
  {-lib_cell            String      }
  {-rise                Flag        }
  {-fall                Flag        }
  {-library             String      }
  {-pin                 String      }
  {-from_pin            String      }
  {-multiply_by         Float       {$par>=0}}
  {-dont_scale          Flag        }
  {-no_design_rule      Flag        }
  {-input_transition_rise   Float   {$par>=0}}
  {-input_transition_fall   Float   {$par>=0}}
  {port_list            List        }
  {-min                 Flag        }
  {-max                 Flag        }
  {-clock               List        }
  {-clock_fall          Flag        }
 } {param(port_list) &&  param(-lib_cell)} 

 declare set_false_path {
  {-setup               Flag        }
  {-hold                Flag        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-from                List        }
  {-to                  List        }
  {-through             List        {dup}}
 } {(param(-from) || param(-to) || param(-through)) && \
 !(param(-rise) && param(-fall)) && !(param(-setup) && param(-hold))}

 declare set_fanout_load {
  {value                Float       {$par>=0}}
  {port_list            List        }
 } {param(value) && param(port_list)}

 declare set_hierarchy_separator {
  {hchar                Enum        {{/} {@} {^} {#} {.} {|}}}
 } {param(hchar)}

 declare set_input_delay {
  {-clock               List        }
  {-clock_fall          Flag        }
  {-level_sensitive     Flag        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-min                 Flag        }
  {-max                 Flag        }
  {-add_delay           Flag        }
  {delay_value          Float       {1}}
  {port_pin_list        List        }
  {-network_latency_included     Flag  }
  {-source_latency_included      Flag  }
 } {param(delay_value) && param(port_pin_list) && \
 !((param(-clock_fall) || param(-level_sensitive)) && !param(-clock))}

 declare set_input_transition {
  {-rise                Flag        }
  {-fall                Flag        }
  {-min                 Flag        }
  {-max                 Flag        }
  {transition           Float       {$par>=0}}
  {port_list            List        }
  {-clock               List        }
  {-clock_fall          Flag        }
 } {param(transition) && param(port_list)}

 declare set_load {
  {-min                 Flag        }
  {-max                 Flag        }
  {-substract_pin_load  Flag        }
  {-pin_load            Flag        }
  {-wire_load           Flag        }
  {value                Float       {$par>=0}}
  {objects              List        }
 } {param(value) && param(objects)}

 declare set_logic_dc {
  {port_list            List        }
 } {param(port_list)}

 declare set_logic_one {
  {port_list            List        }
 } {param(port_list)}

 declare set_logic_zero {
  {port_list            List        }
 } {param(port_list)}

 declare set_max_area {
  {area_value           Float       {$par>=0}}
 } {param(area_value)}

 declare set_max_capacitance {
  {capacitance_value    Float       {$par>=0}}
  {object_list          List        }
 } {param(capacitance_value) && param(object_list)}

 declare set_max_delay {
  {delay_value          Float       {1}}
  {-rise                Flag        }
  {-fall                Flag        }
  {-from                List        }
  {-to                  List        }
  {-through             List        {dup}}
 } {param(delay_value) && \
 !(param(-rise) && param(-fall))}

 declare set_max_fanout {
  {fanout_value         Float       {$par>=0}}
  {object_list          List        }
 } {param(fanout_value) && param(object_list)}

 declare set_max_time_borrow {
  {delay_value          Float       {$par>=0}}
  {object_list          List        }
 } {param(delay_value) && param(object_list)}

 declare set_max_transition {
  {transition_value     Float       {$par>=0}}
  {-clock_path          Flag  }
  {-fall                Flag }
  {-rise                Flag}
  {object_list          List        }
 } {param(transition_value) && param(object_list)}

 declare set_min_capacitance {
  {capacitance_value    Float       {$par>=0}}
  {object_list          List        }
 } {param(capacitance_value) && param(object_list)}

 declare set_min_delay {
  {delay_value          Float       {1}}
  {-rise                Flag        }
  {-fall                Flag        }
  {-from                List        }
  {-to                  List        }
  {-through             List        {dup}}
 } {param(delay_value) && \
  !(param(-rise) && param(-fall))}

 declare set_multicycle_path {
  {path_multiplier      Int         {1}}
  {-setup               Flag        }
  {-hold                Flag        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-start               Flag        }
  {-end                 Flag        }
  {-from                List        }
  {-to                  List        }
  {-through             List        {dup}}
 } {param(path_multiplier)}

 declare set_operating_conditions {
  {-analysis_type       Enum        {single bc_wc on_chip_variation}}
  {-library             List        }
  {-max                 String      }
  {-min                 String      }
  {-max_library         List        }
  {-object_list		List        }
  {-min_library         List        }
  {condition            String      }
 }

 declare set_output_delay {
  {-clock               List        }
  {-clock_fall          Flag        }
  {-level_sensitive     Flag        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-min                 Flag        }
  {-max                 Flag        }
  {-add_delay           Flag        }
  {delay_value          Float       {1}}
  {port_pin_list        List        }
  {-network_latency_included     Flag  }
  {-source_latency_included      Flag  }

 } {param(delay_value) && param(port_pin_list) && \
 !((param(-clock_fall) || param(-level_sensitive)) && !param(-clock))}

 declare set_port_fanout_number {
  {fanout_number        Int         {($par>=0) && ($par<=100000)}}
  {port_list            List        }
 } {param(fanout_number) && param(port_list)}

 declare set_propagated_clock {
  {object_list          List        }
 } {param(object_list)}

 declare set_resistance {
  {value                Float       {$par>=0}}
  {net_list             List        }
  {-min                 Flag        }
  {-max                 Flag        }
 } {param(value) && param(net_list)}

 declare set_wire_load_min_block_size {
  {size                 Float       {$par>=0}}
 } {param(size)}

 declare set_wire_load_mode {
  {mode_name            Enum        {top enclosed segmented}}
 } {param(mode_name)}

 declare set_wire_load_model {
  {-name                String      }
  {-library             List        }
  {-min                 Flag        }
  {-max                 Flag        }
  {object_list          List        }
 } {param(-name)}

 declare set_wire_load_selection_group {
  {group_name          String      }
  {-library             List        }
  {-min                 Flag        }
  {-max                 Flag        }
  {object_list          List        }
 } {param(group_name)}

 declare set_data_check {
  {-from                List        }
  {-rise_from           List        }
  {-fall_from           List        }
  {-to                  List        }
  {-rise_to             List        }
  {-fall_to             List        }
  {-rise                Flag        }
  {-fall                Flag        }
  {-setup               Flag        }
  {-hold                Flag        }
  {-clock               List        }
  {value                Float  {$par>=0}      }
 } {(param(-rise_from) || param(-from) || param(-fall_from)) && \
   ((param(-to) || param(-rise_to)) || param(-fall_to)) }

 declare set_timing_derate {
  {derate_value        Float  {$par>=0.1  } }
  {object_list          List      }
# {derate_value         Float {$par>=0.1 && $par<=2.0}}
  {-min                 Flag      }
  {-max                 Flag      }
  {-early               Flag      }
  {-late                Flag      }
  {-clock               Flag      }
  {-data                Flag      }
  {-net_delay           Flag      }
  {-cell_delay          Flag      }
  {-cell_check          Flag      }
} {param(derate_value) && (param(-early) && !param(-late)) || (param(-late) && !param(-early))}



 declare set_max_dynamic_power {
  {power_value           Float {$par>=0}       }
  {-unit                 Enum  {GW MW KW W mW uW nW pW fW aW} }
 } {param(power_value)}

 declare set_max_leakage_power {
  {power_value         Float        {$par>=0}}
  {-unit               Enum         {GW MW KW W mW uW nW pW fW aW}}
 } {param(power_value)}

declare create_voltage_area {
  {-name                String {1}    }
  {-coordinate          List       }
  {-guard_band_x        List       }
  {-guard_band_y        List       }
  {cell_list            List {1}      }
 } {param(-name) && {param(cell_list)}} 

declare set_level_shifter_strategy {
  {-rule               Enum         {all low_to_high high_to_low}}
 } {param(-rule)}

declare set_level_shifter_threshold {
  {-voltage            Float  {1}      }
  {-percent            Float   {1}  }
 } {param(-voltage)} 



 declare set_min_porosity {
 {porosity_value       Float        {$par>=0 && $par <=90}}
 {object_list          List          }
 } {param(porosity_value) && param(object_list)}



# register_new_type EdgeList {
#    if {[sdc::check_type List $value]} {
#        if {[expr {[llength $value] % 2}] || [llength $value]==0} {
#            return 0
#        }
#
#        set startvalue -0.1
#
#        foreach parv $value {
#            if {[catch {expr {$parv + 1}}]} {
#                return 0
#            }
#            if {$parv<=$startvalue} {
#                return 0
#            }
#            set startvalue $parv
#        }
#
#        return 1
#    } else {
#        return 0
#    }
# }
