diff options
| author | Thomas Bushnell, BSG <tb@debian.org> | 2007-12-28 16:25:32 -0800 | 
|---|---|---|
| committer | Bryan Newbold <bnewbold@robocracy.org> | 2017-02-20 00:05:39 -0800 | 
| commit | d8ae23691ed6392b7f320f5fa7d4dd78ae52c10e (patch) | |
| tree | b20b8bc02e854c4c86d39ee22a0638a8b06e01af /differ.scm | |
| parent | edd1ebef3ad774e7cbcc2f5918d555bfb0b44091 (diff) | |
| parent | 64f037d91e0c9296dcaef9a0ff3eb33b19a2ed34 (diff) | |
| download | slib-d8ae23691ed6392b7f320f5fa7d4dd78ae52c10e.tar.gz slib-d8ae23691ed6392b7f320f5fa7d4dd78ae52c10e.zip | |
Import Debian changes 3a5-1debian/3a5-1
slib (3a5-1) unstable; urgency=low
  * New upstream release.
  
  * slib.texi (Library Catalogs): Repeat change from 3a3-3.
    
  * Makefile: Repeat $(htmldir)slib_toc.html changes from 3a2-1.
   
  * guile.init: (library-vicinity): Repeat change from 3a4-2.
  
  * debian/rules (binary-indep): Don't hide .init files in a separate
    subdirectory, thus conforming better to the usual slib practice.  Put a 
    symlink in place to ease transitions.  (Closes: #407370).
Diffstat (limited to 'differ.scm')
| -rw-r--r-- | differ.scm | 44 | 
1 files changed, 21 insertions, 23 deletions
| @@ -1,5 +1,5 @@  ;;;; "differ.scm" O(NP) Sequence Comparison Algorithm. -;;; Copyright (C) 2001, 2002, 2003, 2004 Aubrey Jaffer +;;; Copyright (C) 2001, 2002, 2003, 2004, 2007 Aubrey Jaffer  ;  ;Permission to copy this software, to modify it, to redistribute it,  ;to distribute modified versions, and to use it for any purpose is @@ -188,11 +188,10 @@      (let ((b-splt (diff:mid-split len-b RR CC tcst)))        (define est-c (array-ref CC b-splt))        (define est-r (array-ref RR (- len-b b-splt))) -      ;;(set! splts (cons (/ b-splt (max .1 len-b)) splts)) -      ;;(display "A: ") (array-for-each display (fp:subarray A start-a mid-a)) (display " + ") (array-for-each display (fp:subarray A mid-a end-a)) (newline) -      ;;(display "B: ") (array-for-each display (fp:subarray B start-b end-b)) (newline) +      ;;(display "A:     ") (array-for-each display (fp:subarray A start-a mid-a)) (display " + ") (array-for-each display (fp:subarray A mid-a end-a)) (newline) +      ;;(display "B:     ") (array-for-each display (fp:subarray B start-b end-b)) (newline)        ;;(print 'cc cc) (print 'rr (fp:subarray RR (+ 1 len-b) 0)) -      ;;(print (make-string (+ 7 (* 2 b-splt)) #\-) '^  (list b-splt)) +      ;;(print (make-string (+ 12 (* 2 b-splt)) #\-) '^  (list b-splt))        (check-cost! 'CC est-c  		  (diff2et fp fpoff CCRR  			   A start-a mid-a @@ -372,23 +371,22 @@  (define (diff:edits A B . p-lim)    (define M (car (array-dimensions A)))    (define N (car (array-dimensions B))) -  (set! p-lim (if (null? p-lim) -1 (car p-lim))) -  (let ((fp (make-array (A:fixZ32b) (if (negative? p-lim) -					(+ 3 M N) -					(+ 3 (abs (- N M)) p-lim p-lim))))) -    (define est (if (< N M) -		    (diff2editlen fp B A p-lim) -		    (diff2editlen fp A B p-lim))) -    (and est -	 (let ((edits (make-array (A:fixZ32b) est)) -	       (CCRR (make-array (A:fixZ32b) (* 2 (+ (max M N) 1))))) -	   (cond ((< N M) -		  (diff2edits! edits fp CCRR B A) -		  (diff:invert-edits! edits)) -		 (else -		  (diff2edits! edits fp CCRR A B))) -	   ;;(diff:order-edits! edits est) -	   edits)))) +  (define est (diff:edit-length A B (if (null? p-lim) -1 (car p-lim)))) +  (and est +       (let ((CCRR (make-array (A:fixZ32b) (* 2 (+ (max M N) 1)))) +	     (edits (make-array (A:fixZ32b) est))) +	 (define fp (make-array (A:fixZ32b) +				(+ (max (- N (quotient M 2)) +					(- M (quotient N 2))) +				   (- est (abs (- N M))) ; 2 * p-lim +				   3))) +	 (cond ((< N M) +		(diff2edits! edits fp CCRR B A) +		(diff:invert-edits! edits)) +	       (else +		(diff2edits! edits fp CCRR A B))) +	 ;;(diff:order-edits! edits est) +	 edits)))  ;;@args array1 array2 p-lim  ;;@args array1 array2 @@ -423,4 +421,4 @@  ;;       ; e  c  h p q  r  ;;@end example -;;(trace-all "/home/jaffer/slib/differ.scm")(set! *qp-width* 333)(untrace fp:run fp:subarray) +;;(trace-all "/home/jaffer/slib/differ.scm")(set! *qp-width* 999)(untrace fp:run) ; fp:subarray | 
