]> git.eshelyaron.com Git - emacs.git/commitdiff
Ooops... undo changes of 2011-12-11T14:49:48Z!vincentb1@users.sourceforge.net, as...
authorVincent Belaïche <vincentb1@users.sourceforge.net>
Mon, 19 Dec 2011 06:30:36 +0000 (07:30 +0100)
committerVincent Belaïche <vincentb1@users.sourceforge.net>
Mon, 19 Dec 2011 06:30:36 +0000 (07:30 +0100)
lisp/ChangeLog
lisp/ses.el

index 9be0d2f1a3ca1450d8c460c7e91a44b9d34bd632..7d5da3a41c073fa75c0917d2922b13a01b385e23 100644 (file)
@@ -1,3 +1,9 @@
+2011-12-19  Vincent Belaïche  <vincentb1@users.sourceforge.net>
+
+       * ses.el: Ooops... undo changes of 2011-12-11T14:49:48Z!vincentb1@users.sourceforge.net, as trunk
+       branch is feature frozen, and 2011-12-11T14:49:48Z!vincentb1@users.sourceforge.net was a feature
+       addition.
+
 2011-12-18  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/ns-win.el (ns-get-selection-internal)
index 403651695a8c2a0aa7de83c01316e86830d0f473..d5947472c1a276bd0da39b86b69beaebd2808294 100644 (file)
@@ -674,13 +674,6 @@ for this spreadsheet."
        (put sym 'ses-cell (cons xrow xcol))
        (make-local-variable sym)))))
 
