Mercurial > emacs
view test/cedet/semantic-utest-c.el @ 112432:27320025ed54
Merge chages made in Gnus trunk.
mailcap.el (mailcap-mime-extensions): Rename text/org to text/x-org.
gnus-draft.el (gnus-group-send-queue): Update the queue group in the group buffer after sending the queue.
gnus-draft.el (gnus-group-send-queue): Really refresh the queue group after sending.
gnus-agent.el (gnus-agent-send-mail): Ditto.
gnus-group.el (gnus-group-refresh-group): New convenience function.
message.el (message-bogus-addresses): Remove commented-out value.
message.el (message-check-recipients): Display the encoded version of the bogus address if they differ.
flow-fill.el (fill-flowed): Make `delete-space' option correspond to "DelSp" parameter in RFC3676.
gnus-sum.el (gnus-summary-move-article): Protect against backends (i.e., nnimap) returning nil as the article number.
author | Katsumi Yamaoka <yamaoka@jpl.org> |
---|---|
date | Sun, 23 Jan 2011 00:34:08 +0000 |
parents | ef719132ddfa |
children |
line wrap: on
line source
;;; semantic-utest-c.el --- C based parsing tests. ;; Copyright (C) 2008, 2009, 2010, 2011 Free Software Foundation, Inc. ;; Author: Eric M. Ludlam <eric@siege-engine.com> ;; This file is part of GNU Emacs. ;; GNU Emacs 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 3 of the License, or ;; (at your option) any later version. ;; GNU Emacs 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 GNU Emacs. If not, see <http://www.gnu.org/licenses/>. ;;; Commentary: ;; ;; Run some C based parsing tests. (require 'semantic) (defvar semantic-utest-c-comparisons '( ("testsppreplace.c" . "testsppreplaced.c") ) "List of files to parse and compare against eachother.") ;;; Code: ;;;###autoload (defun semantic-utest-c () "Run parsing test for C from the test directory." (interactive) (dolist (fp semantic-utest-c-comparisons) (let* ((sem (locate-library "semantic")) (sdir (file-name-directory sem)) (semantic-lex-c-nested-namespace-ignore-second nil) (tags-actual (save-excursion (set-buffer (find-file-noselect (expand-file-name (concat "tests/" (car fp)) sdir))) (semantic-clear-toplevel-cache) (semantic-fetch-tags))) (tags-expected (save-excursion (set-buffer (find-file-noselect (expand-file-name (concat "tests/" (cdr fp)) sdir))) (semantic-clear-toplevel-cache) (semantic-fetch-tags)))) ;; Now that we have the tags, compare them for SPP accuracy. (dolist (tag tags-actual) (if (and (semantic-tag-of-class-p tag 'variable) (semantic-tag-variable-constant-p tag)) nil ; skip the macros. (if (semantic-tag-similar-with-subtags-p tag (car tags-expected)) (setq tags-expected (cdr tags-expected)) (with-mode-local c-mode (error "Found: >> %s << Expected: >> %s <<" (semantic-format-tag-prototype tag nil t) (semantic-format-tag-prototype (car tags-expected) nil t) ))) )) ;; Passed? (message "PASSED!") ))) (provide 'semantic-utest-c) ;;; semantic-utest-c.el ends here