shithub: sl

ref: 75fa6d220de69bdb91954ea8cf942611b25214cb
dir: /src/docs_extra.lsp/

View raw version
(defmacro (doc-for term (doc nil))
  (let* ((func    (cons? term))
         (sym     (or (and func (car term)) term))
         (val     (or (and (symbol? sym) (top-level-value sym)) sym))
         (funvars (and func (cdr term))))
    (if func
        `(void (symbol-set-doc ',sym ,doc ',funvars))
        `(void (symbol-set-doc ',sym ,doc)))))

(doc-for (= a . rest)
  "Return T if the arguments are equal.")

(doc-for (nan? x)
  "Return T if the argument is NaN, regardless of the sign.")

(doc-for (vm-stats)
  "Print various VM-related information, such as the number of GC calls
so far, heap and stack size, etc.")

(doc-for (lz-pack data (level 0))
  "Return data compressed using Lempel-Ziv.
The data must be an array, returned value will have the same type.
The optional level is between 0 and 10.  With level 0 a simple LZSS
using hashing will be performed.  Levels between 1 and 9 offer a
trade-off between time/space and ratio.  Level 10 is optimal but very
slow.")

(doc-for (lz-unpack data :to destination))
(doc-for (lz-unpack data :size decompressed-bytes)
  "Return decompressed data previously compressed using lz-pack.
Either destination for the decompressed data or the expected size of
the decompressed data must be specified.  In the latter case a new
array is allocated.")

(doc-for (rand)
  "Return a random non-negative fixnum on its maximum range.")

(doc-for (rand-uint64)
  "Return a random integer on [0, 2⁶⁴-1] interval.")

(doc-for (rand-uint32)
  "Return a random integer on [0, 2³²-1] interval.")

(doc-for (rand-double)
  "Return a random double on [0.0, 1.0] interval.")

(doc-for (rand-float)
  "Return a random float on [0.0, 1.0] interval.")