-(defun ses-create-cell-variable (sym row col)
-  "Create a buffer-local variable for cell with symbol
-SYM at position ROW COL.  Return nil in case of failure."
-  (unless (local-variable-p sym)
-    (make-local-variable  sym)
-    (put sym 'ses-cell (cons row col))))
-
 ;; We do not delete the ses-cell properties for the cell-variables, in
 ;; case a formula that refers to this cell is in the kill-ring and is
 ;; later pasted back in.
@@ -1406,8 +1399,7 @@ removed.  Example:
 Sets `ses-relocate-return' to 'delete if cell-references were removed."
   (let (rowcol result)
     (if (or (atom formula) (eq (car formula) 'quote))
-       (if (and (setq rowcol (ses-sym-rowcol formula))
-                (string-match "\\`[A-Z]+[0-9]+\\'" (symbol-name formula)))
+       (if (setq rowcol (ses-sym-rowcol formula))
            (ses-relocate-symbol formula rowcol
                                 startrow startcol rowincr colincr)
          formula) ; Pass through as-is.
@@ -1515,15 +1507,14 @@ if the range was altered."
 the rectangle (MINROW,MINCOL)..(NUMROWS,NUMCOLS) by adding ROWINCR and COLINCR
 to each symbol."
   (let (reform)
-    (let (mycell newval xrow)
+    (let (mycell newval)
       (dotimes-with-progress-reporter
          (row ses--numrows) "Relocating formulas..."
        (dotimes (col ses--numcols)
          (setq ses-relocate-return nil
                mycell (ses-get-cell row col)
                newval (ses-relocate-formula (ses-cell-formula mycell)
-                                            minrow mincol rowincr colincr)
-               xrow  (- row rowincr))
+                                            minrow mincol rowincr colincr))
          (ses-set-cell row col 'formula newval)
          (if (eq ses-relocate-return 'range)
              ;; This cell contains a (ses-range X Y) where a cell has been
@@ -1539,22 +1530,8 @@ to each symbol."
                                             minrow mincol rowincr colincr))
          (ses-set-cell row col 'references newval)
          (and (>= row minrow) (>= col mincol)
-              (let ((sym (ses-cell-symbol row col))
-                    (xcol (- col colincr)))
-                (if (and
-                     sym
-                     (>= xrow 0)
-                     (>= xcol 0)
-                     (null (eq sym
-                               (ses-create-cell-symbol xrow xcol))))
-                    ;; This is a renamed cell, do not update the cell
-                    ;; name, but just update the coordinate property.
-                    (put sym 'ses-cell (cons row col))
-                  (ses-set-cell row col 'symbol
-                                (setq sym (ses-create-cell-symbol row col)))
-                  (unless (and (boundp sym) (local-variable-p sym))
-                    (set (make-local-variable sym) nil)
-                    (put sym 'ses-cell (cons row col)))))) )))
+              (ses-set-cell row col 'symbol
+                            (ses-create-cell-symbol row col))))))
     ;; Relocate the cell values.
     (let (oldval myrow mycol xrow xcol)
       (cond
@@ -1567,17 +1544,11 @@ to each symbol."
            (setq mycol  (+ col mincol)
                  xrow   (- myrow rowincr)
                  xcol   (- mycol colincr))
-           (let ((sym (ses-cell-symbol myrow mycol))
-                 (xsym (ses-create-cell-symbol xrow xcol)))
-             ;; Make the value relocation only when if the cell is not
-             ;; a renamed cell.  Otherwise this is not needed.
-             (and (eq sym xsym)
-                 (ses-set-cell myrow mycol 'value
-                   (if (and (< xrow ses--numrows) (< xcol ses--numcols))
-                       (ses-cell-value xrow xcol)
-                     ;;Cell is off the end of the array
-                     (symbol-value xsym))))))))
-
+           (if (and (< xrow ses--numrows) (< xcol ses--numcols))
+               (setq oldval (ses-cell-value xrow xcol))
+             ;; Cell is off the end of the array.
+             (setq oldval (symbol-value (ses-create-cell-symbol xrow xcol))))
+           (ses-set-cell myrow mycol 'value oldval))))
        ((and (wholenump rowincr) (wholenump colincr))
        ;; Insertion of rows and/or columns.  Run the loop backwards.
        (let ((disty (1- ses--numrows))
@@ -1687,6 +1658,7 @@ Does not execute cell formulas or print functions."
        (message "Upgrading from SES-1 file format")))
     (or (= ses--file-format 2)
        (error "This file needs a newer version of the SES library code"))
+    (ses-create-cell-variable-range 0 (1- ses--numrows) 0 (1- ses--numcols))
     ;; Initialize cell array.
     (setq ses--cells (make-vector ses--numrows nil))
     (dotimes (row ses--numrows)
@@ -1706,10 +1678,11 @@ Does not execute cell formulas or print functions."
   (dotimes (row ses--numrows)
     (dotimes (col ses--numcols)
       (let* ((x      (read (current-buffer)))
-            (sym  (car-safe (cdr-safe x))))
+            (rowcol (ses-sym-rowcol (car-safe (cdr-safe x)))))
        (or (and (looking-at "\n")
                 (eq (car-safe x) 'ses-cell)
-                (ses-create-cell-variable sym row col))
+                (eq row (car rowcol))
+                (eq col (cdr rowcol)))
            (error "Cell-def error"))
        (eval x)))
     (or (looking-at "\n\n")
@@ -3166,60 +3139,6 @@ highlighted range in the spreadsheet."
   (mouse-set-point event)
   (ses-insert-ses-range))
 
-(defun ses-replace-name-in-formula (formula old-name new-name)
-  (let ((new-formula formula))
-    (unless (and (consp formula)
-                (eq (car-safe formula) 'quote))
-      (while formula
-       (let ((elt (car-safe formula)))
-         (cond
-          ((consp elt)
-           (setcar formula (ses-replace-name-in-formula elt old-name new-name)))
-          ((and (symbolp elt)
-                (eq (car-safe formula) old-name))
-           (setcar formula new-name))))
-       (setq formula (cdr formula))))
-    new-formula))
-
-(defun ses-rename-cell (new-name)
-  "Rename current cell."
-  (interactive "*SEnter new name: ")
-  (ses-check-curcell)
-  (or
-   (and  (local-variable-p new-name)
-        (ses-sym-rowcol new-name)
-        (error "Already a cell name"))
-   (and (boundp new-name)
-       (null (yes-or-no-p (format "`%S' is already bound outside this buffer, continue? "
-                                  new-name)))
-       (error "Already a bound cell name")))
-  (let* ((rowcol (ses-sym-rowcol ses--curcell))
-        (cell (ses-get-cell (car rowcol) (cdr rowcol))))
-    (dolist (reference (ses-cell-references (car rowcol) (cdr rowcol)))
-      (let* ((rowcol (ses-sym-rowcol reference))
-            (cell  (ses-get-cell (car rowcol) (cdr rowcol))))
-       (ses-cell-set-formula (car rowcol)
-                             (cdr rowcol)
-                             (ses-replace-name-in-formula
-                              (ses-cell-formula cell)
-                              ses--curcell
-                              new-name))))
-    (put new-name 'ses-cell rowcol)
-    (set new-name (symbol-value ses--curcell))
-    (aset cell 0 new-name)
-    (put ses--curcell 'ses-cell nil)
-    (makunbound ses--curcell)
-    (setq ses--curcell new-name)
-    (let* ((pos (point))
-          (inhibit-read-only t)
-          (col (current-column))
-          (end (save-excursion
-                 (move-to-column (1+ col))
-                 (if (eolp)
-                     (+ pos (ses-col-width col) 1)
-                   (point)))))
-      (put-text-property pos end 'intangible new-name))) )
-
 
 ;;----------------------------------------------------------------------------
 ;; Checking formulas for safety