1 ;;; semantic/db-debug.el --- Extra level debugging routines for Semantic
3 ;;; Copyright (C) 2008-2017 Free Software Foundation, Inc.
5 ;; Author: Eric M. Ludlam <eric@siege-engine.com>
7 ;; This file is part of GNU Emacs.
9 ;; GNU Emacs is free software: you can redistribute it and/or modify
10 ;; it under the terms of the GNU General Public License as published by
11 ;; the Free Software Foundation, either version 3 of the License, or
12 ;; (at your option) any later version.
14 ;; GNU Emacs is distributed in the hope that it will be useful,
15 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
16 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 ;; GNU General Public License for more details.
19 ;; You should have received a copy of the GNU General Public License
20 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
24 ;; Various routines for debugging SemanticDB issues, or viewing
28 (require 'semantic
/db
)
29 (require 'semantic
/format
)
33 (defun semanticdb-dump-all-table-summary ()
34 "Dump a list of all databases in Emacs memory."
37 (let ((db semanticdb-database-list
))
38 (data-debug-new-buffer "*SEMANTICDB*")
39 (data-debug-insert-stuff-list db
"*")))
41 (defalias 'semanticdb-adebug-database-list
'semanticdb-dump-all-table-summary
)
43 (defun semanticdb-adebug-current-database ()
44 "Run ADEBUG on the current database."
47 (let ((p semanticdb-current-database
)
49 (data-debug-new-buffer "*SEMANTICDB ADEBUG*")
50 (data-debug-insert-stuff-list p
"*")))
52 (defun semanticdb-adebug-current-table ()
53 "Run ADEBUG on the current database."
56 (let ((p semanticdb-current-table
))
57 (data-debug-new-buffer "*SEMANTICDB ADEBUG*")
58 (data-debug-insert-stuff-list p
"*")))
61 (defun semanticdb-adebug-project-database-list ()
62 "Run ADEBUG on the current database."
65 (let ((p (semanticdb-current-database-list)))
66 (data-debug-new-buffer "*SEMANTICDB ADEBUG*")
67 (data-debug-insert-stuff-list p
"*")))
74 (defun semanticdb-table-oob-sanity-check (cache)
75 "Validate that CACHE tags do not have any overlays in them."
77 (when (semantic-overlay-p (semantic-tag-overlay cache
))
78 (message "Tag %s has an erroneous overlay!"
79 (semantic-format-tag-summarize (car cache
))))
80 (semanticdb-table-oob-sanity-check
81 (semantic-tag-components-with-overlays (car cache
)))
82 (setq cache
(cdr cache
))))
84 (defun semanticdb-table-sanity-check (&optional table
)
85 "Validate the current semanticdb TABLE."
87 (if (not table
) (setq table semanticdb-current-table
))
88 (let* ((full-filename (semanticdb-full-filename table
))
89 (buff (find-buffer-visiting full-filename
)))
91 (with-current-buffer buff
92 (semantic-sanity-check))
93 ;; We can't use the usual semantic validity check, so hack our own.
94 (semanticdb-table-oob-sanity-check (semanticdb-get-tags table
)))))
96 (defun semanticdb-database-sanity-check ()
97 "Validate the current semantic database."
99 (let ((tables (semanticdb-get-database-tables
100 semanticdb-current-database
)))
102 (semanticdb-table-sanity-check (car tables
))
103 (setq tables
(cdr tables
)))
108 (provide 'semantic
/db-debug
)
110 ;;; semantic/db-debug.el ends here