• Skip to main content
  • Skip to search
  • Skip to footer
Cadence Home
  • This search text may be transcribed, used, stored, or accessed by our third-party service providers per our Cookie Policy and Privacy Policy.

  1. Community Forums
  2. Allegro X PCB Editor
  3. axlReplacePadstack axlReplacePadstack

Stats

  • Replies 5
  • Subscribers 160
  • Views 13060
  • Members are here 0
More Content

axlReplacePadstack axlReplacePadstack

Schendly
Schendly over 15 years ago

 I am trying to learn SKILL and I am going through 'allegroskill.pdf' manual and I can't get the axlReplacePadstack on  page 245 to work.  It says: "The padstack can be referenced by name or a dbid and must be present in the Allegro PCB Editor database"

I tried both dbid and padstack name I am still getting nil. I know how to do it with the Allegro Editor command. 

Thanks for any help.

Schendly 

Version Allegro Xl 16.01 

  • Sign in to reply
  • Cancel
  • Ejlersen
    Ejlersen over 15 years ago

    Hi Schendly

    axlReplacePadstack(o_dbid/lo_dbid o_padstackdbid/t_padname)

    o_dbid/lo_dbid is either single or list of ids

    o_padstackdbid/t_padname can be dbid or padstack name

    Although this seems pretty obvious I've not been able to get it to work either. I'm on 16.3. I'll file an SR to see whats going on here.

    Best regards

    Ole

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • Schendly
    Schendly over 15 years ago

    Thanks, Ole.

    As I am a novice in Skill, I thougth I was misreading the manual.

    Regrads,

    Schendly

     

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • eDave
    eDave over 15 years ago
    Try this function. It works in 16.3: defun( AFn_replacePads () let((pins, padstackNames, n, padstack, psid) axlClearSelSet() axlSetFindFilter(?enabled '("NOALL", "PINS"), ?onButtons '("PINS")) axlSelect(?prompt "Select pins") pins = axlGetSelSet() padstackNames = unique(pins ~>name) when(length(padstackNames) > 1 n = axlUIMultipleChoice("Select the padstack name of the pins to replace", padstackNames, "Select pins to replace") pins = and(n >= 0, setof(p, pins, p ->name == nth(n, padstackNames))) ) axlHighlightObject(pins) and( pins padstack = car(axlUIDataBrowse('PADSTACK '(RETRIEVE_NAME, EXAMINE_DATABASE), "New Padstack Name", t)) psid = axlLoadPadstack(padstack) axlReplacePadstack(pins, psid) ) axlDehighlightObject(pins) axlClearSelSet() axlFinishEnterFun() ))
    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • Ejlersen
    Ejlersen over 15 years ago

    Hi

    Found the issue, you need to load the padstack before it can be used to replace. Code below works fine, so Dave, thanks for the hint in your code with axlLoadPadstack - that did the trick.

    axlClearSelSet()

    axlSetFindFilter(?enabled list("noall", "vias", "invisible"), ?onButtons list("noall", "vias"))

    axlAddSelectAll()

    selSet = axlGetSelSet()

    axlClearSelSet()

    pad = axlLoadPadstack("via019")

    via = axlReplacePadstack(selSet, pad)

    Best regards

    Ole

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • Schendly
    Schendly over 15 years ago

    Thanks, Dave and Ole.

     I will try it.

     

    Schendly 

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
Cadence Guidelines

Community Guidelines

The Cadence Design Communities support Cadence users and technologists interacting to exchange ideas, news, technical information, and best practices to solve problems and get the most from Cadence technology. The community is open to everyone, and to provide the most value, we require participants to follow our Community Guidelines that facilitate a quality exchange of ideas and information. By accessing, contributing, using or downloading any materials from the site, you agree to be bound by the full Community Guidelines.

© 2025 Cadence Design Systems, Inc. All Rights Reserved.

  • Terms of Use
  • Privacy
  • Cookie Policy
  • US Trademarks
  • Do Not Sell or Share My Personal Information