home *** CD-ROM | disk | FTP | other *** search
- /* $VER: FinalWrapper 2.1 (11.06.94) by NDY's */
-
- /* Main [2.1] */
- OPTIONS RESULTS
- SIGNAL ON ERROR
- SIGNAL ON SYNTAX
- initerr=init()
- ADDRESS VALUE rxport
- CALL locale
- DO WHILE closed=2
- IF guiinit()=5 THEN
- DO
- ShowMessage 1 1 nogui
- CALL bye(50)
- END
- CALL gui
- IF closed~=2 THEN CALL guiclean
- CALL options
- IF chosenobjs()=0 THEN
- DO
- CALL pointnoval
- IF txt>0 THEN
- CALL textblock
- ELSE
- CALL bodytext
- IF ~broken THEN CALL initwrap
- IF ~broken THEN CALL wrap
- IF ~broken THEN CALL group
- rescan=Max(rescan-1,0)
- broken=0
- END
- END
- CALL bye(0)
-
- PROC init: /* Initialization [2.1] */
- /* Vars needed by "bye" / "ERROR" */
- errtext='"%t" "(#%n) in line %l" "" "Ok" "" ""'
- objs=0
- deci=""
- et=""
- lib.1=0
- lib.2=0
- lib.3=0
- cleangui=0
- /* Started by Final Writer? */
- rxport=ADDRESS()
- portok=Left(rxport,7)="FINALW."
- IF ~portok THEN
- DO i=1 TO 10 UNTIL portok
- rxport="FINALW."||i
- portok=Show("p",rxport)
- END
- IF ~portok THEN RETURN 13
- /* Open libraries */
- library.1="rexxmathlib.library"
- library.2="rexxsupport.library"
- library.3="apig.library"
- DO libn=1 TO 3
- lib.libn=Show("l",library.libn)
- IF ~lib.libn THEN lib.libn=AddLib(library.libn,0,-30,0)
- IF ~lib.libn THEN RETURN 14
- END
- libn=3
- /* Load defaults */
- preff.1="ENV:FinalWrapper.def"
- preff.2="ENVARC:FinalWrapper.def"
- DO i=1 TO 2 UNTIL ok
- ok=Open(prefs,preff.i,"R")
- IF ok THEN
- DO
- default=ReadCh(prefs,52)
- CALL Close(prefs)
- END
- END
- port=0
- rescan=1
- broken=0
- closed=2
- oldlen=0
- oldtxt=0
- oldoval=0
- oldobjs=0
- RETURN 0
- PROC locale: /* Language specific strings [2.1] */
- lang=getlanguage()
- test=0 /* test 1/2/3/4/6/7/8/10/20/100/200 WITH new languages, 0 = no test */
- IF lang="deutsch" THEN /* German */
- DO
- wintitle="%i"
- ltxt.1.1="Sektor (°): Im Uhrzeigersinn"
- ltxt.1.2="Sektor (°): Im Gegenuhrzeigersinn"
- ltxt.2.1="Spirale (%): Von innen nach aussen"
- ltxt.2.2="Spirale (%): Von aussen nach innen"
- ltxt.3.1="Größe (%): Grösser werdend"
- ltxt.3.2="Größe (%): Kleiner werdend"
- ltxt.4.1="Start (°): Im Uhrzeigersinn"
- ltxt.4.2="Start (°): Im Gegenuhrzeigersinn"
- ltxt.4.3="Start (°): Absolut"
- ltxt.5.1="Rotation (°): Uhrzeigersinn"
- ltxt.5.2="Rotation (°): Gegenuhrzeigersinn"
- ltxt.5.3="Rotation (°): Absolut"
- ltxt.5.4="Rotation: Wie Textblock"
- ltxt.6.1="Löschen: Oval und Textblock"
- ltxt.6.2="Löschen: Nichts"
- ltxt.6.3="Löschen: Oval kopieren"
- ltxt.6.4="Löschen: Nur Oval"
- ltxt.7.1="Gruppieren: Ausgewähltes Oval"
- ltxt.7.2="Gruppieren: Unsichtbares Oval"
- ltxt.7.3="Gruppieren: Nein"
- ltxt.8.1="Anpassen: Zeichengrösse"
- ltxt.8.2="Anpassen: Zeichenbreite"
- ltxt.8.3="Anpassen: Sektorgrösse"
- ltxt.8.4="Anpassen: Nichts"
- ltxt.9="Screen anzeigen"
- ltxt.10="Gadgets aktivieren"
- ltxt.11="Einstellungen behalten"
- ltxt.12="Neuer Text"
- ltxt.13="Standard setzen"
- ltxt.14=" Ok "
- ltxt.15="Zeichnen"
- ltxt.16="Abbruch"
- errtext='"FinalWrapper-Fehler:" "%t" "in Zeile %l (Fehlernummer %n)" "Ok" "" ""'
- noselect='"FinalWrapper-Fehler:" "Zuerst einen Textblock oder einen" "Textausschnitt und ein Oval wählen!" "Ok" "" ""'
- fwerrtext.10='Befehl gescheitert'
- fwerrtext.20='Ungültige Argumente'
- fwerrtext.100='Befehl unbekannt'
- fwerrtext.200='Kann fwarexx.library nicht öffnen'
- nolib='"FinalWrapper-Fehler:" "Konnte ''%y'' nicht öffnen!" "" "Ok" "" ""'
- nofw='FinalWrapper-Fehler: Final Writer nicht gefunden!'
- wrongos='"FinalWrapper-Fehler:" "Es wird mindestens OS2.0" "benötigt!" "Ok" "" ""'
- stillalive='"FinalWrapper läuft bereits!" "" "" "Ok" "" ""'
- nogui='"FinalWrapper-Fehler:" "Konnte Requester nicht öffnen!" "" "Ok" "" ""'
- END
- ELSE /* Default: English */
- DO
- wintitle="%i"
- ltxt.1.1="Arc (°): Write clockwise"
- ltxt.1.2="Arc (°): Write anticlockwise"
- ltxt.2.1="Spiral (%): Inside to outside"
- ltxt.2.2="Spiral (%): Outside to inside"
- ltxt.3.1="Size (%): Increasing"
- ltxt.3.2="Size (%): Decreasing"
- ltxt.4.1="Start (°): Shift clockwise"
- ltxt.4.2="Start (°): Shift anticlockwise"
- ltxt.4.3="Start (°): Absolute"
- ltxt.5.1="Rotate (°): Clockwise"
- ltxt.5.2="Rotate (°): Anticlockwise"
- ltxt.5.3="Rotate (°): Absolute"
- ltxt.5.4="Rotate: Like textblock"
- ltxt.6.1="Delete: Oval and textblock"
- ltxt.6.2="Delete: Nothing"
- ltxt.6.3="Delete: Copy oval"
- ltxt.6.4="Delete: Oval only"
- ltxt.7.1="Group: Selected oval"
- ltxt.7.2="Group: Invisible oval"
- ltxt.7.3="Group: No"
- ltxt.8.1="Adjust: Character size"
- ltxt.8.2="Adjust: Character width"
- ltxt.8.3="Adjust: Arc"
- ltxt.8.4="Adjust: Nothing"
- ltxt.9="Autoshow Screen "
- ltxt.10="Autoactivate gadgets"
- ltxt.11="Preserve settings"
- ltxt.12="Rescan"
- ltxt.13="Set default"
- ltxt.14=" Ok "
- ltxt.15=" Draw "
- ltxt.16="Cancel"
- errtext='"FinalWrapper failed:" "%t" "in line %l (errornumber %n)" "Ok" "" ""'
- noselect='"FinalWrapper failed:" "Select an oval and a textblock or" "some text before calling FinalWrapper!" "Ok" "" ""'
- fwerrtext.10='Instruction failed'
- fwerrtext.20='Invalid arguments'
- fwerrtext.100='Unknown instruction'
- fwerrtext.200='Couldn''t open fwarexx.library'
- nolib='"FinalWrapper failed:" "Couldn''t open ''%y''" "" "Ok" "" ""'
- nofw='FinalWrapper failed: Final Writer not found!'
- wrongos='"FinalWrapper failed:" "At least OS2.0 is needed!" "" "Ok" "" ""'
- stillalive='"FinalWrapper is already running!" "" "" "Ok" "" ""'
- nogui='"FinalWrapper failed:" "Couldn''t open requester!" "" "Ok" "" ""'
- END
- /* Don't change the following! */
- info='FinalWrapper 2.1 by NDY''s'
- wintitle=replacepat(wintitle,"%i",info)
- labs.1=2
- labs.2=2
- labs.3=2
- labs.4=3
- labs.5=4
- labs.6=4
- labs.7=3
- labs.8=4
- DO i=9 TO 13
- labs.i=0
- END
- IF test=4 | initerr=13 THEN
- DO
- SAY nofw
- CALL bye(13)
- END
- IF test=1 | initerr=14 THEN
- DO
- ShowMessage 1 1 replacepat(nolib,"%y",library.libn)
- CALL bye(14)
- END
- IF test=8 THEN
- DO
- ShowMessage 1 1 nogui
- CALL bye(50)
- END
- /* Already running? */
- portname="FinalWrapperPort"
- IF Show("p",portname) | test=7 THEN
- DO
- ShowMessage 1 1 stillalive
- /* Don't close libs! */
- DO i=1 TO 3
- lib.i=0
- END
- CALL bye(5)
- END
- /* Test errors */
- IF test>5 THEN
- DO
- RC=test
- IF test=6 THEN SIGNAL SYNTAX
- SIGNAL ERROR
- END
- RETURN
- PROC guiinit: /* Init interface. Returns 5 if failed [2.1] */
- /* Already opened? */
- IF cleangui THEN RETURN 0
- /* OS 2.0 ? */
- execbase=GETVALUE("4"x,0,4,"P")
- osversion=GETVALUE(execbase,20,2,"N")
- IF osversion<37 | test=3 THEN
- DO
- ShowMessage 1 1 wrongos
- CALL bye(10)
- END
- /* Convert defaults */
- IF Length(default)<52 THEN default=X2C("01000168 00010019 00010064 00020000 00020000 00030000 00020000 00030000 01000000 01000000 00000000 00000000 00000000")
- DO id=1 TO 13
- i=id*4
- check.id=C2D(SubStr(default,i-3,1))~=0
- cycle.id=Min(Max(C2D(SubStr(default,i-2,1)),0),labs.id)
- val.id=Min(Max(C2D(SubStr(default,i-1,2)),0),9999)
- END
- /* Initialize constants */
- scr=NULL() ; win=NULL() ; gad=NULL() ; scrvinfo=NULL() ; port=0
- gads=16
- cleangui=1
- CALL SET_APIG_GLOBALS()
- nullbyte=D2C(0)
- /* Screen */
- scr=LockPubScreen("")
- IF scr=NULL() THEN RETURN 5
- scrvinfo=GetVisualInfo(scr)
- IF scrvinfo=NULL() THEN RETURN 5
- scrfont=GETVALUE(scr,40,4,"P")
- fonth=GETVALUE(scrfont,4,2,"N")
- scrrp=D2C(C2D(scr)+84)
- glistptr=MAKEPOINTER(0,0,4,MEMF_CLEAR)
- IF glistptr=NULL() THEN RETURN 5
- borderl=GETVALUE(scr,36,1,"N")
- bordert=GETVALUE(scr,35,1,"N")+fonth+1
- /* Figure out window size */
- gadh=fonth+4
- gaddy=gadh+2
- maxwidth=0
- intw=TextLength(scrrp,"77777"||nullbyte,-1)+12 /* 4 digits plus cursor */
- addwidth=32+intw
- DO id=1 TO 8
- glabels.id=MAKEPOINTER(0,0,4*labs.id+4,MEMF_CLEAR)
- IF glabels.id=NULL() THEN RETURN 5
- DO i=1 TO labs.id /* last one must be null to terminate list */
- lbuf.id.i=MAKEPOINTER(glabels.id,0,Length(ltxt.id.i)+1,MEMF_CLEAR)
- IF lbuf.id.i=NULL() THEN RETURN 5
- /* copy label text into buffer */
- CALL Export(lbuf.id.i,ltxt.id.i)
- /* set array slot to lbuf address */
- CALL SETVALUE(glabels.id,(i-1)*4,4,"P",lbuf.id.i)
- xwid=TextLength(scrrp,ltxt.id.i||nullbyte,-1)+30
- IF id<6 THEN xwid=xwid+addwidth
- maxwidth=Max(maxwidth,xwid)
- END
- END
- DO id=9 TO 13
- gwid.id=TextLength(scrrp,ltxt.id||nullbyte,-1)+34
- END
- DO id=14 TO 16
- gwid.id=TextLength(scrrp,ltxt.id||nullbyte,-1)+6
- END
- maxwidth=Max(maxwidth,gwid.9+gwid.10+4)
- maxwidth=Max(maxwidth,gwid.11+gwid.12+4)
- maxwidth=Max(maxwidth,gwid.13+gwid.14+gwid.15+gwid.16+10)
- winwid=maxwidth+4
- winhi=11*gaddy+6
- /* Initialize gadgets */
- gadx=borderl+2
- gady=bordert+1
- gadw=maxwidth
- gadmaxx=winwid+borderl-2
- gadmaxy=winhi+bordert-1
- DO id=1 TO 5
- gadid=id*3
- newgadxb.id=MAKENEWGADGET(scrvinfo,scrfont,gadx,gady+(id-1)*gaddy,28,gadh,"",0,gadid+1,NULL())
- newgadxi.id=MAKENEWGADGET(scrvinfo,scrfont,gadmaxx-intw,gady+(id-1)*gaddy,intw,gadh,"",0,gadid+2,NULL())
- newgadx.id=MAKENEWGADGET(scrvinfo,scrfont,gadx+30,gady+(id-1)*gaddy,gadw-addwidth,gadh,"",0,gadid,NULL())
- IF newgadxb.id=NULL() | newgadxi.id=NULL() | newgadx.id=NULL() THEN RETURN 5
- END
- DO id=6 TO 8
- newgadx.id=MAKENEWGADGET(scrvinfo,scrfont,gadx,gady+(id-1)*gaddy,gadw,gadh,"",0,id*3,NULL())
- IF newgadx.id=NULL() THEN RETURN 5
- END
- DO id=9 TO 12
- IF (id-9)//2 THEN
- gx=gadmaxx-gwid.id
- ELSE
- gx=gadx
- newgadx.id=MAKENEWGADGET(scrvinfo,scrfont,gx,gady+(8+(id-9)%2)*gaddy,28,gadh,ltxt.id,PLACETEXT_RIGHT,id*3+1,NULL())
- END
- newgadx.13=MAKENEWGADGET(scrvinfo,scrfont,gadx,gadmaxy-gadh,28,gadh,ltxt.13,PLACETEXT_RIGHT,13*3+1,NULL())
- gx=gadmaxx-gwid.14-gwid.15-gwid.16-8
- DO id=14 TO 16
- newgadx.id=MAKENEWGADGET(scrvinfo,scrfont,gx,gadmaxy-gadh,gwid.id,gadh,ltxt.id,PLACETEXT_IN,id*3,NULL())
- gx=gx+gwid.id+4
- END
- DO id=9 TO 16
- IF newgadx.id=NULL() THEN RETURN 5
- END
- /* Create'em */
- gad=CreateContext(glistptr)
- cyclegad.1=gad
- DO id=1 TO 5
- x=Max(id-1,1)
- checkgad.id=CreateGadget(CHECKBOX_KIND,cyclegad.x,newgadxb.id,GTCB_CHECKED,check.id,TAG_DONE,0)
- intgad.id=CreateGadget(INTEGER_KIND,checkgad.id,newgadxi.id,GTIN_NUMBER,val.id,GTIN_MAXCHARS,4,TAG_DONE,0)
- cyclegad.id=CreateGadget(CYCLE_KIND,intgad.id,newgadx.id,GTCY_LABELS,glabels.id,GTCY_ACTIVE,cycle.id,TAG_DONE,0)
- END
- DO id=6 TO 8
- x=id-1
- cyclegad.id=CreateGadget(CYCLE_KIND,cyclegad.x,newgadx.id,GTCY_LABELS,glabels.id,GTCY_ACTIVE,cycle.id,TAG_DONE,0)
- END
- checkgad.8=cyclegad.8
- DO id=9 TO 13
- x=id-1
- checkgad.id=CreateGadget(CHECKBOX_KIND,checkgad.x,newgadx.id,GTCB_CHECKED,check.id,TAG_DONE,0)
- END
- DO id=14 TO 16
- x=id-1
- checkgad.id=CreateGadget(BUTTON_KIND,checkgad.x,newgadx.id,TAG_DONE,0)
- END
- IF checkgad.16=NULL() THEN RETURN 5 /* ANY gadget not created */
- /* Open window */
- winidcmp=IDCMP_CLOSEWINDOW+IDCMP_GADGETUP+IDCMP_ACTIVEWINDOW+IDCMP_MOUSEBUTTONS+IDCMP_RAWKEY
- winflags=WFLG_CLOSEGADGET+WFLG_DEPTHGADGET+WFLG_DRAGBAR+WFLG_ACTIVATE
- port=OpenPort(portname)
- IF ~port THEN RETURN 5
- /* Centered beneath mouseptr */
- ymouse=GETVALUE(scr,16,2,"N")
- xmouse=GETVALUE(scr,18,2,"N")
- /* taglist */
- wtagl=MAKEPOINTER(0,0,88,MEMF_CLEAR)
- IF wtagl=NULL() THEN RETURN 5
- wname=MAKEPOINTER(wtagl,0,Length(wintitle)+1,MEMF_CLEAR)
- IF wname=NULL() THEN RETURN 5
- CALL Export(wname,wintitle)
- wzipdims=MAKEPOINTER(wtagl,0,8,MEMF_CLEAR)
- IF wzipdims=NULL() THEN RETURN 5
- CALL SETVALUE(wzipdims,4,2,"N",winwid)
- CALL SETVALUE(wzipdims,6,2,"N",bordert)
- CALL SETTAGSLOT(wtagl,0,WA_LEFT,"N",Max(xmouse-winwid/2,0))
- CALL SETTAGSLOT(wtagl,1,WA_TOP,"N",Max(ymouse-winhi/2,0))
- CALL SETTAGSLOT(wtagl,2,WA_INNERWIDTH,"N",winwid)
- CALL SETTAGSLOT(wtagl,3,WA_INNERHEIGHT,"N",winhi)
- CALL SETTAGSLOT(wtagl,4,WA_IDCMP,"N",winidcmp)
- CALL SETTAGSLOT(wtagl,5,WA_FLAGS,"N",winflags)
- CALL SETTAGSLOT(wtagl,6,WA_TITLE,"P",wname)
- CALL SETTAGSLOT(wtagl,7,WA_GADGETS,"P",gad)
- CALL SETTAGSLOT(wtagl,8,WA_PUBSCREEN,"P",scr)
- CALL SETTAGSLOT(wtagl,9,WA_ZOOM,"P",wzipdims)
- CALL SETTAGSLOT(wtagl,10,TAG_DONE,"N",0)
- win=OpenWindowTagList(portname,NULL(),wtagl,0)
- IF win=NULL() THEN RETURN 5
- rp=GETWINDOWRASTPORT(win)
- CALL DrawBevelBox(rp,gadx,gadmaxy-gadh-5,gadw,2,GTBB_RECESSED,-1,TAG_DONE,0)
- CALL GT_RefreshWindow(win,NULL())
- RETURN 0
- PROC gui: /* Check gadgets [2.1] */
- IF check.10 THEN CALL ScreenToFront(scr)
- closed=0
- DO WHILE closed=0
- CALL WaitPkt(portname)
- CALL messy
- END
- IF check.10 THEN CALL ScreenToBack(scr)
- IF (check.13 | check.11) & closed~=3 THEN
- DO
- default=""
- DO id=1 TO 12
- default=default||D2C(check.id,1)||D2C(cycle.id,1)||D2C(val.id,2)
- END
- default=default||D2C(0,4)
- DO i=1 TO 1+check.13
- ok=Open(prefs,preff.i,"W")
- IF ok THEN
- DO
- CALL WriteCh(prefs,default)
- CALL Close(prefs)
- END
- END
- END
- ELSE
- IF closed=4 THEN
- DO
- ok=Open(prefs,preff.2,"R")
- IF ~ok THEN CALL bye(0)
- default=ReadCh(prefs,52)
- CALL Close(prefs)
- IF Length(default)<52 THEN CALL bye(0)
- ok=Open(prefs,preff.1,"W")
- CALL WriteCh(prefs,default)
- CALL Close(prefs)
- END
- IF closed>2 THEN CALL bye(0)
- RETURN 0
- PROC messy: /* Process messages [2.1] */
- IF port=0 THEN RETURN
- DO FOREVER
- msg=GetPkt(portname)
- IF msg='0000 0000'x THEN LEAVE
- msgclass=GetArg(msg,0)
- code=GetArg(msg,1)
- qual=GetArg(msg,2)
- gadid=GetArg(msg,9)
- CALL Reply(msg,0)
- IF msgclass=IDCMP_RAWKEY THEN
- DO
- id=code-79
- SELECT
- WHEN id<14 & id>0 THEN /* F-keys */
- DO
- msgclass=IDCMP_GADGETUP
- type=(qual//4)//3
- IF id>8 THEN type=1
- gadid=id*3+type
- IF type=2 THEN CALL ActivateGadget(intgad.id,win,NULL())
- IF type=1 THEN code=~check.id
- IF (id<6 | id>8) & type=1 THEN CALL GT_SetGadgetAttrs(checkgad.id,win,NULL(),GTCB_CHECKED,code)
- IF type=0 THEN code=(cycle.id+1)//labs.id
- IF id<9 & type=0 THEN CALL GT_SetGadgetAttrs(cyclegad.id,win,NULL(),GTCY_ACTIVE,code)
- END
- WHEN code>66 & code<71 THEN closed=code-66 /* Enter|Return|Esc|Del */
- OTHERWISE NOP
- END
- END
- SELECT
- WHEN msgclass=IDCMP_CLOSEWINDOW THEN closed=4
- WHEN check.9 & (msgclass=IDCMP_ACTIVEWINDOW | msgclass=IDCMP_MOUSEBUTTONS) THEN CALL ActivateGadget(intgad.1,win,NULL())
- WHEN msgclass=IDCMP_GADGETUP THEN
- DO
- type=gadid//3
- id=gadid%3
- SELECT
- WHEN id>13 THEN closed=id-13 /* Ok | Go | Cancel */
- WHEN type=2 THEN /* Integer */
- DO
- old=val.id
- specialinfo=GETVALUE(intgad.id,34,4,"P")
- val.id=GETVALUE(specialinfo,28,4,"N")
- check.id=check.9 | check.id | old~=val.id
- IF old~=val.id | check.9 THEN CALL GT_SetGadgetAttrs(checkgad.id,win,NULL(),GTCB_CHECKED,check.id)
- END
- WHEN type=1 THEN /* Checkbox */
- DO
- check.id=code
- IF id<6 & check.id~=0 & check.9 THEN CALL ActivateGadget(intgad.id,win,NULL())
- END
- OTHERWISE /* Cycle */
- DO
- cycle.id=code
- check.id=1
- IF id<6 THEN CALL GT_SetGadgetAttrs(checkgad.id,win,NULL(),GTCB_CHECKED,check.id)
- IF id<6 & check.9 THEN CALL ActivateGadget(intgad.id,win,NULL())
- END
- END
- END
- OTHERWISE NOP
- END
- END
- RETURN
- PROC guiclean: /* Clean up GUI [2.1] */
- IF cleangui THEN
- DO
- IF scr~=NULL() THEN CALL UnLockPubScreen(NULL(),scr)
- IF win~=NULL() THEN CALL CloseWindow(win)
- IF gad~=NULL() THEN CALL FreeGadgets(gad)
- IF scrvinfo~=NULL() THEN CALL FreeVisualInfo(scrvinfo)
- IF port THEN CALL ClosePort(portname)
- port=0
- /* Free allocated structures (some were maybe not allocated, but APIG handles this) */
- DO id=1 TO gads
- CALL FREETHIS(newgadx.id)
- CALL FREETHIS(newgadxi.id)
- CALL FREETHIS(newgadxb.id)
- CALL FREETHIS(glabels.id)
- END
- CALL FREETHIS(wtagl)
- CALL FREETHIS(glistptr)
- cleangui=0
- END
- RETURN
- PROC chosenobjs: /* Selected objects. Returns 0, if OK [2.1] */
- /* Selected objects */
- ovalrescan=0
- txtrescan=0
- txt=0
- oval=0
- len=0
- FirstObject "SELECTED"
- o=RESULT
- IF o~=0 THEN
- DO
- cnt=0
- DO UNTIL o=0
- gobj.cnt=o
- NextObject o "SELECTED"
- o=RESULT
- cnt=cnt+1
- END
- /* Search oval and textblock */
- DO i=0 TO cnt-1 WHILE oval=0 | txt=0
- GetObjectType gobj.i
- IF RESULT=7 THEN txt=gobj.i
- IF RESULT=6 THEN oval=gobj.i
- END
- END
- /* Selected text */
- IF txt=0 THEN
- DO
- Status "PARAPOS"
- pos=RESULT
- IF Words(pos)=4 THEN
- DO
- Extract
- text=RESULT
- MoveToPara Word(pos,1) Word(pos,2)
- len=Length(text)
- txtrescan=1
- END
- ELSE
- IF rescan THEN
- DO
- IF Word(pos,2)~=0 THEN MoveToPara Word(pos,1) 0
- Status "PARACHARS"
- len=RESULT
- text=""
- txtrescan=1
- END
- END
- IF oval=0 THEN
- oval=oldoval
- ELSE
- ovalrescan=1
- IF txt=0 & len=0 THEN
- objs=oldobjs
- ELSE
- txtrescan=1
- IF len=0 THEN len=oldlen
- IF txt=0 & txtrescan=0 THEN txt=oldtxt
- IF (txt=0 & len=0 | oval=0 | test=2) & test~=3 THEN
- DO
- ShowMessage 1 1 noselect
- IF closed~=2 THEN
- CALL bye(5)
- ELSE
- RETURN 5
- END
- oldoval=oval
- oldtxt=txt
- oldlen=len
- oldobjs=objs
- RETURN 0
- PROC options: /* Process inputs [2.1] */
- /* Defaults: */
- ssize=360
- rdim=""
- hdim=""
- start="+0"
- rrot=""
- /* Convert vars */
- IF check.1 THEN ssize=SubStr("+-",cycle.1+1,1)||val.1
- IF check.2 THEN rdim=SubStr("-+",cycle.2+1,1)||val.2
- IF check.3 THEN hdim=SubStr("-+",cycle.3+1,1)||val.3
- IF check.4 THEN start=SubStr("-+",cycle.4+1,1)||val.4
- IF check.5 THEN
- IF cycle.5=3 & txt>0 THEN
- rrot="="
- ELSE
- rrot=SubStr("+-",cycle.5+1,1)||val.5
- del=SubStr("+-=",cycle.6+1,1)
- grp=SubStr("+-",cycle.7+1,1)
- adjust=SubStr("+-=",cycle.8+1,1)
- rescan=check.12 | rescan
- /* Correct inputs */
- IF ssize=0 THEN ssize=0.01 /* no division by zero */
- absstart=0
- IF Verify(Left(start,1),"+-","m")=0 THEN
- DO
- absstart=1
- start=Max(Min(start,360),0)
- END
- ELSE
- start=Max(Min(start,180),-180)
- IF rdim="" THEN
- ssize=Max(Min(ssize,360),-360)
- ELSE
- rdim=Max(Min(rdim,100),-100)
- IF rdim=0 THEN rdim=0.01
- IF hdim="" THEN
- hdim=rdim
- ELSE
- hdim=Max(Min(hdim,100),-100)
- IF hdim=0 THEN hdim=0.01
- /* Relative rotation */
- drot=0
- IF Verify(Left(rrot,1),"+-","m")>0 THEN
- DO
- IF Length(rrot)=1 THEN
- drot=rrot||"90"
- ELSE
- drot=Max(Min(rrot,180),-180)
- rrot=""
- END
- ELSE
- IF rrot~="" & rrot~="=" THEN rrot=Max(Min(rrot,360),-360)
- RETURN
- PROC pointnoval: /* Decimal point & process oval [2.1] */
- /* Use decimal point */
- GetDocItemPrefs "DECIMAL"
- deci=RESULT
- DocItemPrefs "DECIMAL PERIOD"
- /* Examine oval */
- IF ovalrescan THEN
- DO
- GetObjectRotation oval
- orot=RESULT
- GetObjectCoords oval
- PARSE VAR RESULT page x y rx ry
- rx=rx/2
- ry=ry/2
- xm=x+rx
- ym=y+ry
- /* Use oval's text flow settings */
- GetObjectParams oval "TEXTFLOW FLOWDIST"
- flow=Word(RESULT,1)
- IF Left(flow,5)="Right" THEN
- flow="Right"
- ELSE
- IF Left(flow,4)="Left" THEN flow="Left"
- fld=Word(RESULT,2)
- IF orot~=0 THEN SetObjectRotation oval 0
- IF del="=" THEN
- DO
- SelectObject oval
- Copy
- END
- IF del~="-" & grp="" THEN DeleteObject oval
- END
- TextBlockPrefs "TEXTFLOW" flow "FLOWDIST" fld
- RETURN
- PROC textblock: /* Process textblock [2.1] */
- /* Examine textblock */
- IF txtrescan THEN
- DO
- GetTextBlockText txt
- text=RESULT
- text=rembad(text)
- len=Length(text)
- oldlen=len
- GetObjectTypeSpecs txt "SIZE LEADING WIDTH OBLIQUE POSITION CASE STYLE COLOR FONT"
- PARSE VAR RESULT tsize tlead twid tobl tpos tcase tstyl tcol tfont
- GetObjectCoords txt
- txtw=Word(RESULT,4)
- h=Word(RESULT,5)
- /* Get rotation */
- IF rrot="=" THEN
- DO
- GetObjectRotation txt
- rrot=RESULT
- END
- IF del="+" THEN DeleteObject txt
- END
- TextBlockTypePrefs "SIZE" tsize "LEADING" tlead "WIDTH" twid "OBLIQUE" tobl "POSITION" tpos "CASE" tcase "STYLE" tstyl "COLOR" tcol "FONT" tfont
- RETURN
- PROC bodytext: /* Process selected text [2.1] */
- IF ~txtrescan THEN RETURN
- IF rrot="=" THEN rrot=0
- txtw=0
- /* Remove CR at the end */
- IF C2X(Right(text,1))="0A" THEN
- DO
- len=len-1
- text=Left(text,len)
- END
- text=rembad(text)
- /* Create textobjects */
- noextr=text>""
- DO i=1 TO len
- IF noextr THEN
- x=SubStr(text,i,1)
- ELSE
- DO
- Extract
- x=rembad(RESULT)
- text=text||x
- END
- DO
- Cursor "RIGHT"
- specs.i=gettexttypespecs()
- END
- TextBlockTypePrefs specs.i
- IF Verify(x,'";= ',"M") THEN x='"'||x||'"'
- DrawTextBlock page xm ym x
- /* Save size & number */
- objs=objs+1
- GetObjectCoords 0
- PARSE VAR RESULT x x x objw.objs objh.objs
- txtw=txtw+objw.objs
- CurrentObject
- obj.i=RESULT
- /* Have a look at the requester */
- IF closed=2 THEN
- DO
- CALL messy
- IF closed>2 THEN
- DO
- CALL remobjs
- closed=2
- broken=1
- oldlen=0
- rescan=2
- oldobjs=0
- RETURN
- END
- ELSE
- IF closed=1 THEN closed=2
- END
- END
- RETURN
- PROC initwrap: /* Init wrapping [2.1] */
- PI=3.141593
- smin=0.1 /* Minimal size */
- sizerad=ssize/180*PI
- angstep=sizerad/txtw
- IF absstart THEN
- angstart=start/180*PI
- ELSE
- angstart=(ssize-360+start*2)/360*PI
- adone=angstart
- flip=Sign(ssize)
- ssize=ssize<0
- fr=0
- IF rdim="" THEN
- qr=1
- ELSE
- DO
- fr=(1-Abs(rdim)/100)/sizerad*Sign(rdim)
- IF rdim<0 THEN
- fr0=Abs(rdim)/100
- ELSE
- fr0=1
- END
- IF hdim="" THEN
- qh=1
- ELSE
- DO
- fh=(1-Abs(hdim)/100)/sizerad*Sign(hdim)
- IF hdim<0 THEN
- fh0=Abs(hdim)/100
- ELSE
- fh0=1
- END
- wdone=0
- o=0
- RETURN
- PROC wrap: /* Wrap it! [2.1] */
- DO n=1 TO len
- char=SubStr(text,n,1)
- IF Verify(char,'";= ',"M") THEN char='"'||char||'"'
- IF txt>0 & txtrescan THEN
- DO
- /* Draw and get size */
- DrawTextBlock page xm ym char
- GetObjectCoords 0
- objw.n=Word(RESULT,4)
- objh.n=h
- CurrentObject
- objs=objs+1
- obj.n=RESULT
- END
- /* Number and size saved before */
- cw=objw.n
- ch=objh.n
- o=obj.n
- /* What's done so far */
- f=angstart-angstep*(wdone+cw/2)
- wdone=wdone+cw
- /* Adjusting */
- IF adjust="=" THEN
- DO
- asize=cw/radius(adone,rx,ry,fr)
- f=adone-asize/2*flip
- adone=adone-asize*flip
- END
- ELSE
- IF adjust~="" THEN
- DO
- carc=radius(f,rx,ry,fr)*angstep*cw
- IF adjust="+" THEN ch=ch/cw*carc
- cw=carc
- END
- /* Spirals */
- IF rdim~="" THEN qr=fr0+fr*(f-angstart)
- IF hdim~="" THEN
- DO
- qh=fh0+fh*(f-angstart)
- ch=Max(ch*qh,smin)
- cw=Max(cw*qh,smin)
- END
- x=rx*Sin(f)*qr-cw/2
- y=ry*Cos(f)*qr-ch/2
- /* Rotation */
- IF rrot="" THEN
- rot=720-Trunc(Atan(ry/rx*Tan(f))/PI*180)+180*((Cos(f)>0)+ssize)+drot
- /* Circles only: rot=Trunc(ssize*180+180-f/PI*180)+drot */
- ELSE
- rot=rrot
- rot=rot//360
- /* Centre char on the oval */
- IF ~txtrescan THEN
- DO
- IF txt=0 THEN TextBlockTypePrefs specs.n
- DrawTextBlock page x+xm y+ym char
- CurrentObject
- objs=objs+1
- obj.n=RESULT
- o=obj.n
- IF cw~=objw.n | ch~=objh.n THEN SetObjectCoords o page x+xm y+ym cw ch
- END
- ELSE
- SetObjectCoords o page x+xm y+ym cw ch
- SetObjectRotation o rot
- /* Have a look at the requester */
- IF closed=2 THEN
- DO
- CALL messy
- IF closed>2 THEN
- DO
- CALL remobjs
- closed=2
- broken=1
- IF txt>0 & txtrescan THEN
- DO
- oldtxt=0
- oldlen=0
- oldobjs=0
- rescan=2
- END
- RETURN
- END
- ELSE
- IF closed=1 THEN closed=2
- END
- END
- RETURN
- PROC group: /* Group objects [2.1] */
- /* Hide oval */
- IF grp="-" THEN
- DO
- SelectObject oval
- SetObjectParams oval "LINEWT NONE FILL TRANSPARENT"
- END
- /* Rotate oval back */
- IF orot~=0 & del="-" & grp="" THEN SetObjectRotation oval orot
- /* Group chars */
- SelectObject
- DO n=1 TO objs
- SelectObject obj.n "MULTIPLE"
- END
- IF grp~="" & ovalrescan THEN SelectObject oval "MULTIPLE"
- Group
- objs=0
- IF orot~=0 & ovalrescan THEN SetObjectRotation 0 orot
- Redraw
- RETURN
- PROC bye: /* CALL bye(returnvalue) You MUST use this instead of EXIT! [2.1] */
- PARSE ARG errnr
- /* Restore decimal delimitter */
- IF deci~="" THEN DocItemPrefs "DECIMAL" deci
- CALL guiclean
- DO i=1 TO 3
- IF lib.i THEN CALL RemLib(library.i)
- END
- CALL remobjs
- EXIT errnr
- RETURN
- PROC remobjs: /* Delete drawn objects [2.1] */
- IF objs>0 THEN
- DO
- SelectObject
- DO n=1 TO objs
- SelectObject obj.n "MULTIPLE"
- END
- Group
- DeleteObject
- objs=0
- END
- RETURN
- PROC SYNTAX: /* SYNTAX & ERROR handling [1.3] */
- et=ErrorText(RC)
- ERROR:
- line=SIGL
- nr=RC
- IF et="" THEN et=fwerrtext.nr
- IF nr>5 THEN ShowMessage 1 1 replacepat(replacepat(replacepat(errtext,"%n",nr),"%l",line),"%t",et)
- CALL bye(nr)
- RETURN
- PROC rembad: PROCEDURE /* newstr=rembad(str) [1.1] */
- /* Replace unprintable characters by spaces */
- PARSE ARG t
- bad=XRange("00"x,"1F"x)||XRange("7F"x,"9F"x)
- i=Verify(t,bad,"m")
- l=Length(t)
- DO WHILE i>0
- t=Left(t,i-1) Right(t,l-i)
- i=Verify(t,bad,"m")
- END
- RETURN t
- PROC replacepat: PROCEDURE /* newstr=replacepat(str,pat,replc) [1.2] */
- /* Replace all occurences of a pattern in a string by another one */
- PARSE ARG str,pat,replc
- p=Pos(pat,str)
- DO WHILE p>0
- str=Left(str,p-1)||replc||SubStr(str,p+Length(pat))
- p=Pos(pat,str)
- END
- RETURN str
- PROC getlanguage: PROCEDURE /* language=getlanguage() [2.1] */
- /* Get preferred language */
- ok=Open(prefs,"ENV:Language","R")
- IF ok THEN
- DO
- language=ReadLn(prefs)
- CALL Close(prefs)
- END
- RETURN language
- PROC gettexttypespecs: PROCEDURE /* specs=gettexttypespecs() [1.3] */
- Status "FONTSIZE"
- p="SIZE" RESULT
- Status "FONTLEADING"
- p=p "LEADING" RESULT
- Status "FONTWIDTH"
- p=p "WIDTH" RESULT
- Status "FONTOBLIQUE"
- p=p "OBLIQUE" RESULT
- Status "FONTPOSITION"
- p=p "POSITION" RESULT
- Status "FONTCASE"
- p=p "CASE" RESULT
- Status "FONTSTYLE"
- p=p "STYLE" RESULT
- Status "FONTCOLOR"
- p=p "COLOR" RESULT
- Status "FONTNAME"
- p=p "FONT" RESULT
- RETURN p
- PROC radius: PROCEDURE /* rad=radius(angle,rx,ry,v) [1.4] */
- ARG a,rx,ry,v
- rx=rx*Cos(a)
- ry=ry*Sin(a)
- r=(1-a*v)*Sqrt(rx*rx+ry*ry)
- RETURN r
- PROC dump: PROCEDURE /* CALL dump(var[,infostr]) [1.3] */
- /* Dump a variable, %v in infostring determines it's place (debug-only) */
- PARSE ARG v,info
- IF info="" THEN info="%v"
- ShowMessage 1 1 '"'||replacepat(info,"%v",v)||'" "" "" "Ok" "" ""'
- RETURN
-