-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsemanticdb-debug.el
117 lines (95 loc) · 3.57 KB
/
semanticdb-debug.el
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
;;; semanticdb-debug.el --- Extra level debugging routines
;; Copyright (C) 2008, 2009 Eric M. Ludlam
;; Author: Eric M. Ludlam <[email protected]>
;; X-RCS: $Id: semanticdb-debug.el,v 1.7 2009/02/25 19:41:35 zappo Exp $
;; This program is free software; you can redistribute it and/or
;; modify it under the terms of the GNU General Public License as
;; published by the Free Software Foundation; either version 2, or (at
;; your option) any later version.
;; This program is distributed in the hope that it will be useful, but
;; WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
;; General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program; see the file COPYING. If not, write to
;; the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
;; Boston, MA 02110-1301, USA.
;;; Commentary:
;;
;; Various routines for debugging SemanticDB issues, or viewing
;; semanticdb state.
(require 'semanticdb)
;;; Code:
;;
;;;###autoload
(defun semanticdb-dump-all-table-summary ()
"Dump a list of all databases in Emacs memory."
(interactive)
(require 'data-debug)
(let ((db semanticdb-database-list))
(data-debug-new-buffer "*SEMANTICDB*")
(data-debug-insert-stuff-list db "*")))
;;;###autoload
(defalias 'semanticdb-adebug-database-list 'semanticdb-dump-all-table-summary)
;;;###autoload
(defun semanticdb-adebug-current-database ()
"Run ADEBUG on the current database."
(interactive)
(require 'data-debug)
(let ((p semanticdb-current-database)
)
(data-debug-new-buffer "*SEMANTICDB ADEBUG*")
(data-debug-insert-stuff-list p "*")))
;;;###autoload
(defun semanticdb-adebug-current-table ()
"Run ADEBUG on the current database."
(interactive)
(require 'data-debug)
(let ((p semanticdb-current-table))
(data-debug-new-buffer "*SEMANTICDB ADEBUG*")
(data-debug-insert-stuff-list p "*")))
;;;###autoload
(defun semanticdb-adebug-project-database-list ()
"Run ADEBUG on the current database."
(interactive)
(require 'data-debug)
(let ((p (semanticdb-current-database-list)))
(data-debug-new-buffer "*SEMANTICDB ADEBUG*")
(data-debug-insert-stuff-list p "*")))
;;; Sanity Checks
;;
;;;###autoload
(defun semanticdb-table-oob-sanity-check (cache)
"Validate that CACHE tags do not have any overlays in them."
(while cache
(when (semantic-overlay-p (semantic-tag-overlay cache))
(message "Tag %s has an erroneous overlay!"
(semantic-format-tag-summarize (car cache))))
(semanticdb-table-oob-sanity-check
(semantic-tag-components-with-overlays (car cache)))
(setq cache (cdr cache))))
;;;###autoload
(defun semanticdb-table-sanity-check (&optional table)
"Validate the current semanticdb TABLE."
(interactive)
(if (not table) (setq table semanticdb-current-table))
(let* ((full-filename (semanticdb-full-filename table))
(buff (find-buffer-visiting full-filename)))
(if buff
(save-excursion
(set-buffer buff)
(semantic-sanity-check))
;; We can't use the usual semantic validity check, so hack our own.
(semanticdb-table-oob-sanity-check (semanticdb-get-tags table)))))
;;;###autoload
(defun semanticdb-database-sanity-check ()
"Validate the current semantic database."
(interactive)
(let ((tables (semanticdb-get-database-tables
semanticdb-current-database)))
(while tables
(semanticdb-table-sanity-check (car tables))
(setq tables (cdr tables)))
))
(provide 'semanticdb-debug)
;;; semanticdb-debug.el ends here