This file is indexed.

/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