]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix errors in CEDET 1.0 merge.
authorChong Yidong <cyd@stupidchicken.com>
Wed, 29 Sep 2010 16:09:21 +0000 (12:09 -0400)
committerChong Yidong <cyd@stupidchicken.com>
Wed, 29 Sep 2010 16:09:21 +0000 (12:09 -0400)
* semantic/tag.el (semantic-tag-version): Bump to 2.0.

* semantic/db-typecache.el (semanticdb-typecache-find-default):
* semantic/imenu.el (semantic-create-imenu-index):
* semantic/grammar.el (semantic--grammar-macro-function-tag):
* semantic/fw.el (semanticdb-without-unloaded-file-searches): Fix
require.  Suggested by David Engster.

* semantic/bovine/c-by.el: Regenerate.

* semantic/lex-spp.el (semantic-lex-spp-debug-symbol): New var.
(semantic-lex-spp-enable-debug-symbol): New command
(semantic-lex-spp-value-valid-p)
(semantic-lex-spp-validate-value): New functions
(semantic-lex-spp-symbol-set)
(semantic-lex-spp-symbol-push): Add call to validate value.
(semantic-lex-spp-table-write-slot-value): Instead of erroring on
invalid values during save, just save a nil.

lisp/cedet/ChangeLog
lisp/cedet/semantic/bovine/c-by.el
lisp/cedet/semantic/db-typecache.el
lisp/cedet/semantic/fw.el
lisp/cedet/semantic/grammar.el
lisp/cedet/semantic/imenu.el
lisp/cedet/semantic/lex-spp.el
lisp/cedet/semantic/tag.el

index 5b75dfb5048436751b913e8a22734be88ccce8d4..73761b4ee985e2312e1099b94c1b4c50542bb473 100644 (file)
@@ -1,3 +1,26 @@
+2010-09-29  Chong Yidong  <cyd@stupidchicken.com>
+
+       * semantic/tag.el (semantic-tag-version): Bump to 2.0.
+
+       * semantic/db-typecache.el (semanticdb-typecache-find-default):
+       * semantic/imenu.el (semantic-create-imenu-index):
+       * semantic/grammar.el (semantic--grammar-macro-function-tag):
+       * semantic/fw.el (semanticdb-without-unloaded-file-searches): Fix
+       require.  Suggested by David Engster.
+
+       * semantic/bovine/c-by.el: Regenerate.
+
+2010-09-29  Eric Ludlam  <zappo@gnu.org>
+
+       * semantic/lex-spp.el (semantic-lex-spp-debug-symbol): New var.
+       (semantic-lex-spp-enable-debug-symbol): New command
+       (semantic-lex-spp-value-valid-p)
+       (semantic-lex-spp-validate-value): New functions
+       (semantic-lex-spp-symbol-set)
+       (semantic-lex-spp-symbol-push): Add call to validate value.
+       (semantic-lex-spp-table-write-slot-value): Instead of erroring on
+       invalid values during save, just save a nil.
+
 2010-09-25  Chong Yidong  <cyd@stupidchicken.com>
 
        * ede/linux.el (ede-project-class-files):
index 09fb42261a47ebc660b2627542cdb8e2960f96bc..c33f3fb67f552da288786c4262ce91b25a4aaf40 100644 (file)
         (nth 7 vals))
        (nth 0 vals)
        (nth 10 vals)
-       (nth 4 vals))
+       (list
+        (nth 4 vals))
+       (nth 9 vals))
       )
      (opt-stars
       opt-class
         (nth 6 vals))
        (nth 0 vals)
        (nth 9 vals)
-       (nth 4 vals))
+       (list
+        (nth 4 vals))
+       (nth 8 vals))
       )
      ) ;; end func-decl
 
       namespace-symbol
       opt-bits
       opt-array
-      opt-assign
       ,(semantic-lambda
        (nth 2 vals)
        (nth 0 vals)
        (nth 3 vals)
-       (nth 4 vals)
-       (nth 5 vals))
+       (nth 4 vals))
       )
      ) ;; end varname
 
       )
      ) ;; end variablearg-opt-name
 
