;COMMAND: SPRINKLER
;FOR ALL VERSIONS OF AUTOCAD
;SAVE AS sprinkler.lsp to directory \SUPPOTRT;and from command line: (load "sprinkler"

;then, on command line, type SPRINKLER AND FOLLOW SELLECT-OBJECT PROMPTS
;ERASES ALL PICKED CIRCLES AND REPLACES EACH WITH A CIRCLE BLOCK OF R=100
;SCALED TO THE RADIUS OF EACH ERASED CIRCLE
;AND INSERTED AT ITS CENTER POINT,
;APPEARANCE REMAINS THE SAME BUT NOW CIRCLES ARE BLOCKS
;RICHLY COMMENTED FOR YOUR CONVENIENCE AND MODIFICATIONS
;FOR QUESTIONS please call at:
;
;I am home most of the time.
;Get circles by any method you like - follow prompts to get objects
;only circles will be taken seriously, others will be ignored
(defun C:SPRINKLER()
;this allows select objects by any way you like
;first big IF
(IF (setq sset (ssget (list (cons 0 "CIRCLE"

)))(PROGN
;this tells how many circles were caught, picked, windowed, crossed
(setq ssetl (sslength sset))
;just for information, to see the circle count on command line
(print ssetl)(princ " Circles found..."
(circlo)
(setq i 0)
(while (< i ssetl)
(setq Edna (ssname sset i))
(setq Eddy (entget Edna))
(setq Typy (dxf 0 Eddy)
; this is not really used. Was for debugging
Insy (dxf 10 Eddy)
; Insertion point of circle we are going to erase
Rady (dxf 40 Eddy)
;radius of circle we are going to erase
)
;this is tricky (x Y) = (10 20) will be converted into "10,20"
(setq Insy (strcat
(rtos (car Insy) 2)
","
(rtos (cadr Insy))
)
)
;remember, the block CIRCO has radius 100. Why not 1?
;well, snap complications I suppose - too tiny
(setq rady (/ rady 100))
;and this converts R= 25.5 into "25.5"
(setq rady (rtos rady 2))
;this was for debugging. Don't need anymore
;(print Insy)(print Rady)
;erase the circle
(COMMAND "_erase" Edna ""

;insert block circle with scale factor
;to correspond to radius of erased circle
(COMMAND "_insert" "CIRCLO" Insy rady "" "" )
(setq i (+ 1 i));NEXT CIRCLE
);while ends here
)(print "No Circles Found!" ));first big IF ends here
(princ);suppress repeated prompt
);end of main function
;THIS makes a block of r=100 circle, if it does not exist IN THIS DRAWING
(defun Circlo()
(setq Blocky (tblobjname "block" "CIRCLO"

)
(if (not Blocky)(progn
(command "_circle" "0,0" "100"

(command "_block" "CIRCLO" "0,0" "_L" ""

;(command "_erase" "_L" ""

))
)
;Useful function to extract-
;Entity name "CIRCLE n= 0
;Insy InsertionPoint n= 10
;rady radious n= 40
;ed is full entity data
(defun dxf (n ed) (cdr (assoc n ed)))