diff options
| author | Eric M. Ludlam | 2010-09-21 18:11:23 -0400 |
|---|---|---|
| committer | Chong Yidong | 2010-09-21 18:11:23 -0400 |
| commit | b9749554532876da8bc15e10bc3fb8bd8c0f32ea (patch) | |
| tree | 0d00b9800e8eb95e8466ab322fde1879e378fddb /lisp/cedet/srecode/cpp.el | |
| parent | fbb3da770f233a8e0cf99d5f053b0c31cbbc8db4 (diff) | |
| download | emacs-b9749554532876da8bc15e10bc3fb8bd8c0f32ea.tar.gz emacs-b9749554532876da8bc15e10bc3fb8bd8c0f32ea.zip | |
Synch SRecode to CEDET 1.0.
* lisp/cedet/cedet.el (cedet-version):
* lisp/cedet/srecode.el (srecode-version): Bump version to 1.0.
* lisp/cedet/pulse.el (pulse-momentary-highlight-overlay): If pulse-flag is
'never, disable all pulsing.
* lisp/cedet/srecode/compile.el (srecode-compile-templates): Fix directory
compare of built-in templates. Give built-ins lower piority.
Support special variable "project".
(srecode-compile-template-table): Set :project slot of new tables.
(srecode-compile-one-template-tag): Use
srecode-create-dictionaries-from-tags.
* lisp/cedet/srecode/cpp.el (srecode-cpp): New defgroup.
(srecode-cpp-namespaces): New option.
(srecode-semantic-handle-:using-namespaces)
(srecode-cpp-apply-templates): New functions.
(srecode-semantic-apply-tag-to-dict): Handle template parameters
by calling `srecode-cpp-apply-templates'.
* lisp/cedet/srecode/dictionary.el (srecode-dictionary-add-template-table):
Do not add variables in tables not for the current project.
(srecode-compound-toString): Handle cases where the default value
is another compound value.
(srecode-dictionary-lookup-name): New optional argument
NON-RECURSIVE, which inhibits visiting dictionary parents.
(srecode-dictionary-add-section-dictionary)
(srecode-dictionary-merge): New optional argument FORCE adds
values even if an identically named entry exists.
(srecode-dictionary-add-entries): New method.
(srecode-create-dictionaries-from-tags): New function.
* lisp/cedet/srecode/fields.el (srecode-fields-exit-confirmation): New option.
(srecode-field-exit-ask): Use it.
* lisp/cedet/srecode/find.el (srecode-template-get-table)
(srecode-template-get-table-for-binding)
(srecode-all-template-hash): Skip if not in current project.
(srecode-template-table-in-project-p): New method.
* lisp/cedet/srecode/getset.el (srecode-insert-getset): Force tag table
update. Don't query the class if it is empty.
* lisp/cedet/srecode/insert.el (srecode-insert-fcn): Merge template
dictionary before resolving arguments.
(srecode-insert-method-helper): Add error checking to make sure
that we only have dictionaries.
(srecode-insert-method): Check template nesting depth when using
point inserter override.
(srecode-insert-method): Install override with depth limit.
* lisp/cedet/srecode/map.el (srecode-map-update-map): Make map loading more
robust.
* lisp/cedet/srecode/mode.el (srecode-bind-insert): Call
srecode-load-tables-for-mode.
(srecode-minor-mode-templates-menu): Do not list templates that
are not in the current project.
(srecode-menu-bar): Add binding for srecode-macro-help.
* lisp/cedet/srecode/table.el (srecode-template-table): Add :project slot.
(srecode-dump): Dump it.
* lisp/cedet/srecode/texi.el (srecode-texi-insert-tag-as-doc): New function.
(semantic-insert-foreign-tag): Use it.
Diffstat (limited to 'lisp/cedet/srecode/cpp.el')
| -rw-r--r-- | lisp/cedet/srecode/cpp.el | 82 |
1 files changed, 75 insertions, 7 deletions
diff --git a/lisp/cedet/srecode/cpp.el b/lisp/cedet/srecode/cpp.el index ceaa6fba3aa..7fe2bdaa410 100644 --- a/lisp/cedet/srecode/cpp.el +++ b/lisp/cedet/srecode/cpp.el | |||
| @@ -26,6 +26,27 @@ | |||
| 26 | 26 | ||
| 27 | ;;; Code: | 27 | ;;; Code: |
| 28 | 28 | ||
| 29 | (require 'srecode) | ||
| 30 | (require 'srecode/dictionary) | ||
| 31 | (require 'srecode/semantic) | ||
| 32 | (require 'semantic/tag) | ||
| 33 | |||
| 34 | ;;; Customization | ||
| 35 | ;; | ||
| 36 | |||
| 37 | (defgroup srecode-cpp nil | ||
| 38 | "C++-specific Semantic Recoder settings." | ||
| 39 | :group 'srecode) | ||
| 40 | |||
| 41 | (defcustom srecode-cpp-namespaces | ||
| 42 | '("std" "boost") | ||
| 43 | "List expansion candidates for the :using-namespaces argument. | ||
| 44 | A dictionary entry of the named PREFIX_NAMESPACE with the value | ||
| 45 | NAMESPACE:: is created for each namespace unless the current | ||
| 46 | buffer contains a using NAMESPACE; statement " | ||
| 47 | :group 'srecode-cpp | ||
| 48 | :type '(repeat string)) | ||
| 49 | |||
| 29 | ;;; :cpp ARGUMENT HANDLING | 50 | ;;; :cpp ARGUMENT HANDLING |
| 30 | ;; | 51 | ;; |
| 31 | ;; When a :cpp argument is required, fill the dictionary with | 52 | ;; When a :cpp argument is required, fill the dictionary with |
| @@ -33,10 +54,6 @@ | |||
| 33 | ;; | 54 | ;; |
| 34 | ;; Error if not in a C++ mode. | 55 | ;; Error if not in a C++ mode. |
| 35 | 56 | ||
| 36 | (require 'srecode) | ||
| 37 | (require 'srecode/dictionary) | ||
| 38 | (require 'srecode/semantic) | ||
| 39 | |||
| 40 | ;;;###autoload | 57 | ;;;###autoload |
| 41 | (defun srecode-semantic-handle-:cpp (dict) | 58 | (defun srecode-semantic-handle-:cpp (dict) |
| 42 | "Add macros into the dictionary DICT based on the current c++ file. | 59 | "Add macros into the dictionary DICT based on the current c++ file. |
| @@ -59,6 +76,23 @@ HEADER - Shown section if in a header file." | |||
| 59 | ) | 76 | ) |
| 60 | ) | 77 | ) |
| 61 | 78 | ||
| 79 | (defun srecode-semantic-handle-:using-namespaces (dict) | ||
| 80 | "Add macros into the dictionary DICT based on used namespaces. | ||
| 81 | Adds the following: | ||
| 82 | PREFIX_NAMESPACE - for each NAMESPACE in `srecode-cpp-namespaces'." | ||
| 83 | (let ((tags (semantic-find-tags-by-class | ||
| 84 | 'using (semantic-fetch-tags)))) | ||
| 85 | (dolist (name srecode-cpp-namespaces) | ||
| 86 | (let ((variable (format "PREFIX_%s" (upcase name))) | ||
| 87 | (prefix (format "%s::" name))) | ||
| 88 | (srecode-dictionary-set-value dict variable prefix) | ||
| 89 | (dolist (tag tags) | ||
| 90 | (when (and (eq (semantic-tag-get-attribute tag :kind) | ||
| 91 | 'namespace) | ||
| 92 | (string= (semantic-tag-name tag) name)) | ||
| 93 | (srecode-dictionary-set-value dict variable "")))))) | ||
| 94 | ) | ||
| 95 | |||
| 62 | (define-mode-local-override srecode-semantic-apply-tag-to-dict | 96 | (define-mode-local-override srecode-semantic-apply-tag-to-dict |
| 63 | c++-mode (tag-wrapper dict) | 97 | c++-mode (tag-wrapper dict) |
| 64 | "Apply C++ specific features from TAG-WRAPPER into DICT. | 98 | "Apply C++ specific features from TAG-WRAPPER into DICT. |
| @@ -97,6 +131,7 @@ special behavior for tag of classes include, using and function." | |||
| 97 | (srecode-semantic-tag (semantic-tag-name value-tag) | 131 | (srecode-semantic-tag (semantic-tag-name value-tag) |
| 98 | :prime value-tag) | 132 | :prime value-tag) |
| 99 | value-dict)) | 133 | value-dict)) |
| 134 | |||
| 100 | ;; Discriminate using statements referring to namespaces and | 135 | ;; Discriminate using statements referring to namespaces and |
| 101 | ;; types. | 136 | ;; types. |
| 102 | (when (eq (semantic-tag-get-attribute tag :kind) 'namespace) | 137 | (when (eq (semantic-tag-get-attribute tag :kind) 'namespace) |
| @@ -111,7 +146,8 @@ special behavior for tag of classes include, using and function." | |||
| 111 | ;; when they make sense. My best bet would be | 146 | ;; when they make sense. My best bet would be |
| 112 | ;; (semantic-tag-function-parent tag), but it is not there, when | 147 | ;; (semantic-tag-function-parent tag), but it is not there, when |
| 113 | ;; the function is defined in the scope of a class. | 148 | ;; the function is defined in the scope of a class. |
| 114 | (let ((member 't) | 149 | (let ((member t) |
| 150 | (templates (semantic-tag-get-attribute tag :template)) | ||
| 115 | (modifiers (semantic-tag-modifiers tag))) | 151 | (modifiers (semantic-tag-modifiers tag))) |
| 116 | 152 | ||
| 117 | ;; Add modifiers into the dictionary | 153 | ;; Add modifiers into the dictionary |
| @@ -120,6 +156,9 @@ special behavior for tag of classes include, using and function." | |||
| 120 | dict "MODIFIERS"))) | 156 | dict "MODIFIERS"))) |
| 121 | (srecode-dictionary-set-value modifier-dict "NAME" modifier))) | 157 | (srecode-dictionary-set-value modifier-dict "NAME" modifier))) |
| 122 | 158 | ||
| 159 | ;; Add templates into child dictionaries. | ||
| 160 | (srecode-cpp-apply-templates dict templates) | ||
| 161 | |||
| 123 | ;; When the function is a member function, it can have | 162 | ;; When the function is a member function, it can have |
| 124 | ;; additional modifiers. | 163 | ;; additional modifiers. |
| 125 | (when member | 164 | (when member |
| @@ -133,11 +172,40 @@ special behavior for tag of classes include, using and function." | |||
| 133 | ;; entry. | 172 | ;; entry. |
| 134 | (when (semantic-tag-get-attribute tag :pure-virtual-flag) | 173 | (when (semantic-tag-get-attribute tag :pure-virtual-flag) |
| 135 | (srecode-dictionary-show-section dict "PURE")) | 174 | (srecode-dictionary-show-section dict "PURE")) |
| 136 | ) | 175 | ))) |
| 137 | )) | 176 | |
| 177 | ;; | ||
| 178 | ;; CLASS | ||
| 179 | ;; | ||
| 180 | ((eq class 'type) | ||
| 181 | ;; For classes, add template parameters. | ||
| 182 | (when (or (semantic-tag-of-type-p tag "class") | ||
| 183 | (semantic-tag-of-type-p tag "struct")) | ||
| 184 | |||
| 185 | ;; Add templates into child dictionaries. | ||
| 186 | (let ((templates (semantic-tag-get-attribute tag :template))) | ||
| 187 | (srecode-cpp-apply-templates dict templates)))) | ||
| 138 | )) | 188 | )) |
| 139 | ) | 189 | ) |
| 140 | 190 | ||
| 191 | |||
| 192 | ;;; Helper functions | ||
| 193 | ;; | ||
| 194 | |||
| 195 | (defun srecode-cpp-apply-templates (dict templates) | ||
| 196 | "Add section dictionaries for TEMPLATES to DICT." | ||
| 197 | (when templates | ||
| 198 | (let ((templates-dict (srecode-dictionary-add-section-dictionary | ||
| 199 | dict "TEMPLATES"))) | ||
| 200 | (dolist (template templates) | ||
| 201 | (let ((template-dict (srecode-dictionary-add-section-dictionary | ||
| 202 | templates-dict "ARGS"))) | ||
| 203 | (srecode-semantic-apply-tag-to-dict | ||
| 204 | (srecode-semantic-tag (semantic-tag-name template) | ||
| 205 | :prime template) | ||
| 206 | template-dict))))) | ||
| 207 | ) | ||
| 208 | |||
| 141 | (provide 'srecode/cpp) | 209 | (provide 'srecode/cpp) |
| 142 | 210 | ||
| 143 | ;; Local variables: | 211 | ;; Local variables: |