- adopted to new install-lib
- using scsh-include from configure - respecting options build, non-shared-only, dest-dir
This commit is contained in:
		
							parent
							
								
									444f614553
								
							
						
					
					
						commit
						c67b9d6f27
					
				
							
								
								
									
										48
									
								
								pkg-def.scm
								
								
								
								
							
							
						
						
									
										48
									
								
								pkg-def.scm
								
								
								
								
							|  | @ -1,48 +1,50 @@ | ||||||
| (define-package "scx" (0 2 1) | (define-package "scx" (0 2 1) | ||||||
|   ((optional-parts (xft "Compile with Xft support" #f)) |   ((options (with-xft "Compile with Xft support" "<yes/no>" #t #t #f | ||||||
|    ; we need something like one of these | 		      ,parse-boolean ,show-boolean))) | ||||||
|    ;(include-clib-options #t)) |  | ||||||
|    ;(extra-options (scsh-includes "where the scsh include files are" |  | ||||||
| 	;			 ("scsh-includes") #t #f))) |  | ||||||
|    ) |  | ||||||
| 
 | 
 | ||||||
|   ;; compile and install c libs |   ;; compile and install c libs | ||||||
|   (let* ((scsh-includes "/afs/wsi/i386_fbsd46/scsh-0.6.5/include/") |   (display "configuring, compiling and installing the native code library\n") | ||||||
| 	 ;(scsh-includes (get-extra-option 'scsh-includes)) |   (let* ((scsh-includes (include-dir)) | ||||||
| 	 (prefix (get-directory 'lib #t)) | 	 (build-host (get-option-value 'build)) | ||||||
| 	 (xft? (with-optional-part? 'xft)) | 	 (prefix (string-append (get-directory 'lib #f) "/" build-host)) | ||||||
|          (configure `("./configure" ,(string-append "--prefix=" prefix) | 	 (xft? (get-option-value 'with-xft)) | ||||||
|  |          (configure `("./configure" | ||||||
|  | 		      ,(string-append "--prefix=" prefix) | ||||||
| 		      ,(if xft? "--with-xft" "--without-xft") | 		      ,(if xft? "--with-xft" "--without-xft") | ||||||
| 		      ,(if scsh-includes (string-append "--with-scsh-includes=" | 		      ,(string-append "--with-scsh-includes=" scsh-includes) | ||||||
| 							scsh-includes) ""))) | 		      ,(string-append "--build=" build-host))) | ||||||
| 	 ;; better use the real install-prefix as DESTDIR for make... | 
 | ||||||
|          (make '(make install))) |          (make `(make install | ||||||
|      (if (is-running-dry?) | 		  ,(string-append "DESTDIR=" (get-option-value 'dest-dir))))) | ||||||
|  |      (if (get-option-value 'dry-run) | ||||||
|          (begin |          (begin | ||||||
|           (display configure) (newline) |           (display configure) (newline) | ||||||
|           (display make) (newline)) |           (display make) (newline)) | ||||||
|          (if (not (and (zero? (run ,configure)) |          (if (not (and (zero? (run ,configure)) | ||||||
| 		       (zero? (run ,make)))) | 		       (zero? (run ,make)))) | ||||||
| 	     (exit)))) | 	     (exit)))) | ||||||
|   ;; create load.scm with sed | 
 | ||||||
|  |   ;; create load.scm with sed, this is platform-independent | ||||||
|  |   (if (not (get-option-value 'non-shared-only)) | ||||||
|  |       (begin | ||||||
| 	(display "creating load.scm\n") | 	(display "creating load.scm\n") | ||||||
| 	(let ((schemedir (get-directory 'scheme #f)) | 	(let ((schemedir (get-directory 'scheme #f)) | ||||||
| 	      (libdir (get-directory 'lib #f)) | 	      (libdir (get-directory 'lib #f)) | ||||||
| 	(load-xft-packages (if (with-optional-part? 'xft) "yes" "no")) | 	      (load-xft-packages (if (get-option-value 'with-xft) "yes" "no")) | ||||||
| 	      (target-dir (get-directory 'base #t)) | 	      (target-dir (get-directory 'base #t)) | ||||||
| 	      (sed-replace (lambda (from to) | 	      (sed-replace (lambda (from to) | ||||||
| 			     (string-append "s|" from "|" to "|g")))) | 			     (string-append "s|" from "|" to "|g")))) | ||||||
| 	  (let ((cmd `(sed -e ,(sed-replace "@scxschemedir@" schemedir) | 	  (let ((cmd `(sed -e ,(sed-replace "@scxschemedir@" schemedir) | ||||||
| 		     ;; this a bad hack, we would need dir 'lib-base | 			   -e ,(sed-replace "@scxhost@" "(host)") | ||||||
| 		     -e ,(sed-replace "@scxhost@" "\"../\" (host)") |  | ||||||
| 			   -e ,(sed-replace "@scxlibdir@" libdir) | 			   -e ,(sed-replace "@scxlibdir@" libdir) | ||||||
| 			   -e ,(sed-replace "@scxload_xft_packages@" | 			   -e ,(sed-replace "@scxload_xft_packages@" | ||||||
| 					    load-xft-packages) | 					    load-xft-packages) | ||||||
| 			   "load.scm.in")) | 			   "load.scm.in")) | ||||||
| 		(tgt (string-append target-dir "/load.scm"))) | 		(tgt (string-append target-dir "/load.scm"))) | ||||||
|       (if (is-running-dry?) | 	    (if (get-option-value 'dry-run) | ||||||
| 		(begin (display cmd) (display " > ") (display tgt) (newline)) | 		(begin (display cmd) (display " > ") (display tgt) (newline)) | ||||||
| 	  (run ,cmd (> ,tgt))))) | 		(if (not (zero? (run ,cmd (> ,tgt)))) | ||||||
|   (display "copying scheme code\n") | 		    (exit))))))) | ||||||
|  | 
 | ||||||
|   (install-directory-contents "scheme" 'scheme) |   (install-directory-contents "scheme" 'scheme) | ||||||
| ) | ) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 frese
						frese