This file is indexed.

/usr/share/doc/cl-plplot/examples/x18l.lisp is in cl-plplot 0.6.0-4.

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
;;;;
;;;; PLplot example 18
;;;;
;;;; hazen 07/10
;;;;

(in-package :plplot-examples)

(defun example18 (&optional (dev default-dev))
  (plsdev dev)
  (plinit)
  (let ((opt (vector 1 0 1 0))
	(alt (vector 20.0 35.0 50.0 65.0))
	(az (vector 30.0 40.0 50.0 60.0)))
    (labels ((test-poly (k)
	       (let ((draw (vector (vector 1 1 1 1)
				   (vector 1 0 1 0)
				   (vector 0 1 0 1)
				   (vector 1 1 0 0))))
		 (pladv 0)
		 (plvpor 0.0 1.0 0.0 0.9)
		 (plwind -1.0 1.0 -0.9 1.1)
		 (plcol0 1)
		 (plw3d 1.0 1.0 1.0 -1.0 1.0 -1.0 1.0 -1.0 1.0 (aref alt k) (aref az k))
		 (plbox3 "bnstu" "x axis" 0.0 0
			 "bnstu" "y axis" 0.0 0
			 "bcdmnstuv" "z axis" 0.0 0)
		 (plcol0 2)
		 (labels ((theta (a)
			    (/ (* 3.14159 2.0 a) 20.0))
			  (phi (a)
			    (/ (* 3.14159 a) 20.1)))
		   (dotimes (i 20)
		     (dotimes (j 20)
		       (plpoly3 (vector (* (sin (phi j)) (cos (theta i)))
					(* (sin (phi (+ j 1))) (cos (theta i)))
					(* (sin (phi (+ j 1))) (cos (theta (+ i 1))))
					(* (sin (phi j)) (cos (theta (+ i 1))))
					(* (sin (phi j)) (cos (theta i))))
				(vector (* (sin (phi j)) (sin (theta i)))
					(* (sin (phi (+ j 1))) (sin (theta i)))
					(* (sin (phi (+ j 1))) (sin (theta (+ i 1))))
					(* (sin (phi j)) (sin (theta (+ i 1))))
					(* (sin (phi j)) (sin (theta i))))
				(vector (cos (phi j))
					(cos (phi (+ j 1)))
					(cos (phi (+ j 1)))
					(cos (phi j))
					(cos (phi j)))
				(aref draw k)
				1))))
		 (plcol0 3)
		 (plmtex "t" 1.0 0.5 0.5 "unit radius sphere"))))

      ;; first 4 plots
      (dotimes (k 4)
	(test-poly k)))
    
    ;; second 4 plots
    (let* ((npts 1000)
	   (x (make-float-array npts))
	   (y (make-float-array npts))
	   (z (make-float-array npts)))
      (dotimes (i npts)
	(setf (aref z i) (- (* 2.0 (/ i npts)) 1)
	      (aref x i) (* (aref z i) (cos (* 2.0 3.14159 6.0 (/ i npts))))
	      (aref y i) (* (aref z i) (sin (* 2.0 3.14159 6.0 (/ i npts))))))

      (dotimes (k 4)
	(pladv 0)
	(plvpor 0.0 1.0 0.0 0.9)
	(plwind -1.0 1.0 -0.9 1.1)
	(plcol0 1)
	(plw3d 1.0 1.0 1.0 -1.0 1.0 -1.0 1.0 -1.0 1.0 (aref alt k) (aref az k))
	(plbox3 "bnstu" "x axis" 0.0 0
		"bnstu" "y axis" 0.0 0
		"bcdmnstuv" "z axis" 0.0 0)
	(plcol0 2)
	(if (/= (aref opt k) 0)
	    (plline3 x y z)
	    (plpoin3 x y z 1))
	(plcol0 3)
	(plmtex "t" 1.0 0.5 0.5 
		(format nil "#frPLplot Example 18 - Alt=~d, Az=~d" (round (aref alt k)) (round (aref az k)))))))

  (plend1))

;;;;
;;;; Copyright (c) 2010 Hazen P. Babcock
;;;;
;;;; Permission is hereby granted, free of charge, to any person obtaining a copy 
;;;; of this software and associated documentation files (the "Software"), to 
;;;; deal in the Software without restriction, including without limitation the 
;;;; rights to use, copy, modify, merge, publish, distribute, sublicense, and/or 
;;;; sell copies of the Software, and to permit persons to whom the Software is 
;;;; furnished to do so, subject to the following conditions:
;;;;
;;;; The above copyright notice and this permission notice shall be included in 
;;;; all copies or substantial portions of the Software.
;;;;
;;;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 
;;;; IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 
;;;; FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 
;;;; AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 
;;;; LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 
;;;; FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 
;;;; IN THE SOFTWARE.
;;;;