\f
;;; Cross-reference
-(cl-defstruct (xref-item
- (:constructor xref-make (summary location))
- (:noinline t))
+(defmacro xref--defstruct (name &rest fields)
+ (declare (indent 1))
+ `(cl-defstruct ,(if (>= emacs-major-version 27)
+ name
+ (remq (assq :noinline name) name))
+ ,@fields))
+
+(xref--defstruct (xref-item
+ (:constructor xref-make (summary location))
+ (:noinline t))
"An xref item describes a reference to a location somewhere."
- summary location)
+ (summary nil :documentation "String which describes the location.
+
+ When `xref-location-line' returns non-nil (a number), the summary
+ is implied to be the contents of a file or buffer line containing
+ the location. When multiple locations in a row report the same
+ line, in the same group (corresponding to the case of multiple
+ locations on one line), the summaries are concatenated in the
+ Xref output buffer. Consequently, any code that creates xref
+ values should take care to slice the summary values when several
+ locations point to the same line.
+
+ This behavior is new in Emacs 28.")
+ location)
-(cl-defstruct (xref-match-item
- (:include xref-item)
- (:constructor xref-make-match (summary location length))
- (:noinline t))
+(xref--defstruct (xref-match-item
+ (:include xref-item)
+ (:constructor xref-make-match (summary location length))
+ (:noinline t))
"A match xref item describes a search result."
length)