Mercurial > hg > xemacs-beta
annotate lisp/find-paths.el @ 4952:19a72041c5ed
Mule-izing, various fixes related to char * arguments
-------------------- ChangeLog entries follow: --------------------
modules/ChangeLog addition:
2010-01-26 Ben Wing <ben@xemacs.org>
* postgresql/postgresql.c:
* postgresql/postgresql.c (CHECK_LIVE_CONNECTION):
* postgresql/postgresql.c (print_pgresult):
* postgresql/postgresql.c (Fpq_conn_defaults):
* postgresql/postgresql.c (Fpq_connectdb):
* postgresql/postgresql.c (Fpq_connect_start):
* postgresql/postgresql.c (Fpq_result_status):
* postgresql/postgresql.c (Fpq_res_status):
Mule-ize large parts of it.
2010-01-26 Ben Wing <ben@xemacs.org>
* ldap/eldap.c (print_ldap):
* ldap/eldap.c (allocate_ldap):
Use write_ascstring().
src/ChangeLog addition:
2010-01-26 Ben Wing <ben@xemacs.org>
* alloc.c:
* alloc.c (build_ascstring):
* alloc.c (build_msg_cistring):
* alloc.c (staticpro_1):
* alloc.c (staticpro_name):
* alloc.c (staticpro_nodump_1):
* alloc.c (staticpro_nodump_name):
* alloc.c (unstaticpro_nodump_1):
* alloc.c (mcpro_1):
* alloc.c (mcpro_name):
* alloc.c (object_memory_usage_stats):
* alloc.c (common_init_alloc_early):
* alloc.c (init_alloc_once_early):
* buffer.c (print_buffer):
* buffer.c (vars_of_buffer):
* buffer.c (common_init_complex_vars_of_buffer):
* buffer.c (init_initial_directory):
* bytecode.c (invalid_byte_code):
* bytecode.c (print_compiled_function):
* bytecode.c (mark_compiled_function):
* chartab.c (print_table_entry):
* chartab.c (print_char_table):
* config.h.in:
* console-gtk.c:
* console-gtk.c (gtk_device_to_console_connection):
* console-gtk.c (gtk_semi_canonicalize_console_connection):
* console-gtk.c (gtk_canonicalize_console_connection):
* console-gtk.c (gtk_semi_canonicalize_device_connection):
* console-gtk.c (gtk_canonicalize_device_connection):
* console-stream.c (stream_init_frame_1):
* console-stream.c (vars_of_console_stream):
* console-stream.c (init_console_stream):
* console-x.c (x_semi_canonicalize_console_connection):
* console-x.c (x_semi_canonicalize_device_connection):
* console-x.c (x_canonicalize_device_connection):
* console-x.h:
* data.c (eq_with_ebola_notice):
* data.c (Fsubr_interactive):
* data.c (Fnumber_to_string):
* data.c (digit_to_number):
* device-gtk.c (gtk_init_device):
* device-msw.c (print_devmode):
* device-x.c (x_event_name):
* dialog-msw.c (handle_directory_dialog_box):
* dialog-msw.c (handle_file_dialog_box):
* dialog-msw.c (vars_of_dialog_mswindows):
* doc.c (weird_doc):
* doc.c (Fsnarf_documentation):
* doc.c (vars_of_doc):
* dumper.c (pdump):
* dynarr.c:
* dynarr.c (Dynarr_realloc):
* editfns.c (Fuser_real_login_name):
* editfns.c (get_home_directory):
* elhash.c (print_hash_table_data):
* elhash.c (print_hash_table):
* emacs.c (main_1):
* emacs.c (vars_of_emacs):
* emodules.c:
* emodules.c (_emodules_list):
* emodules.c (Fload_module):
* emodules.c (Funload_module):
* emodules.c (Flist_modules):
* emodules.c (find_make_module):
* emodules.c (attempt_module_delete):
* emodules.c (emodules_load):
* emodules.c (emodules_doc_subr):
* emodules.c (emodules_doc_sym):
* emodules.c (syms_of_module):
* emodules.c (vars_of_module):
* emodules.h:
* eval.c (print_subr):
* eval.c (signal_call_debugger):
* eval.c (build_error_data):
* eval.c (signal_error):
* eval.c (maybe_signal_error):
* eval.c (signal_continuable_error):
* eval.c (maybe_signal_continuable_error):
* eval.c (signal_error_2):
* eval.c (maybe_signal_error_2):
* eval.c (signal_continuable_error_2):
* eval.c (maybe_signal_continuable_error_2):
* eval.c (signal_ferror):
* eval.c (maybe_signal_ferror):
* eval.c (signal_continuable_ferror):
* eval.c (maybe_signal_continuable_ferror):
* eval.c (signal_ferror_with_frob):
* eval.c (maybe_signal_ferror_with_frob):
* eval.c (signal_continuable_ferror_with_frob):
* eval.c (maybe_signal_continuable_ferror_with_frob):
* eval.c (syntax_error):
* eval.c (syntax_error_2):
* eval.c (maybe_syntax_error):
* eval.c (sferror):
* eval.c (sferror_2):
* eval.c (maybe_sferror):
* eval.c (invalid_argument):
* eval.c (invalid_argument_2):
* eval.c (maybe_invalid_argument):
* eval.c (invalid_constant):
* eval.c (invalid_constant_2):
* eval.c (maybe_invalid_constant):
* eval.c (invalid_operation):
* eval.c (invalid_operation_2):
* eval.c (maybe_invalid_operation):
* eval.c (invalid_change):
* eval.c (invalid_change_2):
* eval.c (maybe_invalid_change):
* eval.c (invalid_state):
* eval.c (invalid_state_2):
* eval.c (maybe_invalid_state):
* eval.c (wtaerror):
* eval.c (stack_overflow):
* eval.c (out_of_memory):
* eval.c (print_multiple_value):
* eval.c (issue_call_trapping_problems_warning):
* eval.c (backtrace_specials):
* eval.c (backtrace_unevalled_args):
* eval.c (Fbacktrace):
* eval.c (warn_when_safe):
* event-Xt.c (modwarn):
* event-Xt.c (modbarf):
* event-Xt.c (check_modifier):
* event-Xt.c (store_modifier):
* event-Xt.c (emacs_Xt_format_magic_event):
* event-Xt.c (describe_event):
* event-gtk.c (dragndrop_data_received):
* event-gtk.c (store_modifier):
* event-gtk.c (gtk_reset_modifier_mapping):
* event-msw.c (dde_eval_string):
* event-msw.c (Fdde_alloc_advise_item):
* event-msw.c (mswindows_dde_callback):
* event-msw.c (FROB):
* event-msw.c (emacs_mswindows_format_magic_event):
* event-stream.c (external_debugging_print_event):
* event-stream.c (execute_help_form):
* event-stream.c (vars_of_event_stream):
* events.c (print_event_1):
* events.c (print_event):
* events.c (event_equal):
* extents.c (print_extent_1):
* extents.c (print_extent):
* extents.c (vars_of_extents):
* faces.c (print_face):
* faces.c (complex_vars_of_faces):
* file-coding.c:
* file-coding.c (print_coding_system):
* file-coding.c (print_coding_system_in_print_method):
* file-coding.c (default_query_method):
* file-coding.c (find_coding_system):
* file-coding.c (make_coding_system_1):
* file-coding.c (chain_print):
* file-coding.c (undecided_print):
* file-coding.c (gzip_print):
* file-coding.c (vars_of_file_coding):
* file-coding.c (complex_vars_of_file_coding):
* fileio.c:
* fileio.c (report_file_type_error):
* fileio.c (report_error_with_errno):
* fileio.c (report_file_error):
* fileio.c (barf_or_query_if_file_exists):
* fileio.c (vars_of_fileio):
* floatfns.c (matherr):
* fns.c (print_bit_vector):
* fns.c (Fmapconcat):
* fns.c (add_suffix_to_symbol):
* fns.c (add_prefix_to_symbol):
* frame-gtk.c:
* frame-gtk.c (Fgtk_window_id):
* frame-x.c (def):
* frame-x.c (x_cde_transfer_callback):
* frame.c:
* frame.c (Fmake_frame):
* gc.c (show_gc_cursor_and_message):
* gc.c (vars_of_gc):
* glyphs-eimage.c (png_instantiate):
* glyphs-eimage.c (tiff_instantiate):
* glyphs-gtk.c (gtk_print_image_instance):
* glyphs-msw.c (mswindows_print_image_instance):
* glyphs-x.c (x_print_image_instance):
* glyphs-x.c (update_widget_face):
* glyphs.c (make_string_from_file):
* glyphs.c (print_image_instance):
* glyphs.c (signal_image_error):
* glyphs.c (signal_image_error_2):
* glyphs.c (signal_double_image_error):
* glyphs.c (signal_double_image_error_2):
* glyphs.c (xbm_mask_file_munging):
* glyphs.c (pixmap_to_lisp_data):
* glyphs.h:
* gui.c (gui_item_display_flush_left):
* hpplay.c (player_error_internal):
* hpplay.c (myHandler):
* intl-win32.c:
* intl-win32.c (langcode_to_lang):
* intl-win32.c (sublangcode_to_lang):
* intl-win32.c (Fmswindows_get_locale_info):
* intl-win32.c (lcid_to_locale_mule_or_no):
* intl-win32.c (mswindows_multibyte_to_unicode_print):
* intl-win32.c (complex_vars_of_intl_win32):
* keymap.c:
* keymap.c (print_keymap):
* keymap.c (ensure_meta_prefix_char_keymapp):
* keymap.c (Fkey_description):
* keymap.c (Ftext_char_description):
* lisp.h:
* lisp.h (struct):
* lisp.h (DECLARE_INLINE_HEADER):
* lread.c (Fload_internal):
* lread.c (locate_file):
* lread.c (read_escape):
* lread.c (read_raw_string):
* lread.c (read1):
* lread.c (read_list):
* lread.c (read_compiled_function):
* lread.c (init_lread):
* lrecord.h:
* marker.c (print_marker):
* marker.c (marker_equal):
* menubar-msw.c (displayable_menu_item):
* menubar-x.c (command_builder_operate_menu_accelerator):
* menubar.c (vars_of_menubar):
* minibuf.c (reinit_complex_vars_of_minibuf):
* minibuf.c (complex_vars_of_minibuf):
* mule-charset.c (Fmake_charset):
* mule-charset.c (complex_vars_of_mule_charset):
* mule-coding.c (iso2022_print):
* mule-coding.c (fixed_width_query):
* number.c (bignum_print):
* number.c (ratio_print):
* number.c (bigfloat_print):
* number.c (bigfloat_finalize):
* objects-msw.c:
* objects-msw.c (mswindows_color_to_string):
* objects-msw.c (mswindows_color_list):
* objects-tty.c:
* objects-tty.c (tty_font_list):
* objects-tty.c (tty_find_charset_font):
* objects-xlike-inc.c (xft_find_charset_font):
* objects-xlike-inc.c (endif):
* print.c:
* print.c (write_istring):
* print.c (write_ascstring):
* print.c (Fterpri):
* print.c (Fprint):
* print.c (print_error_message):
* print.c (print_vector_internal):
* print.c (print_cons):
* print.c (print_string):
* print.c (printing_unreadable_object):
* print.c (print_internal):
* print.c (print_float):
* print.c (print_symbol):
* process-nt.c (mswindows_report_winsock_error):
* process-nt.c (nt_canonicalize_host_name):
* process-unix.c (unix_canonicalize_host_name):
* process.c (print_process):
* process.c (report_process_error):
* process.c (report_network_error):
* process.c (make_process_internal):
* process.c (Fstart_process_internal):
* process.c (status_message):
* process.c (putenv_internal):
* process.c (vars_of_process):
* process.h:
* profile.c (vars_of_profile):
* rangetab.c (print_range_table):
* realpath.c (vars_of_realpath):
* redisplay.c (vars_of_redisplay):
* search.c (wordify):
* search.c (Freplace_match):
* sheap.c (sheap_adjust_h):
* sound.c (report_sound_error):
* sound.c (Fplay_sound_file):
* specifier.c (print_specifier):
* symbols.c (Fsubr_name):
* symbols.c (do_symval_forwarding):
* symbols.c (set_default_buffer_slot_variable):
* symbols.c (set_default_console_slot_variable):
* symbols.c (store_symval_forwarding):
* symbols.c (default_value):
* symbols.c (defsymbol_massage_name_1):
* symbols.c (defsymbol_massage_name_nodump):
* symbols.c (defsymbol_massage_name):
* symbols.c (defsymbol_massage_multiword_predicate_nodump):
* symbols.c (defsymbol_massage_multiword_predicate):
* symbols.c (defsymbol_nodump):
* symbols.c (defsymbol):
* symbols.c (defkeyword):
* symbols.c (defkeyword_massage_name):
* symbols.c (check_module_subr):
* symbols.c (deferror_1):
* symbols.c (deferror):
* symbols.c (deferror_massage_name):
* symbols.c (deferror_massage_name_and_message):
* symbols.c (defvar_magic):
* symeval.h:
* symeval.h (DEFVAR_SYMVAL_FWD):
* sysdep.c:
* sysdep.c (init_system_name):
* sysdll.c:
* sysdll.c (MAYBE_PREPEND_UNDERSCORE):
* sysdll.c (dll_function):
* sysdll.c (dll_variable):
* sysdll.c (dll_error):
* sysdll.c (dll_open):
* sysdll.c (dll_close):
* sysdll.c (image_for_address):
* sysdll.c (my_find_image):
* sysdll.c (search_linked_libs):
* sysdll.h:
* sysfile.h:
* sysfile.h (DEFAULT_DIRECTORY_FALLBACK):
* syswindows.h:
* tests.c (DFC_CHECK_LENGTH):
* tests.c (DFC_CHECK_CONTENT):
* tests.c (Ftest_hash_tables):
* text.c (vars_of_text):
* text.h:
* tooltalk.c (tt_opnum_string):
* tooltalk.c (tt_message_arg_ival_string):
* tooltalk.c (Ftooltalk_default_procid):
* tooltalk.c (Ftooltalk_default_session):
* tooltalk.c (init_tooltalk):
* tooltalk.c (vars_of_tooltalk):
* ui-gtk.c (Fdll_load):
* ui-gtk.c (type_to_marshaller_type):
* ui-gtk.c (Fgtk_import_function_internal):
* ui-gtk.c (emacs_gtk_object_printer):
* ui-gtk.c (emacs_gtk_boxed_printer):
* unicode.c (unicode_to_ichar):
* unicode.c (unicode_print):
* unicode.c (unicode_query):
* unicode.c (vars_of_unicode):
* unicode.c (complex_vars_of_unicode):
* win32.c:
* win32.c (mswindows_report_process_error):
* window.c (print_window):
* xemacs.def.in.in:
BASIC IDEA: Further fixing up uses of char * and CIbyte *
to reflect their actual semantics; Mule-izing some code;
redoing of the not-yet-working code to handle message translation.
Clean up code to handle message-translation (not yet working).
Create separate versions of build_msg_string() for working with
Ibyte *, CIbyte *, and Ascbyte * arguments. Assert that Ascbyte *
arguments are pure-ASCII. Make build_msg_string() be the same
as build_msg_ascstring(). Create same three versions of GETTEXT()
and DEFER_GETTEXT(). Also create build_defer_string() and
variants for the equivalent of DEFER_GETTEXT() when building a
string. Remove old CGETTEXT(). Clean up code where GETTEXT(),
DEFER_GETTEXT(), build_msg_string(), etc. was being called and
introduce some new calls to build_msg_string(), etc. Remove
GETTEXT() from calls to weird_doc() -- we assume that the
message snarfer knows about weird_doc(). Remove uses of
DEFER_GETTEXT() from error messages in sysdep.c and instead use
special comments /* @@@begin-snarf@@@ */ and /* @@@end-snarf@@@ */
that the message snarfer presumably knows about.
Create build_ascstring() and use it in many instances in place
of build_string(). The purpose of having Ascbyte * variants is
to make the code more self-documenting in terms of what sort of
semantics is expected for char * strings. In fact in the process
of looking for uses of build_string(), much improperly Mule-ized
was discovered.
Mule-ize a lot of code as described in previous paragraph,
e.g. in sysdep.c.
Make the error functions take Ascbyte * strings and fix up a
couple of places where non-pure-ASCII strings were being passed in
(file-coding.c, mule-coding.c, unicode.c). (It's debatable whether
we really need to make the error functions work this way. It
helps catch places where code is written in a way that message
translation won't work, but we may well never implement message
translation.)
Make staticpro() and friends take Ascbyte * strings instead of
raw char * strings. Create a const_Ascbyte_ptr dynarr type
to describe what's held by staticpro_names[] and friends,
create pdump descriptions for const_Ascbyte_ptr dynarrs, and
use them in place of specially-crafted staticpro descriptions.
Mule-ize certain other functions (e.g. x_event_name) by correcting
raw use of char * to Ascbyte *, Rawbyte * or another such type,
and raw use of char[] buffers to another type (usually Ascbyte[]).
Change many uses of write_c_string() to write_msg_string(),
write_ascstring(), etc.
Mule-ize emodules.c, emodules.h, sysdll.h.
Fix some un-Mule-ized code in intl-win32.c.
A comment in event-Xt.c and the limitations of the message
snarfer (make-msgfile or whatever) is presumably incorrect --
it should be smart enough to handle function calls spread over
more than one line. Clean up code in event-Xt.c that was
written awkwardly for this reason.
In config.h.in, instead of NEED_ERROR_CHECK_TYPES_INLINES,
create a more general XEMACS_DEFS_NEEDS_INLINE_DECLS to
indicate when inlined functions need to be declared in
xemacs.defs.in.in, and make use of it in xemacs.defs.in.in.
We need to do this because postgresql.c now calls qxestrdup(),
which is an inline function.
Make nconc2() and other such functions MODULE_API and put
them in xemacs.defs.in.in since postgresql.c now uses them.
Clean up indentation in lread.c and a few other places.
In text.h, document ASSERT_ASCTEXT_ASCII() and
ASSERT_ASCTEXT_ASCII_LEN(), group together the stand-in
encodings and add some more for DLL symbols, function and
variable names, etc.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Tue, 26 Jan 2010 23:22:30 -0600 |
parents | 5da4cc7d5968 |
children | 9c6ea1581159 |
rev | line source |
---|---|
428 | 1 ;;; find-paths.el --- setup various XEmacs paths |
2 | |
3 ;; Copyright (C) 1985-1986, 1990, 1992-1997 Free Software Foundation, Inc. | |
4 ;; Copyright (c) 1993, 1994 Sun Microsystems, Inc. | |
5 ;; Copyright (C) 1995 Board of Trustees, University of Illinois | |
1330 | 6 ;; Copyright (C) 2003 Ben Wing. |
428 | 7 |
2456 | 8 ;; Author: Mike Sperber <mike@xemacs.org> |
428 | 9 ;; Maintainer: XEmacs Development Team |
10 ;; Keywords: internal, dumped | |
11 | |
12 ;; This file is part of XEmacs. | |
13 | |
14 ;; XEmacs is free software; you can redistribute it and/or modify it | |
15 ;; under the terms of the GNU General Public License as published by | |
16 ;; the Free Software Foundation; either version 2, or (at your option) | |
17 ;; any later version. | |
18 | |
19 ;; XEmacs is distributed in the hope that it will be useful, but | |
20 ;; WITHOUT ANY WARRANTY; without even the implied warranty of | |
21 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
22 ;; General Public License for more details. | |
23 | |
24 ;; You should have received a copy of the GNU General Public License | |
25 ;; along with XEmacs; see the file COPYING. If not, write to the | |
26 ;; Free Software Foundation, 59 Temple Place - Suite 330, | |
27 ;; Boston, MA 02111-1307, USA. | |
28 | |
29 ;;; Synched up with: Not in FSF. | |
30 | |
31 ;;; Commentary: | |
32 | |
33 ;; This file is dumped with XEmacs. | |
34 | |
776 | 35 ;; This file contains basic library functionality for manipulating paths |
36 ;; and path lists and finding paths in the XEmacs hierarchy. | |
37 | |
428 | 38 |
39 ;;; Code: | |
40 | |
41 (defvar paths-version-control-filename-regexp | |
42 "^\\(RCS\\|CVS\\|SCCS\\)$" | |
43 "File bases associated with version control.") | |
44 | |
45 (defvar paths-lisp-filename-regexp | |
46 "^\\(.*\\.elc?\\)$" | |
2297 | 47 "File bases that name Emacs Lisp files.") |
428 | 48 |
49 (defvar paths-no-lisp-directory-regexp | |
50 (concat "\\(" paths-version-control-filename-regexp "\\)" | |
51 "\\|" | |
52 "\\(" paths-lisp-filename-regexp "\\)") | |
53 "File bases that may not be directories containing Lisp code.") | |
54 | |
55 (defun paths-find-recursive-path (directories &optional max-depth exclude-regexp) | |
56 "Return a list of the directory hierarchy underneath DIRECTORIES. | |
57 The returned list is sorted by pre-order and lexicographically. | |
58 MAX-DEPTH limits the depth of the search to MAX-DEPTH level, | |
59 if it is a number. If MAX-DEPTH is NIL, the search depth is unlimited. | |
60 EXCLUDE-REGEXP is a regexp that matches directory names to exclude | |
61 from the search." | |
62 (let ((path '())) | |
63 (while directories | |
64 (let ((directory (file-name-as-directory | |
65 (expand-file-name | |
66 (car directories))))) | |
67 (if (paths-file-readable-directory-p directory) | |
68 (let ((raw-entries | |
69 (if (equal 0 max-depth) | |
70 '() | |
71 (directory-files directory nil "^[^.-]"))) | |
72 (reverse-dirs '())) | |
73 (while raw-entries | |
531 | 74 (if (not (and exclude-regexp |
75 (string-match exclude-regexp (car raw-entries)))) | |
428 | 76 (setq reverse-dirs |
77 (cons (expand-file-name (car raw-entries) directory) | |
78 reverse-dirs))) | |
79 (setq raw-entries (cdr raw-entries))) | |
80 | |
81 (let ((sub-path | |
82 (paths-find-recursive-path (reverse reverse-dirs) | |
83 (if (numberp max-depth) | |
84 (- max-depth 1) | |
85 max-depth) | |
86 exclude-regexp))) | |
87 (setq path (nconc path | |
88 (list directory) | |
89 sub-path)))))) | |
90 (setq directories (cdr directories))) | |
91 path)) | |
92 | |
93 (defun paths-file-readable-directory-p (filename) | |
94 "Check if filename is a readable directory." | |
95 (and (file-directory-p filename) | |
96 (file-readable-p filename))) | |
97 | |
98 (defun paths-find-recursive-load-path (directories &optional max-depth) | |
99 "Construct a recursive load path underneath DIRECTORIES." | |
100 (paths-find-recursive-path directories | |
101 max-depth paths-no-lisp-directory-regexp)) | |
102 | |
103 (defun paths-chase-symlink (file-name) | |
104 "Chase a symlink until the bitter end." | |
105 (let ((maybe-symlink (file-symlink-p file-name))) | |
106 (if maybe-symlink | |
107 (let* ((directory (file-name-directory file-name)) | |
108 (destination (expand-file-name maybe-symlink directory))) | |
109 (paths-chase-symlink destination)) | |
110 file-name))) | |
111 | |
112 (defun paths-construct-path (components &optional expand-directory) | |
113 "Convert list of path components COMPONENTS into a path. | |
114 If EXPAND-DIRECTORY is non-NIL, use it as a directory to feed | |
115 to EXPAND-FILE-NAME." | |
116 (let* ((reverse-components (reverse components)) | |
117 (last-component (car reverse-components)) | |
118 (first-components (reverse (cdr reverse-components))) | |
119 (path | |
120 (apply #'concat | |
121 (append (mapcar #'file-name-as-directory first-components) | |
122 (list last-component))))) | |
123 (if expand-directory | |
124 (expand-file-name path expand-directory) | |
125 path))) | |
126 | |
127 (defun paths-construct-emacs-directory (root suffix base) | |
2456 | 128 "Construct a directory name within the XEmacs hierarchy. |
3753 | 129 ROOT must be an installation root. |
2456 | 130 SUFFIX is the subdirectory from there. |
131 BASE is the base to look for." | |
428 | 132 (file-name-as-directory |
133 (expand-file-name | |
134 (concat | |
135 (file-name-as-directory root) | |
136 suffix | |
137 base)))) | |
138 | |
2481 | 139 |
140 (defun paths-for-each-emacs-directory (func | |
4108 | 141 roots suffix bases |
2481 | 142 &optional envvar default keep-suffix) |
143 "Iterate over directories in the XEmacs hierarchy. | |
144 FUNC is a function that called for each directory, with the directory | |
145 as the only argument. | |
428 | 146 ROOTS must be a list of installation roots. |
147 SUFFIX is the subdirectory from there. | |
4108 | 148 BASEA is a list of possible bases to look for. |
428 | 149 ENVVAR is the name of the environment variable that might also |
150 specify the directory. | |
151 DEFAULT is the preferred value. | |
152 If KEEP-SUFFIX is non-nil, the suffix must be respected in searching | |
1218 | 153 the directory." |
428 | 154 (let ((preferred-value (or (and envvar (getenv envvar)) |
155 default))) | |
156 (if (and preferred-value | |
157 (paths-file-readable-directory-p preferred-value)) | |
158 (file-name-as-directory preferred-value) | |
2481 | 159 (while roots |
4108 | 160 (let ((root (car roots)) |
161 (bases bases)) | |
162 (while bases | |
163 (let* ((base (car bases)) | |
164 ;; installed | |
165 (path (paths-construct-emacs-directory root suffix base))) | |
166 (if (paths-file-readable-directory-p path) | |
167 (funcall func path) | |
168 ;; in-place | |
169 (if (null keep-suffix) | |
170 (let ((path (paths-construct-emacs-directory root "" base))) | |
171 (if (paths-file-readable-directory-p path) | |
172 (funcall func path)))))) | |
173 (setq bases (cdr bases)))) | |
2481 | 174 (setq roots (cdr roots)))))) |
175 | |
176 (defun paths-find-emacs-directories (roots | |
4108 | 177 suffix bases |
2481 | 178 &optional envvar default keep-suffix) |
179 "Find a list of directories in the XEmacs hierarchy. | |
180 ROOTS must be a list of installation roots. | |
181 SUFFIX is the subdirectory from there. | |
4108 | 182 BASES is a list of bases to look for. |
2481 | 183 ENVVAR is the name of the environment variable that might also |
184 specify the directory. | |
185 DEFAULT is the preferred value. | |
186 If KEEP-SUFFIX is non-nil, the suffix must be respected in searching | |
187 the directory." | |
188 (let ((l '())) | |
189 (paths-for-each-emacs-directory #'(lambda (dir) | |
190 (setq l (cons dir l))) | |
191 roots | |
4108 | 192 suffix bases |
2481 | 193 envvar default keep-suffix) |
194 (reverse l))) | |
195 | |
4108 | 196 (defun paths-find-emacs-directory (roots suffix bases |
2481 | 197 &optional envvar default keep-suffix) |
198 "Find a directory in the XEmacs hierarchy. | |
199 ROOTS must be a list of installation roots. | |
200 SUFFIX is the subdirectory from there. | |
4108 | 201 BASES is a list of possible bases to look for. |
2481 | 202 ENVVAR is the name of the environment variable that might also |
203 specify the directory. | |
204 DEFAULT is the preferred value. | |
205 If KEEP-SUFFIX is non-nil, the suffix must be respected in searching | |
206 the directory." | |
207 (catch 'gotcha | |
208 (paths-for-each-emacs-directory #'(lambda (dir) | |
209 (throw 'gotcha dir)) | |
210 roots | |
4108 | 211 suffix bases |
2481 | 212 envvar default keep-suffix))) |
213 | |
4108 | 214 (defun paths-for-each-site-directory (func |
215 roots bases | |
216 arch-dependent-p | |
217 &optional envvar default) | |
2481 | 218 "Iterate over the site-specific directories in the XEmacs hierarchy. |
219 FUNC is a function that called for each directory, with the directory | |
220 as the only argument. | |
3753 | 221 ROOTS must be a list of installation roots. |
4108 | 222 BASES is a list of possible bases to look for. |
4092 | 223 ARCH-DEPENDENT-P says whether the file is architecture-specific. |
2481 | 224 ENVVAR is the name of the environment variable that might also |
225 specify the directory. | |
226 DEFAULT is the preferred value." | |
227 (paths-for-each-emacs-directory func | |
228 roots | |
229 (file-name-as-directory | |
230 (paths-construct-path (list | |
4092 | 231 (if arch-dependent-p "lib" "share") |
2481 | 232 emacs-program-name))) |
4108 | 233 bases |
2481 | 234 envvar default)) |
428 | 235 |
4108 | 236 (defun paths-find-site-directory (roots bases arch-dependent-p &optional envvar default) |
2456 | 237 "Find a site-specific directory in the XEmacs hierarchy. |
3753 | 238 ROOTS must be a list of installation roots. |
4108 | 239 BASES is a list of possible bases to look for. |
4092 | 240 ARCH-DEPENDENT-P says whether the file is architecture-specific. |
2456 | 241 ENVVAR is the name of the environment variable that might also |
242 specify the directory. | |
243 DEFAULT is the preferred value." | |
2481 | 244 (catch 'gotcha |
245 (paths-for-each-site-directory #'(lambda (dir) | |
246 (throw 'gotcha dir)) | |
4108 | 247 roots bases arch-dependent-p |
2481 | 248 envvar default))) |
428 | 249 |
4108 | 250 (defun paths-find-site-directories (roots bases arch-dependent-p &optional envvar default) |
2481 | 251 "Find a list of site-specific directories in the XEmacs hierarchy. |
3753 | 252 ROOTS must be a list of installation roots. |
4108 | 253 BASES is a list of bases to look for. |
4092 | 254 ARCH-DEPENDENT-P says whether the file is architecture-specific. |
2481 | 255 ENVVAR is the name of the environment variable that might also |
256 specify the directory. | |
257 DEFAULT is the preferred value." | |
258 (let ((l '())) | |
259 (paths-for-each-site-directory #'(lambda (dir) | |
260 (setq l (cons dir l))) | |
4108 | 261 roots bases arch-dependent-p |
2481 | 262 envvar default) |
263 (reverse l))) | |
2456 | 264 |
4108 | 265 (defun paths-for-each-version-directory (func roots bases arch-dependent-p |
2481 | 266 &optional envvar default enforce-version) |
267 "Iterate over version-specific directories in the XEmacs hierarchy. | |
268 FUNC is a function that called for each directory, with the directory | |
269 as the only argument. | |
3753 | 270 ROOTS must be a list of installation roots. |
4108 | 271 BASES is a list of possible bases to look for. |
4092 | 272 ARCH-DEPENDENT-P says whether the file is architecture-specific. |
2456 | 273 ENVVAR is the name of the environment variable that might also |
274 specify the directory. | |
275 DEFAULT is the preferred value. | |
428 | 276 If ENFORCE-VERSION is non-nil, the directory must contain the XEmacs version." |
2481 | 277 (paths-for-each-emacs-directory func |
278 roots | |
279 (file-name-as-directory | |
280 (paths-construct-path | |
4092 | 281 (list (if arch-dependent-p "lib" "share") |
2481 | 282 (construct-emacs-version-name)))) |
4108 | 283 bases |
2481 | 284 envvar default)) |
285 | |
4108 | 286 (defun paths-find-version-directory (roots bases arch-dependent-p |
2481 | 287 &optional envvar default enforce-version) |
288 "Find a version-specific directory in the XEmacs hierarchy. | |
3753 | 289 ROOTS must be a list of installation roots. |
4108 | 290 BASES is a list of possible bases to look for. |
4092 | 291 ARCH-DEPENDENT-P says whether the file is architecture-specific. |
2481 | 292 ENVVAR is the name of the environment variable that might also |
293 specify the directory. | |
294 DEFAULT is the preferred value. | |
295 If ENFORCE-VERSION is non-nil, the directory must contain the XEmacs version." | |
296 (catch 'gotcha | |
297 (paths-for-each-version-directory #'(lambda (dir) | |
298 (throw 'gotcha dir)) | |
4108 | 299 roots bases arch-dependent-p |
2481 | 300 envvar default))) |
301 | |
4108 | 302 (defun paths-find-version-directories (roots bases arch-dependent-p |
2481 | 303 &optional envvar default enforce-version) |
304 "Find a list of version-specific directories in the XEmacs hierarchy. | |
3753 | 305 ROOTS must be a list of installation roots. |
4108 | 306 BASES is a list of possible bases to look for. |
4092 | 307 ARCH-DEPENDENT-P says whether the file is architecture-specific. |
2481 | 308 ENVVAR is the name of the environment variable that might also |
309 specify the directory. | |
310 DEFAULT is the preferred value. | |
311 If ENFORCE-VERSION is non-nil, the directory must contain the XEmacs version." | |
312 (let ((l '())) | |
4092 | 313 (paths-for-each-version-directory #'(lambda (dir) |
314 (setq l (cons dir l))) | |
4108 | 315 roots bases arch-dependent-p |
4092 | 316 envvar default) |
2481 | 317 (reverse l))) |
428 | 318 |
4108 | 319 (defun paths-find-architecture-directory (roots bases &optional envvar default) |
2456 | 320 "Find an architecture-specific directory in the XEmacs hierarchy. |
3753 | 321 ROOTS must be a list of installation roots. |
4108 | 322 BASES is a list of possible bases to look for. |
2456 | 323 ENVVAR is the name of the environment variable that might also |
324 specify the directory. | |
325 DEFAULT is the preferred value." | |
4108 | 326 (paths-find-version-directory roots |
327 ;; from more to less specific | |
328 (append | |
329 (mapcar | |
330 #'(lambda (base) | |
331 (paths-construct-path | |
332 (list system-configuration base))) | |
333 bases) | |
334 bases | |
335 (list system-configuration)) | |
336 t | |
337 envvar default)) | |
428 | 338 |
339 (defun construct-emacs-version-name () | |
2456 | 340 "Construct a string from the raw XEmacs version number." |
428 | 341 (concat emacs-program-name "-" emacs-program-version)) |
342 | |
343 (defun paths-directories-which-exist (directories) | |
2456 | 344 "Return the directories among DIRECTORIES. |
345 DIRECTORIES is a list of strings." | |
428 | 346 (let ((reverse-directories '())) |
347 (while directories | |
348 (if (paths-file-readable-directory-p (car directories)) | |
349 (setq reverse-directories | |
350 (cons (car directories) | |
351 reverse-directories))) | |
352 (setq directories (cdr directories))) | |
353 (reverse reverse-directories))) | |
354 | |
355 (defun paths-uniq-append (list-1 list-2) | |
2456 | 356 "Append LIST-1 and LIST-2, omitting EQUAL duplicates." |
428 | 357 (let ((reverse-survivors '())) |
358 (while list-2 | |
359 (if (null (member (car list-2) list-1)) | |
360 (setq reverse-survivors (cons (car list-2) reverse-survivors))) | |
361 (setq list-2 (cdr list-2))) | |
362 (append list-1 | |
363 (reverse reverse-survivors)))) | |
364 | |
365 (defun paths-filter (predicate list) | |
366 "Delete all matches of PREDICATE from LIST." | |
367 (let ((reverse-result '())) | |
368 (while list | |
369 (if (funcall predicate (car list)) | |
370 (setq reverse-result (cons (car list) reverse-result))) | |
371 (setq list (cdr list))) | |
372 (nreverse reverse-result))) | |
373 | |
374 (defun paths-decode-directory-path (string &optional drop-empties) | |
375 "Split STRING at path separators into a directory list. | |
442 | 376 Non-\"\" components are converted into directory form. |
428 | 377 If DROP-EMPTIES is non-NIL, \"\" components are dropped from the output. |
378 Otherwise, they are left alone." | |
379 (let* ((components (split-path string)) | |
380 (directories | |
381 (mapcar #'(lambda (component) | |
382 (if (string-equal "" component) | |
383 component | |
384 (file-name-as-directory component))) | |
385 components))) | |
386 (if drop-empties | |
387 (paths-filter #'(lambda (component) | |
388 (null (string-equal "" component))) | |
389 directories) | |
390 directories))) | |
391 | |
392 ;;; find-paths.el ends here |