From: Xue Fuqiao Date: Sun, 22 Dec 2013 07:11:05 +0000 (+0800) Subject: Document new bool-vector set operation functions. X-Git-Tag: emacs-24.3.90~173^2^2~42^2~45^2~387^2~249 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=8fc36a68035c3145d90460de481aa78eda3c8d86;p=emacs.git Document new bool-vector set operation functions. * doc/lispref/sequences.texi (Bool-Vectors): Document new bool-vector set operation functions. --- diff --git a/doc/lispref/ChangeLog b/doc/lispref/ChangeLog index a92ae299250..d03f6ae39da 100644 --- a/doc/lispref/ChangeLog +++ b/doc/lispref/ChangeLog @@ -1,5 +1,7 @@ 2013-12-22 Xue Fuqiao + * sequences.texi (Bool-Vectors): Document new bool-vector set operation functions. + * text.texi (Examining Properties): Document `get-pos-property'. * variables.texi (Directory Local Variables): Document `enable-dir-local-variables'. diff --git a/doc/lispref/sequences.texi b/doc/lispref/sequences.texi index 00384de7ec8..acf8cb38ade 100644 --- a/doc/lispref/sequences.texi +++ b/doc/lispref/sequences.texi @@ -711,6 +711,54 @@ each one initialized to @var{initial}. @defun bool-vector-p object This returns @code{t} if @var{object} is a bool-vector, and @code{nil} otherwise. +@end defun + +There are also some bool-vector set operation functions, described below: + +@defun bool-vector-exclusive-or a b &optional c +Return @dfn{bitwise exclusive or} of bool vectors @var{a} and @var{b}. +If optional argument @var{c} is given, the result of this operation is +stored into @var{c}. All arguments should be bool vectors of the same length. +@end defun + +@defun bool-vector-union a b &optional c +Return @dfn{bitwise or} of bool vectors @var{a} and @var{b}. If +optional argument @var{c} is given, the result of this operation is +stored into @var{c}. All arguments should be bool vectors of the same length. +@end defun + +@defun bool-vector-intersection a b &optional c +Return @dfn{bitwise and} of bool vectors @var{a} and @var{b}. If +optional argument @var{c} is given, the result of this operation is +stored into @var{c}. All arguments should be bool vectors of the same length. +@end defun + +@defun bool-vector-set-difference a b &optional c +Return @dfn{set difference} of bool vectors @var{a} and @var{b}. If +optional argument @var{c} is given, the result of this operation is +stored into @var{c}. All arguments should be bool vectors of the same length. +@end defun + +@defun bool-vector-not a &optional b +Return @dfn{set complement} of bool vector @var{a}. If optional +argument @var{b} is given, the result of this operation is stored into +@var{b}. All arguments should be bool vectors of the same length. +@end defun + +@defun bool-vector-subsetp a b +Return @code{t} if every @code{t} value in @var{a} is also t in +@var{b}, nil otherwise. All arguments should be bool vectors of the +same length. +@end defun + +@defun bool-vector-count-consecutive a b i +Return the number of consecutive elements in @var{a} equal @var{b} +starting at @var{i}. @code{a} is a bool vector, @var{b} is @code{t} +or @code{nil}, and @var{i} is an index into @code{a}. +@end defun + +@defun bool-vector-count-population a +Return the number of elements that are @code{t} in bool vector @var{a}. @end defun Here is an example of creating, examining, and updating a diff --git a/etc/NEWS b/etc/NEWS index e3c902e66d8..374f313733d 100644 --- a/etc/NEWS +++ b/etc/NEWS @@ -923,6 +923,7 @@ The function `display-popup-menus-p' will now return non-nil for a display or frame whenever a mouse is supported on that display or frame. ++++ ** New bool-vector set operation functions: *** `bool-vector-exclusive-or' *** `bool-vector-union'