Mercurial > emacs
view lisp/url/url-ns.el @ 108011:12062a99ca8d
Add SELinux support.
* configure.in: New option: --with(out)-selinux, on by default.
Set HAVE_LIBSELINUX if we find libselinux, and substitute
LIBSELINUX_LIBS in Makefiles.
* src/Makefile.in (LIBSELINUX_LIBS): New.
(LIBES): Add $LIBSELINUX_LIBS.
* src/eval.c, lisp.h (call7): New function.
* src/fileio.c [HAVE_LIBSELINUX]: Include selinux headers.
(Ffile_selinux_context, Fset_file_selinux_context):
New functions.
(Fcopy_file): New parameter preserve-selinux-context.
(Frename_file): Preserve selinux context when renaming by copy-file.
* lisp/files.el (backup-buffer): Handle SELinux context, and return it
if a backup was made by renaming.
(backup-buffer-copy): Set SELinux context to the target file.
(basic-save-buffer): Set SELinux context of the newly written file.
(basic-save-buffer-1): Now it also returns any SELinux context.
(basic-save-buffer-2): Set SELinux context of the newly created file,
and return it.
* lisp/net/tramp.el (tramp-file-name-for-operation):
Add file-selinux-context.
author | Glenn Morris <rgm@gnu.org> |
---|---|
date | Tue, 20 Apr 2010 20:02:58 -0700 |
parents | 1d1d5d9bd884 |
children | 376148b31b5e |
line wrap: on
line source
;;; url-ns.el --- Various netscape-ish functions for proxy definitions ;; Copyright (C) 1997, 1998, 1999, 2004, 2005, ;; 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. ;; Keywords: comm, data, processes, hypermedia ;; This file is part of GNU Emacs. ;; GNU Emacs 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. ;; GNU Emacs 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 GNU Emacs. If not, see <http://www.gnu.org/licenses/>. ;;; Code: (require 'url-gw) ;;;###autoload (defun isPlainHostName (host) (not (string-match "\\." host))) ;;;###autoload (defun dnsDomainIs (host dom) (string-match (concat (regexp-quote dom) "$") host)) ;;;###autoload (defun dnsResolve (host) (url-gateway-nslookup-host host)) ;;;###autoload (defun isResolvable (host) (if (string-match "^[0-9.]+$" host) t (not (string= host (url-gateway-nslookup-host host))))) ;;;###autoload (defun isInNet (ip net mask) (let ((netc (split-string ip "\\.")) (ipc (split-string net "\\.")) (maskc (split-string mask "\\."))) (if (or (/= (length netc) (length ipc)) (/= (length ipc) (length maskc))) nil (setq netc (mapcar 'string-to-number netc) ipc (mapcar 'string-to-number ipc) maskc (mapcar 'string-to-number maskc)) (and (= (logand (nth 0 netc) (nth 0 maskc)) (logand (nth 0 ipc) (nth 0 maskc))) (= (logand (nth 1 netc) (nth 1 maskc)) (logand (nth 1 ipc) (nth 1 maskc))) (= (logand (nth 2 netc) (nth 2 maskc)) (logand (nth 2 ipc) (nth 2 maskc))) (= (logand (nth 3 netc) (nth 3 maskc)) (logand (nth 3 ipc) (nth 3 maskc))))))) ;; Netscape configuration file parsing (defvar url-ns-user-prefs nil "Internal, do not use.") ;;;###autoload (defun url-ns-prefs (&optional file) (if (not file) (setq file (expand-file-name "~/.netscape/preferences.js"))) (if (not (and (file-exists-p file) (file-readable-p file))) (message "Could not open %s for reading" file) (save-excursion (let ((false nil) (true t)) (setq url-ns-user-prefs (make-hash-table :size 13 :test 'equal)) (set-buffer (get-buffer-create " *ns-parse*")) (erase-buffer) (insert-file-contents file) (goto-char (point-min)) (while (re-search-forward "^//" nil t) (replace-match ";;")) (goto-char (point-min)) (while (re-search-forward "^user_pref(" nil t) (replace-match "(url-ns-set-user-pref ")) (goto-char (point-min)) (while (re-search-forward "\"," nil t) (replace-match "\"")) (goto-char (point-min)) (eval-buffer))))) (defun url-ns-set-user-pref (key val) (puthash key val url-ns-user-prefs)) ;;;###autoload (defun url-ns-user-pref (key &optional default) (gethash key url-ns-user-prefs default)) (provide 'url-ns) ;; arch-tag: 69520992-cf97-40b4-9ad1-c866d3cae5bf ;;; url-ns.el ends here