/usr/share/ferret-vis/jnls/go/scalemark.jnl is in ferret-vis 6.9.3-4build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 | \cancel mode verify
! scalemark.jnl
! 6/99 *sh*
! Description: Plot an "I beam" documenting a scale on a plot
! This script is particularly designed to be a companion for trackplot.jnl
! See trackplot_demo for examples.
! Usage:              $1   $2     $3     $4     $5        $6         $7        $8
! yes?  GO scalemark xloc yloc [value] [user] [label] [units/in] [baseline] [line no.] 
! $1 - X coordinate of the lower left hand corner of the scale marker
! $2 - Y coordinate of the lower left hand corner of the scale marker
! $3 - [optional] magnitude (range) in data units to be shown by the scale.
!		Default = 1
! $4 - [optional] If "user" then coordinates are in "user units".
!		Default = coords in inches 
! $5 - [optional] label to be written at center of scale.
!		Default = magnitude as text
! $6 - [optional] units/inch to be shown by scale
!		Default normally pre-set by the trackplot command
! $7 - [optional] baseline (a.k.a. offset) of variable plotted
!		(e.g. value represented by plot crossing the trackline)
!		Default =  normally pre-set by the trackplot command
! $8 - [optional] line number (style) to match on the screen.
!		Default = 1 (use if one line was drawn in the last plot command)
! example
! Define synthetic data
!       yes? LET xpts = 230 - L[L=1:80]
!       yes? LET ypts = 30 + 20*SIN(L[L=1:80]/30)
!       yes? LET val  = RANDN(L[L=1:80])
!
! Draw base map
!       yes? go basemap x=130E:120W Y=10n:60n 20
!       yes? plot/vs/over/line/title="track" xpts, ypts
!
! Auto-scaled plot, then manually scaled plot
!	yes? GO trackplot plot/vs/over/line=2/title="my data" xpts, ypts, val
!       yes? GO scalemark 150 30 1 user
!	yes? GO trackplot plot/vs/over/line=4/title="scaled" xpts, ypts, val 3
!	yes? GO scalemark 0.5 6.2 2 nouser "2 units"
! argument check
QUERY/IGNORE $1"<usage: yes? GO scalemark xloc yloc [value] ["user"] [label] [units/in] [line no.]"
QUERY/IGNORE $2"<usage: yes? GO scalemark xloc yloc [value] ["user"] [label] [units/in] [line no.]"
! set default argument values
LET/QUIET SMKmagnitude = $3"1"
IF $6"0|*>1" THEN
   LET/QUIET SMKunitsperinch = $6
ELSE
   LET/QUIET SMKunitsperinch = ($TRACKPLOTscale"1")  
ENDIF
IF $5"0|*>1" THEN
   DEFINE SYMBOL SMKlabel = $5
ELSE
   DEFINE SYMBOL SMKlabel = `SMKmagnitude`
ENDIF
IF $7"0|*>1" THEN
   LET/QUIET SMKoffset = $7
ELSE
   LET/QUIET SMKoffset =  ($TRACKPLOToffset"0")
ENDIF
LET/QUIET SMKline = $8"1"
! size of label text (inches)
LET/QUIET SMKtxt_size = 0.1
! draw the scale mark
IF  $4"0|USER>1|*>0"  THEN
! using user units (typ. lat/lon degrees)
   LET/QUIET SMKhsize = 0.01 * (($xaxis_max)-(($xaxis_min)))		! horizontal size
   LET/QUIET SMKmap_yscale =   (($yaxis_max)-(($yaxis_min)))/ ($ppl$ylen)  ! degrees/inch
   LET/QUIET SMKvsize =  SMKmap_yscale * SMKmagnitude/SMKunitsperinch	! vertical   size
! ... I-beam
   PPL ALINE `SMKline`,$1,$2,`$1+SMKhsize*2`,$2				 ! bottom
   PPL ALINE `SMKline`,`$1+SMKhsize`,$2,`$1+SMKhsize`,`$2+SMKvsize`
   PPL ALINE `SMKline`,`$1+SMKhsize*0.5`,`$2+SMKvsize`,`$1+SMKhsize*1.5`,`$2+SMKvsize` ! top
! ... labels
   LET/QUIET SMKtxt_height = SMKtxt_size * SMKmap_yscale
   LABEL `$1+SMKhsize*2.1`,`$2+SMKvsize/2-SMKtxt_height/2`,-1,0,`SMKtxt_size` "($SMKlabel)"
   LABEL `$1+SMKhsize*2.4`,`$2-SMKtxt_height*0.4`,-1,0,`SMKtxt_size*0.8` "`SMKoffset`"
ELSE
! using inches
   LET/QUIET SMKhsize = 0.01 * ($ppl$xlen)		! horizontal size
   LET/QUIET SMKvsize = SMKmagnitude/SMKunitsperinch	! vertical   size
! ... I-beam
   PPL ALINE/NOUSER `SMKline`,$1,$2,`$1+SMKhsize*2`,$2				 ! bottom
   PPL ALINE/NOUSER `SMKline`,`$1+SMKhsize`,$2,`$1+SMKhsize`,`$2+SMKvsize`
   PPL ALINE/NOUSER `SMKline`,`$1+SMKhsize*0.5`,`$2+SMKvsize`,`$1+SMKhsize*1.5`,`$2+SMKvsize` ! top
! ... labels
   LABEL/NOUSER `$1+SMKhsize*2.1`,`$2+SMKvsize/2-SMKtxt_size/2`,-1,0,`SMKtxt_size` "($SMKlabel)"
   LABEL/NOUSER `$1+SMKhsize*2.5`,`$2-SMKtxt_size*0.4`,-1,0,`SMKtxt_size*0.8`  "`SMKoffset`"
ENDIF
! clean up
cancel symbol SMK*
cancel variable SMK*
set mode/last verify
 |