File: //usr/share/emacs/27.1/lisp/gnus/gnus-score.elc
;ELC   
;;; Compiled
;;; in Emacs version 27.1
;;; with all optimizations.
;;; This file uses dynamic docstrings, first added in Emacs 19.29.
;;; This file does not contain utf-8 non-ASCII characters,
;;; and so can be loaded in Emacs versions earlier than 23.
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(byte-code "\301\302!\210\301\303!\210\301\304!\210\301\305!\210\301\306!\210\301\307!\210\301\310!\210\301\311!\210\312\313\314\315\316\317\320\321&\210\312\322\314\323\316\317\320\324&\210\312\325\314\326\316\317\320\327&\210\312\330\331\332\316\317\320\333&\210\312\300\334\335\316\317\316\336\320\333&	\210\312\337\340\341\316\317\320\342&\210\312\343\344\345\316\346\320\347&\210\312\350\351\352\316\353\320\354&\210\312\355\356\357\316\353\320\360&\210\312\361\314\362\316\363\320\364\365\366\367\370\371\372\373QF\374BBBB&\210\312\375\376\377\316\363\320\201@ &\210\312\201A \201B \201C \316\363\320\347&\210\312\201D \201E \201F \316\363\320\201G &\210\312\201H \314\201I \316\317\320\201J &\210\312\201K \314\201L \316\336\316\317\320\201M &	\210\312\201N \201O \201P \316\336\320\201Q &\210\312\201R \314\201S \201T \201U \316\336\320\201V &	\210\312\201W \314\201X \316\336\320\201Y &\210\312\201Z \201[ \201\\ \316\336\320\201] &\210\312\201^ \201_ \201` \316\336\320\201a &\210\312\201b \314\201c \316\336\320\201d &\210\312\201e \314\201f \316\336\320\360&\210\312\201g \314\201h \316\346\320\360&\210\312\201i \201j \201k \316\336\320\201l &\210\312\201m \201n \201o \316\336\316\317\320\201p &	\210\312\201q \314\201r \316\317\316\336\201T \201s \320\360&\210\312\201t \314\201u \316\346\320\201v &\210\312\201w \314\201x \316\346\320\201y &\210\312\201z \314\201{ \316\346\320\360&\210\312\201| \314\201} \316\346\320\201~ &\210\312\201 \314\201\200 \316\317\320\201\201 &\210\312\201\202 \314\201\203 \316\201\204 \320\360&\210\312\201\205 \314\201\206 \316\201\204 \201T \201s \320\201\207 &	\207" [gnus-adaptive-file-suffix require gnus gnus-sum gnus-art gnus-range gnus-win message score-mode gmm-utils custom-declare-variable gnus-global-score-files nil "List of global score files and directories.\nSet this variable if you want to use people's score files.  One entry\nfor each score file or each score file directory.  Gnus will decide\nby itself what score files are applicable to which group.\n\nSay you want to use the single score file\n\"/ftp.gnus.org:/pub/larsi/ding/score/soc.motss.SCORE\" and all\nscore files in the \"/ftp.some-where:/pub/score\" directory.\n\n (setq gnus-global-score-files\n       \\='(\"/ftp.gnus.org:/pub/larsi/ding/score/soc.motss.SCORE\"\n	 \"/ftp.some-where:/pub/score\"))" :group gnus-score-files :type (repeat file) gnus-score-file-single-match-alist "Alist mapping regexps to lists of score files.\nEach element of this alist should be of the form\n	(\"REGEXP\" [ \"SCORE-FILE-1\" ] [ \"SCORE-FILE-2\" ] ... )\n\nIf the name of a group is matched by REGEXP, the corresponding scorefiles\nwill be used for that group.\nThe first match found is used, subsequent matching entries are ignored (to\nuse multiple matches, see `gnus-score-file-multiple-match-alist').\n\nThese score files are loaded in addition to any files returned by\n`gnus-score-find-score-files-function'." (repeat (cons regexp (repeat file))) gnus-score-file-multiple-match-alist "Alist mapping regexps to lists of score files.\nEach element of this alist should be of the form\n	(\"REGEXP\" [ \"SCORE-FILE-1\" ] [ \"SCORE-FILE-2\" ] ... )\n\nIf the name of a group is matched by REGEXP, the corresponding scorefiles\nwill be used for that group.\nIf multiple REGEXPs match a group, the score files corresponding to each\nmatch will be used (for only one match to be used, see\n`gnus-score-file-single-match-alist').\n\nThese score files are loaded in addition to any files returned by\n`gnus-score-find-score-files-function'." (repeat (cons regexp (repeat file))) gnus-score-file-suffix "SCORE" "Suffix of the score files." string "ADAPT" "Suffix of the adaptive score files." gnus-score-adapt gnus-score-find-score-files-function 'gnus-score-find-bnews "Function used to find score files.\nThe function will be called with the group name as the argument, and\nshould return a list of score files to apply to that group.  The score\nfiles do not actually have to exist.\n\nPredefined values are:\n\n`gnus-score-find-single': Only apply the group's own score file.\n`gnus-score-find-hierarchical': Also apply score files from parent groups.\n`gnus-score-find-bnews': Apply score files whose names matches.\n\nSee the documentation to these functions for more information.\n\nThis variable can also be a list of functions to be called.  Each\nfunction is given the group name as argument and should either return\na list of score files, or a list of score alists.\n\nIf functions other than these pre-defined functions are used,\nthe `a' symbolic prefix to the score commands will always use\n\"all.SCORE\"." (radio (function-item gnus-score-find-single) (function-item gnus-score-find-hierarchical) (function-item gnus-score-find-bnews) (repeat :tag "List of functions" (choice (function :tag "Other" :value 'ignore) (function-item gnus-score-find-single) (function-item gnus-score-find-hierarchical) (function-item gnus-score-find-bnews))) (function :tag "Other" :value 'ignore)) gnus-score-interactive-default-score 1000 "Scoring commands will raise/lower the score with this number as the default." gnus-score-default integer gnus-score-expiry-days 7 "Number of days before unused score file entries are expired.\nIf this variable is nil, no score file entries will be expired." gnus-score-expire (choice (const :tag "never" nil) number) gnus-update-score-entry-dates t "If non-nil, update matching score entry dates.\nIf this variable is nil, then score entries that provide matches\nwill be expired along with non-matching score entries." boolean gnus-decay-scores "If non-nil, decay non-permanent scores.\n\nIf it is a regexp, only decay score files matching regexp." gnus-score-decay choice (const :tag "never" nil) (const :tag "always" t) const :tag "adaptive score files" "\\." "\\'" ((regexp)) gnus-decay-score-function 'gnus-decay-score "Function called to decay a score.\nIt is called with one parameter -- the score to be decayed." (radio (function-item gnus-decay-score) (function :tag "Other")) gnus-score-decay-constant 3 "Decay all \"small\" scores with this amount." gnus-score-decay-scale 0.05 "Decay all \"big\" scores with this factor." number gnus-home-score-file "Variable to control where interactive score entries are to go.\nIt can be:\n\n * A string\n   This file will be used as the home score file.\n\n * A function\n   The result of this function will be used as the home score file.\n   The function will be passed the name of the group as its\n   parameter.\n\n * A list\n   The elements in this list can be:\n\n   * `(regexp file-name ...)'\n     If the `regexp' matches the group name, the first `file-name'\n     will be used as the home score file.  (Multiple filenames are\n     allowed so that one may use gnus-score-file-single-match-alist to\n     set this variable.)\n\n   * A function.\n     If the function returns non-nil, the result will be used\n     as the home score file.  The function will be passed the\n     name of the group as its parameter.\n\n   * A string.  Use the string as the home score file.\n\n   The list will be traversed from the beginning towards the end looking\n   for matches." (choice string (repeat (choice string (cons regexp (repeat file)) function)) (function-item gnus-hierarchial-home-score-file) (function-item gnus-current-home-score-file) function) gnus-home-adapt-file "Variable to control where new adaptive score entries are to go.\nThis variable allows the same syntax as `gnus-home-score-file'." (choice string (repeat (choice string (cons regexp (repeat file)) function)) function) gnus-default-adaptive-score-alist `((gnus-kill-file-mark) (gnus-unread-mark) (gnus-read-mark (from ,(+ 2 gnus-score-decay-constant)) (subject ,(+ 27 gnus-score-decay-constant))) (gnus-catchup-mark (subject ,(+ -7 (* -1 gnus-score-decay-constant)))) (gnus-killed-mark (from ,(- -1 gnus-score-decay-constant)) (subject ,(+ -17 (* -1 gnus-score-decay-constant)))) (gnus-del-mark (from ,(- -1 gnus-score-decay-constant)) (subject ,(+ -12 (* -1 gnus-score-decay-constant))))) "Alist of marks and scores.\nIf you use score decays, you might want to set values higher than\n`gnus-score-decay-constant'." (repeat (cons (symbol :tag "Mark") (repeat (list (choice :tag "Header" (const from) (const subject) (symbol :tag "other")) (integer :tag "Score"))))) gnus-adaptive-word-length-limit "Words of a length lesser than this limit will be ignored when doing adaptive scoring." :version "22.1" (radio (const :format "Unlimited " nil) (integer :format "Maximum length: %v")) gnus-ignored-adaptive-words "List of words to be ignored when doing adaptive word scoring." (repeat string) gnus-default-ignored-adaptive-words '("a" "i" "the" "to" "of" "and" "in" "is" "it" "for" "that" "if" "you" "this" "be" "on" "with" "not" "have" "are" "or" "as" "from" "can" "but" "by" "at" "an" "will" "no" "all" "was" "do" "there" "my" "one" "so" "we" "they" "what" "would" "any" "which" "about" "get" "your" "use" "some" "me" "then" "name" "like" "out" "when" "up" "time" "other" "more" "only" "just" "end" "also" "know" "how" "new" "should" "been" "than" "them" "he" "who" "make" "may" "people" "these" "now" "their" "here" "into" "first" "could" "way" "had" "see" "work" "well" "were" "two" "very" "where" "while" "us" "because" "good" "same" "even" "much" "most" "many" "such" "long" "his" "over" "last" "since" "right" "before" "our" "without" "too" "those" "why" "must" "part" "being" "current" "back" "still" "go" "point" "value" "each" "did" "both" "true" "off" "say" "another" "state" "might" "under" "start" "try" "re") "Default list of words to be ignored when doing adaptive word scoring." (repeat string) gnus-default-adaptive-word-score-alist `((,gnus-read-mark . 30) (,gnus-catchup-mark . -10) (,gnus-killed-mark . -20) (,gnus-del-mark . -15)) "Alist of marks and scores." (repeat (cons (character :tag "Mark") (integer :tag "Score"))) gnus-adaptive-word-minimum "If a number, this is the minimum score value that can be assigned to a word." (choice (const nil) integer) gnus-adaptive-word-no-group-words "If t, don't adaptively score words included in the group name." gnus-score-mimic-keymap "Have the score entry functions pretend that they are a keymap." gnus-score-exact-adapt-limit 10 "Number that says how long a match has to be before using substring matching.\nWhen doing adaptive scoring, one normally uses fuzzy or substring\nmatching.  However, if the header one matches is short, the possibility\nfor false positives is great, so if the length of the match is less\nthan this variable, exact matching will be used.\n\nIf this variable is nil, exact matching will always be used." (choice (const nil) integer) gnus-score-uncacheable-files "ADAPT$" "All score files that match this regexp will not be cached." regexp gnus-adaptive-pretty-print "If non-nil, adaptive score files fill are pretty printed." "23.1" gnus-score-default-header "Default header when entering new scores.\n\nShould be one of the following symbols.\n\n a: from\n s: subject\n b: body\n h: head\n i: message-id\n t: references\n x: xref\n e: `extra' (non-standard overview)\n l: lines\n d: date\n f: followup\n\nIf nil, the user will be asked for a header." (choice (const :tag "from" a) (const :tag "subject" s) (const :tag "body" b) (const :tag "head" h) (const :tag "message-id" i) (const :tag "references" t) (const :tag "xref" x) (const :tag "extra" e) (const :tag "lines" l) (const :tag "date" d) (const :tag "followup" f) (const :tag "ask" nil)) gnus-score-default-type "Default match type when entering new scores.\n\nShould be one of the following symbols.\n\n s: substring\n e: exact string\n f: fuzzy string\n r: regexp string\n b: before date\n a: after date\n n: this date\n <: less than number\n >: greater than number\n =: equal to number\n\nIf nil, the user will be asked for a match type." (choice (const :tag "substring" s) (const :tag "exact string" e) (const :tag "fuzzy string" f) (const :tag "regexp string" r) (const :tag "before date" b) (const :tag "after date" a) (const :tag "this date" n) (const :tag "less than number" <) (const :tag "greater than number" >) (const :tag "equal than number" =) (const :tag "ask" nil)) gnus-score-default-fold "Non-nil means use case folding for new score file entries." gnus-score-default-duration "Default duration of effect when entering new scores.\n\nShould be one of the following symbols.\n\n t: temporary\n p: permanent\n i: immediate\n\nIf nil, the user will be asked for a duration." (choice (const :tag "temporary" t) (const :tag "permanent" p) (const :tag "immediate" i) (const :tag "ask" nil)) gnus-score-after-write-file-function "Function called with the name of the score file just written to disk." (choice (const nil) function) gnus-score-thread-simplify "If non-nil, subjects will simplified as in threading." gnus-score-various gnus-inhibit-slow-scoring "Inhibit slow scoring, e.g. scoring on headers or body.\n\nIf a regexp, scoring on headers or body is inhibited if the group\nmatches the regexp.  If it is t, scoring on headers or body is\ninhibited for all groups." (choice (const :tag "All" nil) (const :tag "None" t) regexp)] 16)
#@62 If nil, only `gnus-score-find-score-files-function' is used.
(defvar gnus-score-use-all-scores t (#$ . 13620))
#@53 Syntax table used when doing adaptive word scoring.
(defvar gnus-adaptive-word-syntax-table (byte-code "\302\303 !\304\203 \305\211A\242\306	#\210\202 \305\307\310	#\210	*\207" [numbers table copy-syntax-table standard-syntax-table (48 49 50 51 52 53 54 55 56 57) modify-syntax-entry " " 39 "w"] 4) (#$ . 13737))
(defvar gnus-scores-exclude-files nil)
(defvar gnus-internal-global-score-files nil)
(defvar gnus-score-file-list nil)
(defvar gnus-short-name-score-file-cache nil)
(defvar gnus-score-help-winconf nil)
(defvar gnus-adaptive-score-alist gnus-default-adaptive-score-alist)
(defvar gnus-adaptive-word-score-alist gnus-default-adaptive-word-score-alist)
(defvar gnus-score-trace nil)
(defvar gnus-score-edit-buffer nil)
#@683 Alist containing score information.
The keys can be symbols or strings.  The following symbols are defined.
touched: If this alist has been modified.
mark:    Automatically mark articles below this.
expunge: Automatically expunge articles below this.
files:   List of other score files to load when loading this one.
eval:    Sexp to be evaluated when the score file is loaded.
String entries have the form (HEADER (MATCH TYPE SCORE DATE) ...)
where HEADER is the header being scored, MATCH is the string we are
looking for, TYPE is a flag indicating whether it should use regexp or
substring matching, SCORE is the score to add and DATE is the date
of the last successful match.
(defvar gnus-score-alist nil (#$ . 14480))
(defvar gnus-score-cache nil)
(defvar gnus-scores-articles nil)
(defvar gnus-score-index nil)
(defconst gnus-header-index '(("number" 0 gnus-score-integer) ("subject" 1 gnus-score-string) ("from" 2 gnus-score-string) ("date" 3 gnus-score-date) ("message-id" 4 gnus-score-string) ("references" 5 gnus-score-string) ("chars" 6 gnus-score-integer) ("lines" 7 gnus-score-integer) ("xref" 8 gnus-score-string) ("extra" 9 gnus-score-string) ("head" -1 gnus-score-body) ("body" -1 gnus-score-body) ("all" -1 gnus-score-body) ("followup" 2 gnus-score-followup) ("thread" 5 gnus-score-thread)))
(gnus-define-keys-1 '(gnus-summary-score-map "V" gnus-summary-mode-map) '("s" gnus-summary-set-score "S" gnus-summary-current-score "c" gnus-score-change-score-file "C" gnus-score-customize "m" gnus-score-set-mark-below "x" gnus-score-set-expunge-below "R" gnus-summary-rescore "e" gnus-score-edit-current-scores "f" gnus-score-edit-file "F" gnus-score-flush-cache "t" gnus-score-find-trace "w" gnus-score-find-favorite-words))
#@327 Make a score entry based on the current article.
The user will be prompted for header to score on, match type,
permanence, and the string to be used.  The numerical prefix will
be used as SCORE.  A symbolic prefix of `a' (the SYMP parameter)
says to use the `all.SCORE' file for the command instead of the
current score file.
(defalias 'gnus-summary-lower-score #[(&optional score symp) "\302\303![	\"\207" [score symp gnus-summary-increase-score gnus-score-delta-default] 3 (#$ . 16226) (gnus-interactive "P\ny")])
(defalias 'gnus-score-kill-help-buffer #[nil "\301\302!\205 \303\302!\210\205 \304!\207" [gnus-score-help-winconf get-buffer "*Score Help*" kill-buffer set-window-configuration] 2])
#@327 Make a score entry based on the current article.
The user will be prompted for header to score on, match type,
permanence, and the string to be used.  The numerical prefix will
be used as SCORE.  A symbolic prefix of `a' (the SYMP parameter)
says to use the `all.SCORE' file for the command instead of the
current score file.
(defalias 'gnus-summary-increase-score #[(&optional score symp) "\306!\211\307W\203 \310\202 \311	\307V\312\313@A\314\315 \316E\317\320EBCDE\2055 \321E!\307HFG\205B \321G!\307HHI\205O \321I!\307HJ\322\211KL\322\211MN\322O\323\216F\204\247 D\203x \324\325!\210\326\327\n\"\210\202\212 \326\330\203\202 \331\202\203 \332\333\334\f\335##\210\336 \211F\337U\204\233 F\340U\203b \322F\341\342\f\325#\210\202b \343 \210F\227\f\236\211K\204\310 D\203\304 \344\345\nF#\210\202\310 \344\346!\210F\227FU\204\364 D\203\340 \326\345\nF#\210\202\344 \326\335!\210H\206\352 \347HJ\206\362 \314J\350\322\351\352
\"\"PH\204JD\203\324\325!\210\326\353\nF#\210\202,\326\354\203\331\202 \332KA@\333\355P\335#$\210\336 \211H\337U\204=H\340U\203\375 \322H\341\356P\357#\210\202\375 \343 \210H\227P\236A@\211M\204nD\203j\344\345\nF#\210\202n\344\360!\210)H\227HU\204\225D\203\211\326\361\nFH$\210\202\215\326\335!\210J\206\223\314JJ\204\340D\203\257\324\325!\210\326\362\nFH$\210\202\302\326\363\203\271\331\202\272\332\333\364B\335##\210\336 \211J\337U\204\323J\340U\203\225\322J\341\365B\357#\210\202\225\343 \210D\203\366\326\366\nFHJ%\210\202\372\326\335!\210JB\236A@\211L\204C\nT\367=\203,F\370\\\371=\203,HS\372=\203,J\373Z\374=\203,\344\375!\210D\203?\344\366\nFHJ%\210\202C\344\376!\210)Q\205pKA@\377\232\205p\201V \351\321Q\"R\201W \201X R\201Y \322\211R@&)!O\357K8\335\230\203\335\202\221\201Z \357K8\206\215KA@\322O#NKA@\201[ \232\203\312\201\\ \201] N\"\203\264\201^ N\307\225\"N\201\\ \201_ N\"\203\312\201^ N\307\225\"NM\201` >\203\333\201a N!NS\201b =\203\frTq\210\201c U\201d \267\202\201e \335!\202	A\202	\201e \201f !!\210)\201g KA@NM\201h =?\205!L\201i =?\205-L\201j K8?\322O&\210S\201b =\205OrTq\210\201c A!).\207" [score nscore prefix increase char-to-header char-to-type gnus-score-delta-default 0 76 73 ((97 "from" nil nil string) (115 "subject" nil nil string) (98 "body" #1="" nil body-string) (104 "head" #1# nil body-string) (105 "message-id" nil nil string) (114 "references" "message-id" nil string) (120 "xref" nil nil string) (101 "extra" nil nil string) (108 "lines" nil nil number) (100 "date" nil nil date) (102 "followup" nil nil string) (116 "thread" "message-id" nil string)) ((115 s "substring" string) (101 e "exact string" string) (102 f "fuzzy string" string) (114 r "regexp string" string) (122 s "substring" body-string) (112 r "regexp string" body-string) (98 before "before date" date) (97 after "after date" date) (110 at "this date" date) (60 < "less than number" number) (62 > "greater than number" number) (61 = "equal to number" number)) 116 current-time-string "temporary" (112 perm "permanent") (105 now "immediate") symbol-name nil #[nil "\300 \207" [gnus-score-kill-help-buffer] 1] sit-for 1 message "%c-" "%s header (%s?): " "Increase" "Lower" mapconcat #[(s) "\301@!\207" [s char-to-string] 2] #1# read-char 63 8 gnus-score-insert-help "Match on header" gnus-score-kill-help-buffer error "%c %c" "Invalid header type" 115 delq mapcar #[(s) "\3028\303	8=\205 	\207" [entry s 4 3] 3] "%c %c-" "%s header `%s' with match type (%s?): " #[(s) "\301@!\207" [s char-to-string] 2] "Match type" 2 "Invalid match type" "%c %c %c" "%c %c %c-" "%s permanence (%s?): " #[(s) "\301@!\207" [s char-to-string] 2] "Match permanence" "%c %c %c %c" 77 12 109 113 4 111 "You rang?" "Invalid match duration" "extra" gnus-current-score-file current-score-file char-to-perm gnus-score-mimic-keymap mimic gnus-score-default-header hchar gnus-score-default-type tchar gnus-score-default-duration pchar entry temporary type match extra legal-types gnus-extra-headers collection symp gnus-summary-buffer gnus-score-find-score-files-function intern gnus-completing-read "Score extra header" t gnus-summary-header "xref" string-match "^Xref: *" substring "^[^:]* +" (r R regexp Regexp) regexp-quote a gnus-score-load-file #s(hash-table size 2 test eq rehash-size 1.5 rehash-threshold 0.8125 purecopy t data (gnus-score-find-hierarchical 757 gnus-score-find-single 765)) gnus-score-file-name "all" gnus-summary-score-entry s perm 3] 10 (#$ . 16936) (gnus-interactive "P\ny")])
(autoload 'appt-select-lowest-window "appt")
(defalias 'gnus-score-insert-help #[(string alist idx) "\306 r\307\310!q\210\311 \210\312p!\210\313 \210	\314\261\210\315\n\316\317\211\211\211#$%&%\203M '%@8G#&#V\204D #&%A\211%\204/ &\320\\&\321 S&\245#\321 S#\245\n\203\233 $#W\204x \316$\322\315!\210\323c\210
\324Z\325\326\f!\327Q\303\n@@'\n@8#c\210\nA$T$\202b .eb\210\330 \210\331 \332\245(W\203\264 \333\310!\210\202\273 \334 \210\335\310!\210\336(\337 \210)\340\341)\342\"!)\207" [gnus-score-help-winconf string alist format pad width current-window-configuration gnus-get-buffer-create "*Score Help*" buffer-disable-undo delete-windows-on erase-buffer ":\n\n" -1 0 nil 4 window-width delete-char "\n" 3 "%c: %-" int-to-string "s" appt-select-lowest-window window-height 2 switch-to-buffer split-window pop-to-buffer 1 shrink-window-if-larger-than-buffer select-window gnus-get-buffer-window t n i list max idx window-min-height gnus-summary-buffer] 8])
(defalias 'gnus-summary-header #[(header &optional no-err extra) "\306`\307\"\211\203\f \310!\210\210\306`\311\"\206 \312 \313\211\203Z \314	\n\"\3158)\211\203N \316!\203N \f\203B \f\317H\236A\206b \320\202b \321
\"A@H\202b ?\205b \322\323!\202b \205b \322\324!*\207" [headers article gnus-newsgroup-data cl-x extra header get-text-property gnus-intangible gnus-summary-goto-subject gnus-number gnus-summary-last-subject nil gnus-data-find-in 3 vectorp 9 "" assoc error "Pseudo-articles can't be scored" "No article on current line" gnus-header-index no-err] 5])
(defalias 'gnus-newsgroup-score-alist #[nil "\303\304\"\211\205\f \305	!)\204 \305\306!!\210\n\207" [gnus-newsgroup-name param-file gnus-score-alist gnus-group-find-parameter score-file gnus-score-load gnus-score-file-name] 4])
(defalias 'gnus-score-get #[(symbol &optional alist) "\303	\206\f \n\206\f \304 \"A\207" [symbol alist gnus-score-alist assoc gnus-newsgroup-score-alist] 3])
(put 'gnus-score-get 'byte-optimizer 'byte-compile-inline-expand)
#@474 Enter score file entry.
HEADER is the header being scored.
MATCH is the string we are looking for.
TYPE is the match type: substring, regexp, exact, fuzzy.
SCORE is the score to add.
DATE is the expire date, or nil for no expire, or `now' for immediate expire.
If optional argument `PROMPT' is non-nil, allow user to edit match.
If optional argument `SILENT' is nil, show effect of score entry.
If optional argument `EXTRA' is non-nil, it's a non-standard overview header.
(defalias 'gnus-summary-score-entry #[(header match type score date &optional prompt silent extra) "\306=\203 \307\307=\204 \310=\204 \311=\2035 	\2030 	\312\n\"\2031 \313\314\225\"\262\2021 \315\202? \316=\203? \317	!\320!\f\227\311\321\314\fG\311\f$\210*\203\211 \322\323\324+\325=\203c \326\202n +;\203m \327\202n \330\f\314W\203y \331\202z \332$	\247\203\206 \333	!\202\207 	\"\334\335\f,\"8\336=\203\241 	;\203\251 \337	!\202\251 \321\314	G\311	$\210+\325=\204\241-U\203\271 \311\f\311./\335/.\206\316 0\206\316 \340 \"A*\311123\203\373 	+\205\361 +\247\203\355 +\202\361 \341+!\3423!\257\2025\203	+\205+\247\203+\202\341+!F\2025+\203)	\341+!E\2025\2033	D\2025	C2\203\207\335	2\"\2111\203\207\34318\343
8=\203\207\33418\247\203`\334
8\247\204m\33418\204\207\334
8\204\2071A1A@\206y-
A@\206\201-\\\240\210\202\233\344\f2\203\225
2B\202\227
C\311\306$\210\344\345\346\"\210*4\204\315\335\f,\"A@\314Y\203\312\334\335\f,\"8\347=\203\312\350\f	3%\210\202\315\351 \210
+\207" [type match message-subject-re-regexp score header new t r s nil string-match substring 0 "" f gnus-simplify-subject-fuzzy gnus-score-delta-default set-text-properties read-string format "Match %s on %s, %s: " now "now" "temp" "permanent" "lower" "raise" int-to-string 2 assoc gnus-score-integer string-to-number gnus-newsgroup-score-alist date-to-day symbol-name 3 gnus-score-set touched (t) gnus-score-string gnus-summary-score-effect gnus-summary-rescore prompt date gnus-header-index gnus-score-interactive-default-score alist symbol gnus-score-alist elem old extra silent] 7 (#$ . 23569)])
#@213 Simulate the effect of a score file entry.
HEADER is the header being scored.
MATCH is the string we are looking for.
TYPE is the score type.
SCORE is the score to add.
EXTRA is the possible non-standard header.
(defalias 'gnus-summary-score-effect #[(header match type score &optional extra) "\212;\203
 G\306V\204 \307\310!\210eb\210	\311\267\202- \312!\2020 \2020 \313\314!\315Q\2020 \314!m\204f \316\317\f#\320\211\203^ 	\321=\203Q \312!\n\230\202V \322\n\"\203^ \323!\210*\324\325!\210\2021 *\326\327!\207" [match type regexp header extra case-fold-search 0 error "No match" #s(hash-table size 3 test eq rehash-size 1.5 rehash-threshold 0.8125 purecopy t data (f 26 r 32 e 36)) gnus-simplify-subject-fuzzy "\\`" regexp-quote "\\'" gnus-summary-header noerr t f string-match gnus-summary-raise-score beginning-of-line 2 gnus-set-mode-line summary content score] 5 (#$ . 25726) (list (gnus-completing-read "Header" (mapcar 'car (seq-filter #'(lambda (x) (fboundp (nth 2 x))) gnus-header-index)) t) (read-string "Match: ") (if (y-or-n-p "Use regexp match? ") 'r 's) (string-to-number (read-string "Score: ")))])
#@61 Automatically mark articles with score below SCORE as read.
(defalias 'gnus-score-set-mark-below #[(score) "\206	 	\206	 \303\304\305C\"\210\304\306\307\"\210\310 \207" [score gnus-summary-default-score gnus-summary-mark-below 0 gnus-score-set mark touched (t) gnus-score-update-lines] 3 (#$ . 26864) (list (or (and current-prefix-arg (prefix-numeric-value current-prefix-arg)) (string-to-number (read-string "Mark below: "))))])
#@41 Update all lines in the summary buffer.
(defalias 'gnus-score-update-lines #[nil "\212eb\210m?\205 \300 \210\301y\210\202 )\207" [gnus-summary-update-line 1] 1 (#$ . 27305)])
#@63 Update all lines in the summary buffer, even the hidden ones.
(defalias 'gnus-score-update-all-lines #[nil "\212eb\210\301m\204 \302 \203 `B\303 \210\304y\210\202 \205- \211A\242b\210\305 \210\202 *\207" [hidden nil gnus-summary-show-thread gnus-summary-update-line 1 gnus-summary-hide-thread] 2 (#$ . 27488)])
#@56 Automatically expunge articles with score below SCORE.
(defalias 'gnus-score-set-expunge-below #[(score) "\206	 	\206	 \302\303\304C\"\210\303\305\306\"\207" [score gnus-summary-default-score 0 gnus-score-set expunge touched (t)] 3 (#$ . 27815) (list (or (and current-prefix-arg (prefix-numeric-value current-prefix-arg)) (string-to-number (read-string "Set expunge below: "))))])
#@66 Add SCORE to all followups to the article in the current buffer.
(defalias 'gnus-score-followup-article #[(&optional score) "\304!	\211\205 \305\306\n!\211!\205 \n)\2057 \212\214\307 \210\310\311!\211\2056 	q\210\312\313\314P\315\316 \317\320&+\207" [score gnus-summary-buffer buffer id gnus-score-delta-default buffer-live-p get-buffer message-narrow-to-headers mail-fetch-field "message-id" gnus-summary-score-entry "references" "[ 	]*$" r current-time-string nil t] 9 (#$ . 28205) "P"])
#@78 Add SCORE to all later articles in the thread the current buffer is part of.
(defalias 'gnus-score-followup-thread #[(&optional score) "\304!	\211\205 \305\306\n!\211!\205 \n)\2052 \212\214eb\210\307\310!\211\2051 	q\210\311\312\313\314 %+\207" [score gnus-summary-buffer buffer id gnus-score-delta-default buffer-live-p get-buffer mail-fetch-field "message-id" gnus-summary-score-entry "references" s current-time-string] 7 (#$ . 28711) "P"])
(defalias 'gnus-score-set #[(symbol value &optional alist warn) "\206\n 	\206\n \306 \307\n\"\310\307\n\206  	\206  \306 \"A*\2031 \f\205M \311\312\313\"\202M \203; 
\241\202M \204E \314\315!\202M \n
BAB\241*\207" [alist gnus-score-alist symbol entry warn value gnus-newsgroup-score-alist assoc read-only gnus-message 4 "Note: read-only score file; entry discarded" error "Empty alist"] 3])
#@46 Raise the score of the current article by N.
(defalias 'gnus-summary-raise-score #[(n) "\304\305`\306\"\211\203
 \307!\210\210\305`\310\"\206 \311 \236A\206\"