]> git.eshelyaron.com Git - emacs.git/commitdiff
(Finvisible_p): New function.
authorStefan Monnier <monnier@iro.umontreal.ca>
Sat, 25 Aug 2007 20:11:09 +0000 (20:11 +0000)
committerStefan Monnier <monnier@iro.umontreal.ca>
Sat, 25 Aug 2007 20:11:09 +0000 (20:11 +0000)
(syms_of_xdisp): defsubr it.

src/ChangeLog
src/xdisp.c

index 5f2a7d820cdeaca240ff900e5c0cdd0367c96000..b775844bf3b879e642e849d8c8d80f853ea7e370 100644 (file)
@@ -1,3 +1,8 @@
+2007-08-25  Stefan Monnier  <monnier@iro.umontreal.ca>
+
+       * xdisp.c (Finvisible_p): New function.
+       (syms_of_xdisp): defsubr it.
+
 2007-08-24  Juanma Barranquero  <lekktu@gmail.com>
 
        * image.c (syms_of_image) <image-library-alist, cross-disabled-images>:
index b1a837b799a755e920859a32b536ea374398ffb3..da33b05c4c520060a1a440f3bfc58b4c3c699f4e 100644 (file)
@@ -18435,6 +18435,27 @@ invisible_p (propval, list)
   return 0;
 }
 
+DEFUN ("invisible-p", Finvisible_p, Sinvisible_p, 1, 1, 0,
+       doc: /* Non-nil if the property makes the text invisible.
+POS-OR-PROP can be a marker or number, in which case it is taken to be
+a position in the current buffer and the value of the `invisible' property
+is checked; or it can be some other value, which is then presumed to be the
+value of the `invisible' property of the text of interest.
+The non-nil value returned can be t for truly invisible text or something
+else if the text is replaced by an ellipsis.  */)
+     (pos_or_prop)
+     Lisp_Object pos_or_prop;
+{
+  Lisp_Object prop =
+    (NATNUMP (pos_or_prop) || MARKERP (pos_or_prop))
+    ? Fget_char_property (pos_or_prop, Qinvisible, Qnil)
+    : pos_or_prop;
+  int invis = TEXT_PROP_MEANS_INVISIBLE (prop);
+  return (invis == 0 ? Qnil
+         : invis == 1 ? Qt
+         : make_number (invis));
+}
+
 /* Calculate a width or height in pixels from a specification using
    the following elements:
 
@@ -23806,6 +23827,7 @@ syms_of_xdisp ()
   defsubr (&Slookup_image_map);
 #endif
   defsubr (&Sformat_mode_line);
+  defsubr (&Sinvisible_p);
 
   staticpro (&Qmenu_bar_update_hook);
   Qmenu_bar_update_hook = intern ("menu-bar-update-hook");