[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
Re: gEDA-user: Bug report for renaming slots [Was: Re: gEDA on windows]
On Tue, 2009-01-13 at 04:14 +0000, Kai-Martin Knaak wrote:
> On Tue, 13 Jan 2009 03:41:24 +0000, Peter Clifton wrote:
>
> > As an example I wrote for someone (and I ended up using it myself), I
> > have a script hook here which renames any component I copy back to "U?"
> > (removes the numbering), so that I don't end up accidentally naming two
> > components the same due to a copy-paste in my schematics.
>
> I have wished geschem behaved like. Any chance, this script is going to
> hit the main distribution of geda?
Perhaps when we have a more formal system of enabling various plugins.
Fow now, it is attached. You need to hook it in with:
(load-from-path "/path/to/unnumber-refdes.scm")
(add-hook! copy-component-hook unnumber-refdes)
in your gschemrc file.
--
Peter Clifton
Electrical Engineering Division,
Engineering Department,
University of Cambridge,
9, JJ Thomson Avenue,
Cambridge
CB3 0FA
Tel: +44 (0)7729 980173 - (No signal in the lab!)
;; Copyright (C) 2008 Peter Clifton
;;
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2 of the License, or
;; (at your option) any later version.
;;
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;;
;; You should have received a copy of the GNU General Public License
;; along with this program; if not, write to the Free Software
;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111 USA
(use-modules (srfi srfi-13) (srfi srfi-14))
(define (unnumber-refdes attribs)
;; Function to strip digit suffixes
(define (strip-digit-suffix string)
(string-trim-right string char-set:digit)
)
(define (unnumbered-refdes oldrefdes)
(if (string-suffix? "?" oldrefdes)
oldrefdes
(string-append (strip-digit-suffix oldrefdes) "?")
)
)
(for-each
(lambda (attrib)
(let* ((name-value (get-attribute-name-value attrib))
(name (car name-value))
(value (cdr name-value)))
(if (string=? name "refdes")
(set-attribute-value! attrib (unnumbered-refdes value)))
)
)
attribs
)
)
_______________________________________________
geda-user mailing list
geda-user@xxxxxxxxxxxxxx
http://www.seul.org/cgi-bin/mailman/listinfo/geda-user