This file is indexed.

/usr/share/ncarg/nclex/gsun/gsun05n.ncl is in libncarg-data 6.3.0-6build1.

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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
load "$NCARG_ROOT/lib/ncarg/nclscripts/csm/gsn_code.ncl"

begin
  data_dir  = ncargpath("data")   ; Get ready to open three netCDF files.
  cdf_file1 = addfile(data_dir + "/cdf/941110_P.cdf","r")
  cdf_file2 = addfile(data_dir + "/cdf/sstdata_netcdf.nc","r")
  cdf_file3 = addfile(data_dir + "/cdf/Pstorm.cdf","r")

  psl = cdf_file1->Psl    ; Store some data from the three netCDF
  sst = cdf_file2->sst    ; files to local variables.
  pf  = cdf_file3->p

  psl@nlon = dimsizes(psl&lon)  ; Store the sizes of the lat/lon
  psl@nlat = dimsizes(psl&lat)  ; arrays as attributes of the psl
  pf@nlon  = dimsizes(pf&lon)   ; and pf variables.
  pf@nlat  = dimsizes(pf&lat)

  sst!1    = "lat"                 ; Name dimensions 0 and 1 of sst
  sst!2    = "lon"                 ; "lat" and "lon.
  sst&lat  = cdf_file2->lat        ; Create coordinate variables
  sst&lon  = cdf_file2->lon        ; for sst and store the sizes
  sst@nlon = dimsizes(sst&lon)     ; of the arrays as attributes 
  sst@nlat = dimsizes(sst&lat)     ; of sst.

  wks = gsn_open_wks("x11","gsun05n") ; Open a workstation.

;----------- Begin first plot -----------------------------------------

  resources = True
  
  resources@sfXCStartV = min(psl&lon)   ; Define where contour plot
  resources@sfXCEndV   = max(psl&lon)   ; should lie on the map plot.
  resources@sfYCStartV = min(psl&lat)
  resources@sfYCEndV   = max(psl&lat)

  map = gsn_contour_map(wks,psl,resources) ; Draw contours over a map.

;----------- Begin second plot -----------------------------------------

  getvalues wks                   ; Retrieve the default color map.
    "wkColorMap" : cmap
  end getvalues

  cmap(0,:) = (/1.,1.,1./)        ; Change background to white.
  cmap(1,:) = (/0.,0.,0./)        ; and foreground to black.
  gsn_define_colormap(wks, cmap)

  resources@mpProjection = "Orthographic" ; Change the map projection.
  resources@mpCenterLonF = 180.           ; Rotate the projection.
  resources@mpFillOn     = True           ; Turn on map fill.
  resources@mpFillColors = (/0,-1,28,-1/) ; Fill land and leave oceans
                                          ; and inland water transparent.

  resources@vpXF      = 0.1    ; Change the size and location of the 
  resources@vpYF      = 0.9    ; plot on the viewport.
  resources@vpWidthF  = 0.7
  resources@vpHeightF = 0.7

  mnlvl = 0                        ; Minimum contour level.
  mxlvl = 28                       ; Maximum contour level.
  spcng = 2                        ; Contour level spacing.
  ncn   = (mxlvl-mnlvl)/spcng + 1  ; Number of contour levels.

  resources@cnLevelSelectionMode = "ManualLevels" ; Define your own
  resources@cnMinLevelValF       = mnlvl          ; contour levels.
  resources@cnMaxLevelValF       = mxlvl
  resources@cnLevelSpacingF      = spcng

  resources@cnLineThicknessF     = 2.0   ; Double the line thickness.

  resources@cnFillOn           = True  ; Turn on contour level fill.
  resources@cnMonoFillColor    = True  ; Use one fill color.
  resources@cnMonoFillPattern  = False ; Use multiple fill patterns.
  resources@cnFillPatterns     = new((/ncn+1/),integer) ; Only fill
  resources@cnFillPatterns(:)  = -1                     ; last two
  resources@cnFillPatterns(ncn-1:ncn) = 17              ; contour levels.

  resources@cnLineDrawOrder      = "Predraw" ; Draw lines and filled
  resources@cnFillDrawOrder      = "Predraw" ; areas before map gets
                                             ; drawn.

  resources@tiMainString = "~F26~" + cdf_file2@title
  
  resources@sfXCStartV = min(sst&lon)   ; Define where contour plot
  resources@sfXCEndV   = max(sst&lon)   ; should lie on the map plot.
  resources@sfYCStartV = min(sst&lat)
  resources@sfYCEndV   = max(sst&lat)

  map = gsn_contour_map(wks,sst(0,:,:),resources) ; Draw contours over a map.

