comparison lisp/mh-e/mh-limit.el @ 68465:37d03b3298bf

The Great Cleanup Remove circular dependencies. mh-e.el now includes few require statements and stands alone. Other files should need to require mh-e.el, which requires mh-loaddefs.el, plus variable-only files such as mh-scan.el. Remove unneeded require statements. Remove unneeded load statements, or replace them with non-fatal require statements. Break out components into their own files that were often spread between many files. As a result, many functions that are now only used within a single file no longer need to be autoloaded. Rearrange and provide consistent headings. Untabify. * mh-acros.el: Update commentary to reflect current usage. Add autoload cookies to all macros. (mh-require-cl): Merge docstring and comment. (mh-do-in-xemacs): Fix typo in docstring. (assoc-string): Move to new file mh-compat.el. (with-mh-folder-updating, mh-in-show-buffer) (mh-do-at-event-location, mh-seq-msgs): Move here from mh-utils.el. (mh-iterate-on-messages-in-region, mh-iterate-on-range): Move here from mh-seq.el. * mh-alias.el (mh-address-mail-regexp) (mh-goto-address-find-address-at-point): Move here from mh-utils.el. (mh-folder-line-matches-show-buffer-p): Move here from mh-e.el. * mh-buffers.el: Update descriptive text. * mh-comp.el (mh-note-repl, mh-note-forw, mh-note-dist): Move to new file mh-scan.el. (mh-yank-hooks, mh-to-field-choices, mh-position-on-field) (mh-letter-menu, mh-letter-mode-help-messages) (mh-letter-buttons-init-flag, mh-letter-mode) (mh-font-lock-field-data, mh-letter-header-end) (mh-auto-fill-for-letter, mh-to-field, mh-to-fcc) (mh-file-is-vcard-p, mh-insert-signature, mh-check-whom) (mh-insert-letter, mh-extract-from-attribution, mh-yank-cur-msg) (mh-filter-out-non-text, mh-insert-prefix-string) (mh-current-fill-prefix, mh-open-line, mh-complete-word) (mh-folder-expand-at-point, mh-letter-complete-function-alist) (mh-letter-complete, mh-letter-complete-or-space) (mh-letter-confirm-address, mh-letter-header-field-at-point) (mh-letter-next-header-field-or-indent) (mh-letter-next-header-field, mh-letter-previous-header-field) (mh-letter-skipped-header-field-p) (mh-letter-skip-leading-whitespace-in-header-field) (mh-hidden-header-keymap) (mh-letter-toggle-header-field-display-button) (mh-letter-toggle-header-field-display) (mh-letter-truncate-header-field, mh-letter-mode-map): Move to new file mh-letter.el. (mh-letter-mode-map, mh-sent-from-folder, mh-send-args) (mh-pgp-support-flag, mh-x-mailer-string) (mh-letter-header-field-regexp): Move to mh-e.el. (mh-goto-header-field, mh-goto-header-end) (mh-extract-from-header-value, mh-beginning-of-word): Move to mh-utils.el. (mh-insert-header-separator): Move to mh-comp.el. (mh-display-completion-list-compat): Move to new file mh-compat.el. * mh-compat.el: New file. (assoc-string): Move here from mh-acros.el. (mh-display-completion-list): Move here from mh-comp.el. * mh-customize.el: Move content into mh-e.el and remove. * mh-e.el (mh-folder-mode-map, mh-folder-seq-tool-bar-map) (mh-folder-tool-bar-map, mh-inc-spool-map, mh-letter-mode-map) (mh-letter-tool-bar-map, mh-search-mode-map, mh-show-mode-map) (mh-show-seq-tool-bar-map, mh-show-tool-bar-map): All maps now declared here so that they can be used in docstrings. (mh-sent-from-folder, mh-sent-from-msg) (mh-letter-header-field-regexp, mh-pgp-support-flag) (mh-x-mailer-string): Move here from mh-comp.el. (mh-folder-line-matches-show-buffer-p): Move to mh-alias.el. (mh-thread-scan-line-map, mh-thread-scan-line-map-stack): Move here from mh-seq.el. (mh-draft-folder, mh-inbox, mh-user-path, mh-current-folder) (mh-previous-window-config, mh-seen-list, mh-seq-list) (mh-show-buffer, mh-showing-mode, mh-globals-hash) (mh-show-folder-buffer, mh-mail-header-separator) (mh-unseen-seq, mh-previous-seq, mh-page-to-next-msg-flag) (mh-signature-separator, mh-signature-separator-regexp) (mh-list-to-string, mh-list-to-string-1): Move here from mh-utils.el. (mh-index-max-cmdline-args, mh-xargs, mh-quote-for-shell) (mh-exec-cmd, mh-exec-cmd-error, mh-exec-cmd-daemon) (mh-exec-cmd-env-daemon, mh-process-daemon, mh-exec-cmd-quiet) (mh-exec-cmd-output) (mh-exchange-point-and-mark-preserving-active-mark) (mh-exec-lib-cmd-output, mh-handle-process-error): Move here from deprecated file mh-exec.el. (mh-path): Move here from deprecated file mh-customize.el. (mh-sys-path, mh-variants, mh-variant-in-use, mh-progs, mh-lib) (mh-flists-present-flag, mh-variants, mh-variant-mh-info) (mh-variant-mu-mh-info, mh-variant-nmh-info, mh-file-command-p) (mh-variant-set-variant, mh-variant-p, mh-profile-component) (mh-profile-component-value, mh-defface-compat): Move here from deprecated file mh-init.el. (mh-goto-next-button, mh-folder-mime-action) (mh-folder-toggle-mime-part, mh-folder-inline-mime-part) (mh-folder-save-mime-part, mh-toggle-mime-buttons): Move to to mh-mime.el. (mh-scan-format-mh, mh-scan-format-nmh, mh-note-deleted) (mh-note-refiled, mh-note-cur, mh-scan-good-msg-regexp) (mh-scan-deleted-msg-regexp, mh-scan-refiled-msg-regexp) (mh-scan-valid-regexp, mh-scan-cur-msg-number-regexp) (mh-scan-date-regexp, mh-scan-rcpt-regexp, mh-scan-body-regexp) (mh-scan-subject-regexp, mh-scan-sent-to-me-sender-regexp) (mh-scan-cmd-note-width, mh-scan-destination-width) (mh-scan-date-width, mh-scan-date-flag-width) (mh-scan-from-mbox-width, mh-scan-from-mbox-sep-width) (mh-scan-field-destination-offset) (mh-scan-field-from-start-offset, mh-scan-field-from-end-offset) (mh-scan-field-subject-start-offset, mh-scan-format) (mh-msg-num-width-to-column, mh-set-cmd-note): Move to new file mh-scan.el. (mh-partial-folder-mode-line-annotation) (mh-folder-font-lock-keywords, mh-folder-font-lock-subject) (mh-generate-sequence-font-lock, mh-last-destination) (mh-last-destination-write, mh-first-msg-num, mh-last-msg-num) (mh-rmail, mh-nmail, mh-delete-msg, mh-delete-msg-no-motion) (mh-execute-commands, mh-first-msg, mh-header-display) (mh-inc-folder, mh-last-msg, mh-next-undeleted-msg) (mh-folder-from-address, mh-prompt-for-refile-folder) (mh-refile-msg, mh-refile-or-write-again, mh-quit, mh-page-msg) (mh-previous-page, mh-previous-undeleted-msg) (mh-previous-unread-msg, mh-next-button, mh-prev-button) (mh-reset-threads-and-narrowing, mh-rescan-folder) (mh-write-msg-to-file, mh-toggle-showing, mh-undo) (mh-visit-folder, mh-update-sequences, mh-delete-a-msg) (mh-refile-a-msg, mh-next-msg, mh-next-unread-msg) (mh-set-scan-mode, mh-undo-msg, mh-make-folder) (mh-folder-sequence-menu, mh-folder-message-menu) (mh-folder-folder-menu, mh-remove-xemacs-horizontal-scrollbar) (mh-write-file-functions-compat, mh-folder-mode) (mh-restore-desktop-buffer, mh-scan-folder) (mh-regenerate-headers, mh-generate-new-cmd-note) (mh-get-new-mail, mh-make-folder-mode-line, mh-goto-cur-msg) (mh-process-or-undo-commands, mh-process-commands) (mh-update-unseen, mh-delete-scan-msgs) (mh-outstanding-commands-p): Move to new file mh-folder.el. (mh-mapc, mh-colors-available-p, mh-colors-in-use-p) (mh-make-local-vars, mh-coalesce-msg-list, mh-greaterp) (mh-lessp): Move to mh-utils.el. (mh-parse-flist-output-line, mh-folder-size-folder) (mh-folder-size-flist, mh-folder-size, mh-add-sequence-notation) (mh-remove-sequence-notation, mh-remove-cur-notation) (mh-remove-all-notation, mh-delete-seq-locally) (mh-read-folder-sequences, mh-read-msg-list) (mh-notate-user-sequences, mh-internal-seqs, mh-internal-seq) (mh-valid-seq-p, mh-delete-msg-from-seq, mh-catchup) (mh-delete-a-msg-from-seq, mh-undefine-sequence) (mh-define-sequence, mh-seq-containing-msg): Move to mh-seq.el. (mh-xemacs-flag) (mh-customize, mh-e, mh-alias, mh-folder, mh-folder-selection) (mh-identity, mh-inc, mh-junk, mh-letter, mh-ranges) (mh-scan-line-formats, mh-search, mh-sending-mail, mh-sequences) (mh-show, mh-speedbar, mh-thread, mh-tool-bar, mh-hooks) (mh-faces, mh-alias-completion-ignore-case-flag) (mh-alias-expand-aliases-flag, mh-alias-flash-on-comma) (mh-alias-insert-file, mh-alias-insertion-location) (mh-alias-local-users, mh-alias-local-users-prefix) (mh-alias-passwd-gecos-comma-separator-flag) (mh-new-messages-folders, mh-ticked-messages-folders) (mh-large-folder, mh-recenter-summary-flag) (mh-recursive-folders-flag, mh-sortm-args) (mh-default-folder-for-message-function, mh-default-folder-list) (mh-default-folder-must-exist-flag, mh-default-folder-prefix) (mh-identity-list, mh-auto-fields-list) (mh-auto-fields-prompt-flag, mh-identity-default) (mh-identity-handlers, mh-inc-prog, mh-inc-spool-list) (mh-junk-choice, mh-junk-function-alist, mh-junk-choose) (mh-junk-background, mh-junk-disposition, mh-junk-program) (mh-compose-insertion, mh-compose-skipped-header-fields) (mh-compose-space-does-completion-flag) (mh-delete-yanked-msg-window-flag) (mh-extract-from-attribution-verb, mh-ins-buf-prefix) (mh-letter-complete-function, mh-letter-fill-column) (mh-mml-method-default, mh-signature-file-name) (mh-signature-separator-flag, mh-x-face-file, mh-yank-behavior) (mh-interpret-number-as-range-flag, mh-adaptive-cmd-note-flag) (mh-scan-format-file-check, mh-scan-format-file) (mh-adaptive-cmd-note-flag-check, mh-scan-prog) (mh-search-program, mh-compose-forward-as-mime-flag) (mh-compose-letter-function, mh-compose-prompt-flag) (mh-forward-subject-format, mh-insert-x-mailer-flag) (mh-redist-full-contents-flag, mh-reply-default-reply-to) (mh-reply-show-message-flag, mh-refile-preserves-sequences-flag) (mh-tick-seq, mh-update-sequences-after-mh-show-flag) (mh-bury-show-buffer-flag, mh-clean-message-header-flag) (mh-decode-mime-flag, mh-display-buttons-for-alternatives-flag) (mh-display-buttons-for-inline-parts-flag) (mh-do-not-confirm-flag, mh-fetch-x-image-url) (mh-graphical-smileys-flag, mh-graphical-emphasis-flag) (mh-highlight-citation-style) (mh-invisible-header-fields-internal) (mh-delay-invisible-header-generation-flag) (mh-invisible-header-fields, mh-invisible-header-fields-default) (mh-invisible-header-fields-compiled, mh-invisible-headers) (mh-lpr-command-format, mh-max-inline-image-height) (mh-max-inline-image-width, mh-mhl-format-file) (mh-mime-save-parts-default-directory, mh-print-background-flag) (mh-show-maximum-size, mh-show-use-goto-addr-flag) (mh-show-use-xface-flag, mh-store-default-directory) (mh-summary-height, mh-speed-update-interval) (mh-show-threads-flag, mh-tool-bar-search-function) (mh-after-commands-processed-hook, mh-alias-reloaded-hook) (mh-before-commands-processed-hook, mh-before-quit-hook) (mh-before-send-letter-hook, mh-delete-msg-hook) (mh-find-path-hook, mh-folder-mode-hook, mh-forward-hook) (mh-inc-folder-hook, mh-insert-signature-hook) (mh-kill-folder-suppress-prompt-hooks, mh-letter-mode-hook) (mh-mh-to-mime-hook, mh-search-mode-hook, mh-quit-hook) (mh-refile-msg-hook, mh-show-hook, mh-show-mode-hook) (mh-unseen-updated-hook, mh-min-colors-defined-flag) (mh-folder-address, mh-folder-body) (mh-folder-cur-msg-number, mh-folder-date, mh-folder-deleted) (mh-folder-followup, mh-folder-msg-number, mh-folder-refiled) (mh-folder-sent-to-me-hint, mh-folder-sent-to-me-sender) (mh-folder-subject, mh-folder-tick, mh-folder-to) (mh-search-folder, mh-letter-header-field, mh-show-cc) (mh-show-date, mh-show-from, mh-show-header, mh-show-pgg-bad) (mh-show-pgg-good, mh-show-pgg-unknown, mh-show-signature) (mh-show-subject, mh-show-to, mh-show-xface, mh-speedbar-folder) (mh-speedbar-folder-with-unseen-messages) (mh-speedbar-selected-folder) (mh-speedbar-selected-folder-with-unseen-messages): Move here from deprecated file mh-customize.el. * mh-exec.el: Move content into mh-e.el and remove. * mh-folder.el: New file. Contains mh-folder-mode from mh-e.el * mh-funcs.el (mh-note-copied, mh-note-printed): Move to new file mh-scan.el. (mh-ephem-message, mh-help, mh-prefix-help): Move to mh-utils.el. * mh-gnus.el (mm-uu-dissect-text-parts): Add. (mh-mail-abbrev-make-syntax-table): Move to mh-utils.el and rename to mail-abbrev-make-syntax-table. * mh-identity.el (mh-identity-menu): New variable for existing menu. (mh-identity-make-menu-no-autoload): New alias for mh-identity-make-menu which can be called from mh-e.el. (mh-identity-list-set): Move to mh-e.el. (mh-identity-add-menu): New function (mh-insert-identity): Add optional argument maybe-insert so that local variable mh-identity-local does not have to be visible. (mh-identity-handler-default): * mh-inc.el (mh-inc-spool-map): Move declaration to mh-e.el (with rest of keymaps). Update key binding for ? to call mh-help with help messages in new argument. (mh-inc-spool-make-no-autoload): New alias for mh-inc-spool-make which can be called from mh-e.el. (mh-inc-spool-list-set): Simplify update of mh-inc-spool-map-help. * mh-init.el: Move content into mh-e.el and remove. * mh-junk.el: Update requires, untabify, and add mh-autoload cookies. * mh-letter.el: New file. Contains mh-letter-mode from mh-comp.el. * mh-limit.el: New file. Contains display limit commands from mh-mime.el. * mh-mime.el: Rearrange for consistency with other files. (mh-buffer-data, mh-mm-inline-media-tests): Move here from mh-utils.el. (mh-folder-inline-mime-part, mh-folder-save-mime-part) (mh-folder-toggle-mime-part, mh-toggle-mime-buttons) (mh-goto-next-button): Move here from mh-e.el. * mh-print.el: Rearrange for consistency with other files. * mh-scan.el: New file. Contains scan line constants and utilities from XXX, mh-funcs, mh-utils.el. * mh-search.el: Rearrange for consistency with other files. (mh-search-mode-map): Drop C-c C-f {dr} bindings since these fields which don't exist in the saved header. Replace C-c C-f f with C-c C-f m per mail-mode consistency. (mh-search-mode): Use mh-set-help instead of setting mh-help-messages. * mh-seq.el (mh-thread-message, mh-thread-container) (mh-thread-id-hash, mh-thread-subject-hash, mh-thread-id-table) (mh-thread-id-index-map, mh-thread-index-id-map) (mh-thread-scan-line-map, mh-thread-scan-line-map-stack) (mh-thread-subject-container-hash, mh-thread-duplicates) (mh-thread-history, mh-thread-body-width) (mh-thread-find-msg-subject mh-thread-initialize-hash) (mh-thread-initialize, mh-thread-id-container) (mh-thread-remove-parent-link, mh-thread-add-link) (mh-thread-ancestor-p, mh-thread-get-message-container) (mh-thread-get-message, mh-thread-canonicalize-id) (mh-thread-prune-subject, mh-thread-container-subject) (mh-thread-rewind-pruning, mh-thread-prune-containers) (mh-thread-sort-containers, mh-thread-group-by-subject) (mh-thread-process-in-reply-to, mh-thread-set-tables) (mh-thread-update-id-index-maps, mh-thread-generate) (mh-thread-inc, mh-thread-generate-scan-lines) (mh-thread-parse-scan-line, mh-thread-update-scan-line-map) (mh-thread-add-spaces, mh-thread-print-scan-lines) (mh-thread-folder, mh-toggle-threads, mh-thread-forget-message) (mh-thread-current-indentation-level, mh-thread-next-sibling) (mh-thread-previous-sibling, mh-thread-immediate-ancestor) (mh-thread-ancestor, mh-thread-find-children) (mh-message-id-regexp, mh-thread-delete, mh-thread-refile): Move to new file mh-thread.el. (mh-subject-to-sequence, mh-subject-to-sequence-unthreaded) (mh-subject-to-sequence-threaded, mh-edit-pick-expr) (mh-pick-args-list, mh-narrow-to-subject, mh-narrow-to-from) (mh-narrow-to-cc, mh-narrow-to-to, mh-narrow-to-header-field) (mh-current-message-header-field, mh-narrow-to-range) (mh-delete-subject, mh-delete-subject-or-thread): Move to new file mh-limit.el. (mh-iterate-on-messages-in-region, mh-iterate-on-range): Move to mh-acros.el. (mh-internal-seqs, mh-catchup, mh-delete-msg-from-seq) (mh-internal-seq, mh-valid-seq-p, mh-seq-containing-msg) (mh-define-sequence, mh-undefine-sequence) (mh-delete-a-msg-from-seq, mh-delete-seq-locally) (mh-folder-size, mh-folder-size-flist, mh-folder-size-folder) (mh-parse-flist-output-line, mh-read-folder-sequences) (mh-read-msg-list, mh-notate-user-sequences) (mh-remove-cur-notation, mh-add-sequence-notation) (mh-remove-sequence-notation, mh-remove-all-notation): Move here from mh-e.el. (mh-make-seq, mh-seq-name, mh-find-seq, mh-seq-to-msgs) (mh-add-msgs-to-seq, mh-notate): Move here from mh-utils.el. * mh-show.el: New file. Contains mh-show-mode from mh-utils.el. * mh-speed.el: Rearrange for consistency with other files. * mh-thread.el: New file. Contains threading code from mh-seq.el. * mh-tool-bar.el: New file. Contains tool bar creation code from deprecated file mh-customize.el. * mh-utils.el (recursive-load-depth-limit): Remove setting. No longer needed. (mh-scan-msg-number-regexp, mh-scan-msg-overflow-regexp) (mh-scan-msg-format-regexp, mh-scan-msg-format-string) (mh-scan-msg-search-regexp, mh-cmd-note, mh-note-seq) (mh-update-scan-format, mh-msg-num-width): Move to new file mh-scan.el. (mh-show-buffer-mode-line-buffer-id, mh-letter-header-font-lock) (mh-header-field-font-lock, mh-header-to-font-lock) (mh-header-cc-font-lock, mh-header-subject-font-lock) (mh-show-font-lock-keywords) (mh-show-font-lock-keywords-with-cite) (mh-show-font-lock-fontify-region) (mh-gnus-article-highlight-citation, mh-showing-with-headers) (mh-start-of-uncleaned-message, mh-invalidate-show-buffer) (mh-unvisit-file, mh-defun-show-buffer, mh-show-mode-map) (mh-show-sequence-menu, mh-show-message-menu) (mh-show-folder-menu, mh-show-mode, mh-show-addr) (mh-maybe-show, mh-show, mh-show-msg, mh-show-unquote-From) (mh-msg-folder, mh-display-msg, mh-clean-msg-header): Move to new file mh-show.el. (mh-mail-header-separator, mh-signature-separator-regexp) (mh-signature-separator, mh-globals-hash, mh-user-path) (mh-draft-folder, mh-unseen-seq, mh-previous-seq, mh-inbox) (mh-previous-window-config, mh-current-folder mh-show-buffer) (mh-showing-mode, mh-show-mode-map, mh-show-folder-buffer) (mh-showing-mode, mh-seq-list, mh-seen-list, mh-summary-height) (mh-list-to-string, mh-list-to-string-1): Move to mh-e.el. (mh-buffer-data, mh-mm-inline-media-tests): Move to mh-mime.el. (mh-address-mail-regexp, mh-goto-address-find-address-at-point): Move to mh-alias.el. (mh-letter-font-lock-keywords): Move to new file mh-letter.el. (mh-folder-filename, mh-msg-count, mh-recenter, mh-msg-filename) (mh-show-mouse, mh-modify, mh-goto-msg, mh-set-folder-modified-p): Move to new file mh-folder.el. (with-mh-folder-updating, mh-in-show-buffer) (mh-do-at-event-location, mh-seq-msgs): Moved to mh-acros.el. (mh-make-seq, mh-seq-name, mh-notate, mh-find-seq) (mh-seq-to-msgs, mh-add-msgs-to-seq, mh-canonicalize-sequence): Moved to mh-seq.el. (mh-show-xface-function, mh-uncompface-executable, mh-face-to-png) (mh-uncompface, mh-icontopbm, mh-face-foreground-compat) (mh-face-background-compat, mh-face-display-function) (mh-show-xface, mh-picon-directory-list) (mh-picon-existing-directory-list) (mh-picon-cache, mh-picon-image-types) (mh-picon-set-directory-list, mh-picon-get-image) (mh-picon-file-contents, mh-picon-generate-path) (mh-x-image-cache-directory, mh-x-image-scaling-function) (mh-wget-executable, mh-wget-choice, mh-wget-option) (mh-x-image-temp-file, mh-x-image-url, mh-x-image-marker) (mh-x-image-url-cache-file, mh-x-image-scale-with-pnm) (mh-x-image-scale-with-convert) (url-unreserved-chars, url-hexify-string) (mh-x-image-url-cache-canonicalize) (mh-x-image-set-download-state, mh-x-image-get-download-state) (mh-x-image-url-fetch-image, mh-x-image-display) (mh-x-image-scale-and-display, mh-x-image-url-sane-p) (mh-x-image-url-display): Move to new file mh-xface.el. (mh-logo-display): Call mh-image-load-path. (mh-find-path-run, mh-find-path): Move here from deprecated file mh-init.el. (mh-help-messages): Now an alist of modes to an alist of messages. (mh-set-help): New function used to set mh-help-messages (mh-help): Adjust for new format of mh-help-messages. Add help-messages argument. (mh-prefix-help): Refactor to use mh-help. (mh-coalesce-msg-list, mh-greaterp, mh-lessp): Move here from mh-e.el. (mh-clear-sub-folders-cache): New function added to avoid exposing mh-sub-folders-cache variable. * mh-xface.el: New file. Contains X-Face and Face header field display routines from mh-utils.el.
author Bill Wohler <wohler@newt.com>
date Sun, 29 Jan 2006 19:34:57 +0000
parents
children 4bd450a8dbe2
comparison
equal deleted inserted replaced
68464:79464a6167f5 68465:37d03b3298bf
1 ;;; mh-limit.el --- MH-E display limits
2
3 ;; Copyright (C) 2001, 2002, 2003, 2006 Free Software Foundation, Inc.
4
5 ;; Author: Peter S. Galbraith <psg@debian.org>
6 ;; Maintainer: Bill Wohler <wohler@newt.com>
7 ;; Keywords: mail
8 ;; See: mh-e.el
9
10 ;; This file is part of GNU Emacs.
11
12 ;; GNU Emacs is free software; you can redistribute it and/or modify
13 ;; it under the terms of the GNU General Public License as published by
14 ;; the Free Software Foundation; either version 2, or (at your option)
15 ;; any later version.
16
17 ;; GNU Emacs is distributed in the hope that it will be useful,
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 ;; GNU General Public License for more details.
21
22 ;; You should have received a copy of the GNU General Public License
23 ;; along with GNU Emacs; see the file COPYING. If not, write to the
24 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
25 ;; Boston, MA 02110-1301, USA.
26
27 ;;; Commentary:
28
29 ;; "Poor man's threading" by psg.
30
31 ;;; Change Log:
32
33 ;;; Code:
34
35 (require 'mh-e)
36 (mh-require-cl)
37 (require 'mh-scan)
38
39 (autoload 'message-fetch-field "message")
40
41
42
43 ;;; MH-Folder Commands
44
45 ;; Alphabetical.
46
47 ;;;###mh-autoload
48 (defun mh-delete-subject ()
49 "Delete messages with same subject\\<mh-folder-mode-map>.
50
51 To delete messages faster, you can use this command to delete all
52 the messages with the same subject as the current message. This
53 command puts these messages in a sequence named \"subject\". You
54 can undo this action by using \\[mh-undo] with a prefix argument
55 and then specifying the \"subject\" sequence."
56 (interactive)
57 (let ((count (mh-subject-to-sequence nil)))
58 (cond
59 ((not count) ; No subject line, delete msg anyway
60 (mh-delete-msg (mh-get-msg-num t)))
61 ((= 0 count) ; No other msgs, delete msg anyway.
62 (message "No other messages with same Subject following this one")
63 (mh-delete-msg (mh-get-msg-num t)))
64 (t ; We have a subject sequence.
65 (message "Marked %d messages for deletion" count)
66 (mh-delete-msg 'subject)))))
67
68 ;;;###mh-autoload
69 (defun mh-delete-subject-or-thread ()
70 "Delete messages with same subject or thread\\<mh-folder-mode-map>.
71
72 To delete messages faster, you can use this command to delete all
73 the messages with the same subject as the current message. This
74 command puts these messages in a sequence named \"subject\". You
75 can undo this action by using \\[mh-undo] with a prefix argument
76 and then specifying the \"subject\" sequence.
77
78 However, if the buffer is displaying a threaded view of the
79 folder then this command behaves like \\[mh-thread-delete]."
80 (interactive)
81 (if (memq 'unthread mh-view-ops)
82 (mh-thread-delete)
83 (mh-delete-subject)))
84
85 ;;;###mh-autoload
86 (defun mh-narrow-to-cc (&optional pick-expr)
87 "Limit to messages with the same \"Cc:\" field.
88 With a prefix argument, edit PICK-EXPR.
89
90 Use \\<mh-folder-mode-map>\\[mh-widen] to undo this command."
91 (interactive
92 (list (mh-edit-pick-expr (mh-current-message-header-field 'cc))))
93 (mh-narrow-to-header-field 'cc pick-expr))
94
95 ;;;###mh-autoload
96 (defun mh-narrow-to-from (&optional pick-expr)
97 "Limit to messages with the same \"From:\" field.
98 With a prefix argument, edit PICK-EXPR.
99
100 Use \\<mh-folder-mode-map>\\[mh-widen] to undo this command."
101 (interactive
102 (list (mh-edit-pick-expr (mh-current-message-header-field 'from))))
103 (mh-narrow-to-header-field 'from pick-expr))
104
105 ;;;###mh-autoload
106 (defun mh-narrow-to-range (range)
107 "Limit to RANGE.
108
109 Check the documentation of `mh-interactive-range' to see how
110 RANGE is read in interactive use.
111
112 Use \\<mh-folder-mode-map>\\[mh-widen] to undo this command."
113 (interactive (list (mh-interactive-range "Narrow to")))
114 (when (assoc 'range mh-seq-list) (mh-delete-seq 'range))
115 (mh-add-msgs-to-seq (mh-range-to-msg-list range) 'range)
116 (mh-narrow-to-seq 'range))
117
118 ;;;###mh-autoload
119 (defun mh-narrow-to-subject (&optional pick-expr)
120 "Limit to messages with same subject.
121 With a prefix argument, edit PICK-EXPR.
122
123 Use \\<mh-folder-mode-map>\\[mh-widen] to undo this command."
124 (interactive
125 (list (mh-edit-pick-expr (mh-current-message-header-field 'subject))))
126 (mh-narrow-to-header-field 'subject pick-expr))
127
128 ;;;###mh-autoload
129 (defun mh-narrow-to-to (&optional pick-expr)
130 "Limit to messages with the same \"To:\" field.
131 With a prefix argument, edit PICK-EXPR.
132
133 Use \\<mh-folder-mode-map>\\[mh-widen] to undo this command."
134 (interactive
135 (list (mh-edit-pick-expr (mh-current-message-header-field 'to))))
136 (mh-narrow-to-header-field 'to pick-expr))
137
138
139
140 ;;; Support Routines
141
142 (defun mh-subject-to-sequence (all)
143 "Put all following messages with same subject in sequence 'subject.
144 If arg ALL is t, move to beginning of folder buffer to collect all
145 messages.
146 If arg ALL is nil, collect only messages fron current one on forward.
147
148 Return number of messages put in the sequence:
149
150 nil -> there was no subject line.
151
152 0 -> there were no later messages with the same
153 subject (sequence not made)
154
155 >1 -> the total number of messages including current one."
156 (if (memq 'unthread mh-view-ops)
157 (mh-subject-to-sequence-threaded all)
158 (mh-subject-to-sequence-unthreaded all)))
159
160 (defun mh-subject-to-sequence-threaded (all)
161 "Put all messages with the same subject in the 'subject sequence.
162
163 This function works when the folder is threaded. In this
164 situation the subject could get truncated and so the normal
165 matching doesn't work.
166
167 The parameter ALL is non-nil then all the messages in the buffer
168 are considered, otherwise only the messages after the current one
169 are taken into account."
170 (let* ((cur (mh-get-msg-num nil))
171 (subject (mh-thread-find-msg-subject cur))
172 region msgs)
173 (if (null subject)
174 (and (message "No subject line") nil)
175 (setq region (cons (if all (point-min) (point)) (point-max)))
176 (mh-iterate-on-range msg region
177 (when (eq (mh-thread-find-msg-subject msg) subject)
178 (push msg msgs)))
179 (setq msgs (sort msgs #'mh-lessp))
180 (if (null msgs)
181 0
182 (when (assoc 'subject mh-seq-list)
183 (mh-delete-seq 'subject))
184 (mh-add-msgs-to-seq msgs 'subject)
185 (length msgs)))))
186
187 (defvar mh-limit-max-subject-size 41
188 "Maximum size of the subject part.
189 It would be desirable to avoid hard-coding this.")
190
191 (defun mh-subject-to-sequence-unthreaded (all)
192 "Put all following messages with same subject in sequence 'subject.
193
194 This function only works with an unthreaded folder. If arg ALL is
195 t, move to beginning of folder buffer to collect all messages. If
196 arg ALL is nil, collect only messages fron current one on
197 forward.
198
199 Return number of messages put in the sequence:
200
201 nil -> there was no subject line.
202 0 -> there were no later messages with the same
203 subject (sequence not made)
204 >1 -> the total number of messages including current one."
205 (if (not (eq major-mode 'mh-folder-mode))
206 (error "Not in a folder buffer"))
207 (save-excursion
208 (beginning-of-line)
209 (if (or (not (looking-at mh-scan-subject-regexp))
210 (not (match-string 3))
211 (string-equal "" (match-string 3)))
212 (progn (message "No subject line")
213 nil)
214 (let ((subject (match-string-no-properties 3))
215 (list))
216 (if (> (length subject) mh-limit-max-subject-size)
217 (setq subject (substring subject 0 mh-limit-max-subject-size)))
218 (save-excursion
219 (if all
220 (goto-char (point-min)))
221 (while (re-search-forward mh-scan-subject-regexp nil t)
222 (let ((this-subject (match-string-no-properties 3)))
223 (if (> (length this-subject) mh-limit-max-subject-size)
224 (setq this-subject (substring this-subject
225 0 mh-limit-max-subject-size)))
226 (if (string-equal this-subject subject)
227 (setq list (cons (mh-get-msg-num t) list))))))
228 (cond
229 (list
230 ;; If we created a new sequence, add the initial message to it too.
231 (if (not (member (mh-get-msg-num t) list))
232 (setq list (cons (mh-get-msg-num t) list)))
233 (if (assoc 'subject mh-seq-list) (mh-delete-seq 'subject))
234 ;; sort the result into a sequence
235 (let ((sorted-list (sort (copy-sequence list) 'mh-lessp)))
236 (while sorted-list
237 (mh-add-msgs-to-seq (car sorted-list) 'subject nil)
238 (setq sorted-list (cdr sorted-list)))
239 (safe-length list)))
240 (t
241 0))))))
242
243 (defun mh-edit-pick-expr (default)
244 "With prefix arg edit a pick expression.
245 If no prefix arg is given, then return DEFAULT."
246 (let ((default-string (loop for x in default concat (format " %s" x))))
247 (if (or current-prefix-arg (equal default-string ""))
248 (mh-pick-args-list (read-string "Pick expression: "
249 default-string))
250 default)))
251
252 (defun mh-pick-args-list (s)
253 "Form list by grouping elements in string S suitable for pick arguments.
254 For example, the string \"-subject a b c -from Joe User
255 <user@domain.com>\" is converted to (\"-subject\" \"a b c\"
256 \"-from\" \"Joe User <user@domain.com>\""
257 (let ((full-list (split-string s))
258 current-arg collection arg-list)
259 (while full-list
260 (setq current-arg (car full-list))
261 (if (null (string-match "^-" current-arg))
262 (setq collection
263 (if (null collection)
264 current-arg
265 (format "%s %s" collection current-arg)))
266 (when collection
267 (setq arg-list (append arg-list (list collection)))
268 (setq collection nil))
269 (setq arg-list (append arg-list (list current-arg))))
270 (setq full-list (cdr full-list)))
271 (when collection
272 (setq arg-list (append arg-list (list collection))))
273 arg-list))
274
275 (defun mh-current-message-header-field (header-field)
276 "Return a pick regexp to match HEADER-FIELD of the message at point."
277 (let ((num (mh-get-msg-num nil)))
278 (when num
279 (let ((folder mh-current-folder))
280 (with-temp-buffer
281 (insert-file-contents-literally (mh-msg-filename num folder))
282 (goto-char (point-min))
283 (when (search-forward "\n\n" nil t)
284 (narrow-to-region (point-min) (point)))
285 (let* ((field (or (message-fetch-field (format "%s" header-field))
286 ""))
287 (field-option (format "-%s" header-field))
288 (patterns (loop for x in (split-string field "[ ]*,[ ]*")
289 unless (equal x "")
290 collect (if (string-match "<\\(.*@.*\\)>" x)
291 (match-string 1 x)
292 x))))
293 (when patterns
294 (loop with accum = `(,field-option ,(car patterns))
295 for e in (cdr patterns)
296 do (setq accum `(,field-option ,e "-or" ,@accum))
297 finally return accum))))))))
298
299 (defun mh-narrow-to-header-field (header-field pick-expr)
300 "Limit to messages whose HEADER-FIELD match PICK-EXPR.
301 The MH command pick is used to do the match."
302 (let ((folder mh-current-folder)
303 (original (mh-coalesce-msg-list
304 (mh-range-to-msg-list (cons (point-min) (point-max)))))
305 (msg-list ()))
306 (with-temp-buffer
307 (apply #'mh-exec-cmd-output "pick" nil folder
308 (append original (list "-list") pick-expr))
309 (goto-char (point-min))
310 (while (not (eobp))
311 (let ((num (ignore-errors
312 (string-to-number
313 (buffer-substring (point) (line-end-position))))))
314 (when num (push num msg-list))
315 (forward-line))))
316 (if (null msg-list)
317 (message "No matches")
318 (when (assoc 'header mh-seq-list) (mh-delete-seq 'header))
319 (mh-add-msgs-to-seq msg-list 'header)
320 (mh-narrow-to-seq 'header))))
321
322 (provide 'mh-limit)
323
324 ;; Local Variables:
325 ;; indent-tabs-mode: nil
326 ;; sentence-end-double-space: nil
327 ;; End:
328
329 ;;; mh-limit.el ends here