Mercurial > hg > xemacs-beta
view lisp/check-features.el @ 5891:a0e751d6c3ad
Import the #'clear-string API from GNU, use it in tls.c
src/ChangeLog addition:
2015-04-18 Aidan Kehoe <kehoea@parhasard.net>
* sequence.c (Fclear_string): New, API from GNU. Zero a string's
contents, making sure the text is not kept around even when the
string's data is reallocated because of a changed character
length.
* sequence.c (syms_of_sequence): Make it available to Lisp.
* lisp.h: Make it available to C code.
* tls.c (nss_pk11_password): Use it.
* tls.c (gnutls_pk11_password): Use it.
* tls.c (openssl_password): Use it.
tests/ChangeLog addition:
2015-04-18 Aidan Kehoe <kehoea@parhasard.net>
* automated/lisp-tests.el:
Test #'clear-string, just added. Unfortunately there's no way to
be certain from Lisp that the old password data has been erased
after realloc; it may be worth adding a test to tests.c, but
*we'll be reading memory we shouldn't be*, so that gives me pause.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sat, 18 Apr 2015 23:00:14 +0100 |
parents | 308d34e9f07d |
children |
line wrap: on
line source
;;; check-features.el --- Do a sanity check on an XEmacs build ;; Copyright (C) 1998 by Free Software Foundation, Inc. ;; Copyright (C) 2002 Ben Wing. ;; Author: SL Baur <steve@xemacs.org> ;; Keywords: internal ;; This file is part of XEmacs. ;; XEmacs is free software: you can redistribute it and/or modify it ;; under the terms of the GNU General Public License as published by the ;; Free Software Foundation, either version 3 of the License, or (at your ;; option) any later version. ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ;; for more details. ;; You should have received a copy of the GNU General Public License ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>. ;;; Synched up with: Not in FSF ;;; Commentary: ;; This file is executed after a build to check that all lisp packages that ;; need to be installed are. ;;; Code: (require 'packages) (defvar build-error 0) (when (featurep 'tooltalk) (condition-case nil (package-require 'tooltalk 1.0) (t (progn ;; (setq build-error 1) (lwarn 'tooltalk 'alert "Warning: This XEmacs is built with tooltalk support but does not have a tooltalk package installed. Without the tooltalk lisp package, Tooltalk support is broken."))))) (when (featurep 'sparcworks) (condition-case nil (package-require 'Sun 1.0) (t (progn ;; (setq build-error 1) (lwarn 'sparcworks 'alert "Warning: This XEmacs is built with sparcworks support but does not have the Sun package installed. Without the Sun lisp package, Sparcworks support will be broken."))))) (kill-emacs build-error) ;;; check-features.el ends here