;----------- Begin third plot -----------------------------------------

  delete(resources)  ; Start with a new list of resources.
  resources = True

  resources@tiXAxisString = "~F25~longitude"
  resources@tiYAxisString = "~F25~latitude"

  resources@cnFillOn              = True     ; Turn on contour fill.
  resources@cnLineLabelsOn        = False    ; Turn off line labels.
  resources@cnInfoLabelOn         = False    ; Turn off info label.
  resources@pmLabelBarDisplayMode = "Always" ; Turn on a label bar.
  resources@lbPerimOn             = False    ; Turn off label bar perim.

  resources@sfXCStartV = min(pf&lon)   ; Define where contour plot
  resources@sfXCEndV   = max(pf&lon)   ; should lie on the map plot.
  resources@sfYCStartV = min(pf&lat)
  resources@sfYCEndV   = max(pf&lat)

  resources@mpProjection = "LambertEqualArea"  ; Change the map projection.
  resources@mpCenterLonF = (pf&lon(pf@nlon-1) + pf&lon(0))/2
  resources@mpCenterLatF = (pf&lat(pf@nlat-1) + pf&lat(0))/2

  resources@mpLimitMode = "LatLon"    ; Limit the map view.
  resources@mpMinLonF   = min(pf&lon)
  resources@mpMaxLonF   = max(pf&lon)
  resources@mpMinLatF   = min(pf&lat)
  resources@mpMaxLatF   = max(pf&lat)
  resources@mpPerimOn   = True        ; Turn on map perimeter.

  resources@tiMainString = "~F26~January 1996 storm" ; Set a title.

  resources@vpXF      = 0.1    ; Change the size and location of the 
  resources@vpYF      = 0.9    ; plot on the viewport.
  resources@vpWidthF  = 0.7
  resources@vpHeightF = 0.7

  resources@gsnScale = True  ; Force X/Y axes labels to be the same size.
  resources@gsnFrame = False ; Don't advance frame.

  map = gsn_contour_map(wks,pf(0,:,:)*0.01,resources) ; Convert pf to "mb" and
                                                     ; draw contours over map.
  txres               = True   ; Set some resources
  txres@txFontHeightF = 0.025  ; for a text string.
  txres@txFontColor   = 4
  gsn_text_ndc(wks,"~F25~Pressure (mb)",.45,.25,txres) ; Draw a text string.
                                                       ; on the viewport.
  frame(wks)   ; Advance the frame.
  
;---------- Begin fourth plot ------------------------------------------

  delete(resources@tiXAxisString)  ; Delete some resources you don't
  delete(resources@tiYAxisString)  ; need anymore.
  delete(resources@gsnFrame)

  delete(cmap)
  cmap = (/(/1.00, 1.00, 1.00/), (/0.00, 0.00, 0.00/), \
           (/.560, .500, .700/), (/.300, .300, .700/), \
           (/.100, .100, .700/), (/.000, .100, .700/), \
           (/.000, .300, .700/), (/.000, .500, .500/), \
           (/.000, .400, .200/), (/.000, .600, .000/), \
           (/.000, 1.00, 0.00/), (/.550, .550, .000/), \
           (/.570, .420, .000/), (/.700, .285, .000/), \
           (/.700, .180, .000/), (/.870, .050, .000/), \
           (/1.00, .000, .000/), (/0.00, 1.00, 1.00/), \
           (/.700, .700, .700/)/)

  gsn_define_colormap(wks, cmap)  ; Define a new color map.

  resources@mpFillOn              = True         ; Turn on map fill.
  resources@mpFillAreaSpecifiers  = (/"Water","Land","USStatesWater"/)
  resources@mpSpecifiedFillColors = (/17,18,17/)
  resources@mpAreaMaskingOn       = True            ; Indicate we want to 
  resources@mpMaskAreaSpecifiers  = "USStatesLand"  ; mask land.
  resources@mpPerimOn             = True            ; Turn on a perimeter.
  resources@mpGridMaskMode        = "MaskLand"      ; Mask grid over land.
  resources@cnFillDrawOrder       = "Predraw"       ; Draw contours first.

  resources@cnLevelSelectionMode = "ExplicitLevels" ; Define own levels.
  resources@cnLevels             = fspan(985.,1045.,13)

  resources@lbTitleString  = "~F25~pressure (mb)" ; Title for label bar.
  resources@cnLinesOn      = False         ; Turn off contour lines.
  resources@pmLabelBarSide = "Bottom"      ; Change orientation of
  resources@lbOrientation  = "Horizontal"  ; label bar.

  map = gsn_contour_map(wks,pf(1,:,:)*0.01,resources)

  delete(map)          ; Clean up.
  delete(resources)
  delete(txres)
end