+    (varname-opt-initializer
+     (semantic-list)
+     (opt-assign)
+     ( ;;EMPTY
+      )
+     ) ;; end varname-opt-initializer
+
     (varnamelist
      (opt-ref
       varname
+      varname-opt-initializer
       punctuation
       "\\`[,]\\'"
       varnamelist
       ,(semantic-lambda
        (cons
         (nth 1 vals)
-        (nth 3 vals)))
+        (nth 4 vals)))
       )
      (opt-ref
       varname
+      varname-opt-initializer
       ,(semantic-lambda
        (list
         (nth 1 vals)))
       "\\`[&]\\'")
      ) ;; end expr-start
 
+    (expr-binop
+     (punctuation
+      "\\`[-]\\'")
+     (punctuation
+      "\\`[+]\\'")
+     (punctuation
+      "\\`[*]\\'")
+     (punctuation
+      "\\`[/]\\'")
+     (punctuation
+      "\\`[&]\\'"
+      punctuation
+      "\\`[&]\\'")
+     (punctuation
+      "\\`[&]\\'")
+     (punctuation
+      "\\`[|]\\'"
+      punctuation
+      "\\`[|]\\'")
+     (punctuation
+      "\\`[|]\\'")
+     ) ;; end expr-binop
+
     (expression
-     (number
+     (unaryexpression
+      expr-binop
+      unaryexpression
       ,(semantic-lambda
        (list
         (identity start)
         (identity end)))
       )
-     (multi-stage-dereference
+     (unaryexpression
       ,(semantic-lambda
        (list
         (identity start)
         (identity end)))
       )
+     ) ;; end expression
+
+    (unaryexpression
+     (number)
+     (multi-stage-dereference)
      (NEW
-      multi-stage-dereference
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
+      multi-stage-dereference)
      (NEW
       builtintype-types
-      semantic-list
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
-     (namespace-symbol
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
-     (string-seq
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
+      semantic-list)
+     (namespace-symbol)
+     (string-seq)
      (type-cast
-      expression
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
-     (semantic-list
-      expression
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
+      expression)
      (semantic-list
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
+      expression)
+     (semantic-list)
      (expr-start
-      expression
-      ,(semantic-lambda
-       (list
-        (identity start)
-        (identity end)))
-      )
-     ) ;; end expression
+      expression)
+     ) ;; end unaryexpression
     )
   "Parser table.")
 
index 71b15fdf82a5405cc61cd5b48723366feba10f18..59ba83fe9d065cbae0d4d418a7311875cbb4ad8d 100644 (file)
@@ -403,7 +403,7 @@ TYPE is the datatype to find.
 PATH is the search path, which should be one table object.
 If FIND-FILE-MATCH is non-nil, then force the file belonging to the
 found tag to be loaded."
-  (if (not (and (featurep 'semanticdb) semanticdb-current-database))
+  (if (not (and (featurep 'semantic/db) semanticdb-current-database))
       nil ;; No DB, no search
     (save-excursion
       (semanticdb-typecache-find-method (or path semanticdb-current-table)
index 49790861632767501c0db1763a069d240c4c1b66..811508377b8fa819e8e9cbdadfbba22c517538c5 100644 (file)
@@ -315,7 +315,7 @@ FILE, NOWARN, RAWFILE, and WILDCARDS are passed into `find-file-noselect'"
 (defmacro semanticdb-without-unloaded-file-searches (forms)
   "Execute FORMS with `unloaded' removed from the current throttle."
   `(let ((semanticdb-find-default-throttle
-         (if (featurep 'semanticdb-find)
+         (if (featurep 'semantic/db-find)
              (remq 'unloaded semanticdb-find-default-throttle)
            nil)))
      ,forms))
index 65365768f980d3c750dc074da844f7233c56dc0a..d99ae0cb0acf13b2f4a57783ce243988d3d29992 100644 (file)
@@ -1519,7 +1519,7 @@ Return the tag found or nil if not found."
   (car (semantic-find-tags-by-class
         'function
         (or (semantic-find-tags-by-name name (current-buffer))
-            (and (featurep 'semanticdb)
+            (and (featurep 'semantic/db)
                  semanticdb-current-database
                  (cdar (semanticdb-find-tags-by-name name nil t)))))))
 
index e38b50bcd574e492e07e39a5a236e62a878c56a4..465a93a16dddfc40d3f6e04f2dd974ef2ac25da2 100644 (file)
@@ -235,7 +235,7 @@ Optional argument STREAM is an optional stream of tags used to create menus."
   (setq imenu-default-goto-function 'semantic-imenu-goto-function)
   (prog1
       (if (and semantic-imenu-index-directory
-               (featurep 'semanticdb)
+               (featurep 'semantic/db)
                (semanticdb-minor-mode-p))
           (semantic-create-imenu-directory-index
           (or stream (semantic-fetch-tags-fast)))
index 88b77e50e1d33372d9b81f56e28b83576fee4155..0b4fa930b1babd6e5731edf28957914b2d0e19bc 100644 (file)
@@ -173,10 +173,42 @@ The search priority is:
       (setq semantic-lex-spp-dynamic-macro-symbol-obarray-stack
            (make-vector 13 0))))
 
+(defun semantic-lex-spp-value-valid-p (value)
+  "Return non-nil if VALUE is valid."
+  (or (null value)
+      (stringp value)
+      (and (consp value)
+          (or (semantic-lex-token-p (car value))
+              (eq (car (car value)) 'spp-arg-list)))))
+
+(defvar semantic-lex-spp-debug-symbol nil
+  "A symbol to break on if it is being set somewhere.")
+
+(defun semantic-lex-spp-enable-debug-symbol (sym)
+  "Enable debugging for symbol SYM.
+Disable debugging by entering nothing."
+  (interactive "sSymbol: ")
+  (if (string= sym "")
+      (setq semantic-lex-spp-debug-symbol nil)
+    (setq semantic-lex-spp-debug-symbol sym)))
+
+(defmacro semantic-lex-spp-validate-value (name value)
+  "Validate the NAME and VALUE of a macro before it is set."
+;  `(progn
+;     (when (not (semantic-lex-spp-value-valid-p ,value))
+;       (error "Symbol \"%s\" with bogus value %S" ,name ,value))
+;     (when (and semantic-lex-spp-debug-symbol
+;              (string= semantic-lex-spp-debug-symbol name))
+;       (debug))
+;     )
+  nil
+  )
+
 (defun semantic-lex-spp-symbol-set (name value &optional obarray-in)
   "Set value of spp symbol with NAME to VALUE and return VALUE.
 If optional OBARRAY-IN is non-nil, then use that obarray instead of
 the dynamic map."
+  (semantic-lex-spp-validate-value name value)
   (if (and (stringp value) (string= value "")) (setq value nil))
   (set (intern name (or obarray-in
                        (semantic-lex-spp-dynamic-map)))
@@ -192,6 +224,7 @@ the dynamic map."
 (defun semantic-lex-spp-symbol-push (name value)
   "Push macro NAME with VALUE into the map.
 Reverse with `semantic-lex-spp-symbol-pop'."
+  (semantic-lex-spp-validate-value name value)
   (let* ((map (semantic-lex-spp-dynamic-map))
         (stack (semantic-lex-spp-dynamic-map-stack))
         (mapsym (intern name map))
index e9094fcb051f2865b0167ed0510aced65c4d02c0..0195a29b66ed3c2eec6fb2880140377b140aa54a 100644 (file)
@@ -53,7 +53,7 @@
 (declare-function semantic-fetch-tags "semantic")
 (declare-function semantic-clear-toplevel-cache "semantic")
 
-(defconst semantic-tag-version "2.0pre7"
+(defconst semantic-tag-version "2.0"
   "Version string of semantic tags made with this code.")
 
 (defconst semantic-tag-incompatible-version "1.0"
@@ -221,6 +221,7 @@ See also the function `semantic-ctxt-current-mode'."
           ;; beginning of TAG.
           (or (and (>= (point) start) (< (point) end))
               (goto-char start))
+          (require 'semantic/ctxt)
           (semantic-ctxt-current-mode)))))
 
 (defsubst semantic--tag-attributes-cdr (tag)