Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
d8921379
Commit
d8921379
authored
Nov 10, 2003
by
Martin v. Löwis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Patch #798297: Add IMAP THREAD command.
parent
49ee14da
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
38 additions
and
0 deletions
+38
-0
Doc/lib/libimaplib.tex
Doc/lib/libimaplib.tex
+22
-0
Lib/imaplib.py
Lib/imaplib.py
+11
-0
Misc/ACKS
Misc/ACKS
+1
-0
Misc/NEWS
Misc/NEWS
+4
-0
No files found.
Doc/lib/libimaplib.tex
View file @
d8921379
...
...
@@ -355,6 +355,28 @@ msgnums = M.search(None, '(FROM "LDJ")')
Subscribe to new mailbox.
\end{methoddesc}
\begin{methoddesc}
{
thread
}{
threading
_
algorithm, charset, search
_
criterion
\optional
{
, ...
}}
The
\code
{
thread
}
command is a variant of
\code
{
search
}
with threading semantics for
the results. Returned data contains a space
separated list of thread members.
Thread members consist of zero or more messages numbers, delimited by spaces,
indicating successive parent and child.
Thread has two arguments before the
\var
{
search
_
criterion
}
argument(s); a
\var
{
threading
_
algorithm
}
, and the searching
\var
{
charset
}
.
Note that unlike
\code
{
search
}
, the searching
\var
{
charset
}
argument is mandatory.
There is also a
\code
{
uid thread
}
command which corresponds to
\code
{
thread
}
the way
that
\code
{
uid search
}
corresponds to
\code
{
search
}
.
The
\code
{
thread
}
command first searches the mailbox for messages that
match the given searching criteria using the charset argument for
the interpretation of strings in the searching criteria. It thren
returns the matching messages threaded according to the specified
threading algorithm.
This is an
\samp
{
IMAP4rev1
}
extension command.
\versionadded
{
2.4
}
\end{methoddesc}
\begin{methoddesc}
{
uid
}{
command, arg
\optional
{
, ...
}}
Execute command args with messages identified by UID, rather than
message number. Returns response appropriate to command. At least
...
...
Lib/imaplib.py
View file @
d8921379
...
...
@@ -69,6 +69,7 @@ Commands = {
'STATUS'
:
(
'AUTH'
,
'SELECTED'
),
'STORE'
:
(
'SELECTED'
,),
'SUBSCRIBE'
:
(
'AUTH'
,
'SELECTED'
),
'THREAD'
:
(
'SELECTED'
,),
'UID'
:
(
'SELECTED'
,),
'UNSUBSCRIBE'
:
(
'AUTH'
,
'SELECTED'
),
}
...
...
@@ -679,6 +680,16 @@ class IMAP4:
return
self
.
_simple_command
(
'SUBSCRIBE'
,
mailbox
)
def
thread
(
self
,
threading_algorithm
,
charset
,
*
search_criteria
):
"""IMAPrev1 extension THREAD command.
(type, [data]) = <instance>.thread(threading_alogrithm, charset, search_criteria, ...)
"""
name
=
'THREAD'
typ
,
dat
=
self
.
_simple_command
(
name
,
threading_algorithm
,
charset
,
*
search_criteria
)
return
self
.
_untagged_response
(
typ
,
dat
,
name
)
def
uid
(
self
,
command
,
*
args
):
"""Execute "command arg ..." with messages identified by UID,
rather than message number.
...
...
Misc/ACKS
View file @
d8921379
...
...
@@ -137,6 +137,7 @@ John DeGood
Vincent Delft
Roger Dev
Toby Dickenson
Yves Dionne
Daniel Dittmar
Walter Drwald
Jaromir Dolecek
...
...
Misc/NEWS
View file @
d8921379
...
...
@@ -57,6 +57,8 @@ Core and builtins
Extension
modules
-----------------
-
os
.
getsid
was
added
.
-
The
pwd
module
incorrectly
advertised
its
struct
type
as
struct_pwent
;
this
has
been
renamed
to
struct_passwd
.
(
The
old
name
is
still
supported
for
backwards
compatibility
.)
...
...
@@ -104,6 +106,8 @@ Extension modules
Library
-------
-
imaplib
.
IMAP4
.
thread
was
added
.
-
Plugged
a
minor
hole
in
tempfile
.
mktemp
()
due
to
the
use
of
os
.
path
.
exists
(),
switched
to
using
os
.
lstat
()
directly
if
possible
.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment