Re: Problem with draft mails when using offlineimap
[notmuch-archives.git] / 1d / 45b2ba218d5138dd7888db46b83dde597c4bbc
1 Return-Path: <teythoon@jade-hamburg.de>\r
2 X-Original-To: notmuch@notmuchmail.org\r
3 Delivered-To: notmuch@notmuchmail.org\r
4 Received: from localhost (localhost [127.0.0.1])\r
5         by olra.theworths.org (Postfix) with ESMTP id EB0D3429E2F\r
6         for <notmuch@notmuchmail.org>; Wed, 14 Dec 2011 05:04:50 -0800 (PST)\r
7 X-Virus-Scanned: Debian amavisd-new at olra.theworths.org\r
8 X-Spam-Flag: NO\r
9 X-Spam-Score: 0\r
10 X-Spam-Level: \r
11 X-Spam-Status: No, score=0 tagged_above=-999 required=5 tests=[none]\r
12         autolearn=disabled\r
13 Received: from olra.theworths.org ([127.0.0.1])\r
14         by localhost (olra.theworths.org [127.0.0.1]) (amavisd-new, port 10024)\r
15         with ESMTP id L4+mpuVvnR5N for <notmuch@notmuchmail.org>;\r
16         Wed, 14 Dec 2011 05:04:50 -0800 (PST)\r
17 Received: from mail.cryptobitch.de (cryptobitch.de [88.198.7.68])\r
18         (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits))\r
19         (No client certificate requested)\r
20         by olra.theworths.org (Postfix) with ESMTPS id BEC39429E27\r
21         for <notmuch@notmuchmail.org>; Wed, 14 Dec 2011 05:04:49 -0800 (PST)\r
22 Received: from mail.jade-hamburg.de (unknown [85.183.11.228])\r
23         (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits))\r
24         (No client certificate requested)\r
25         by mail.cryptobitch.de (Postfix) with ESMTPSA id 8936950F522\r
26         for <notmuch@notmuchmail.org>; Wed, 14 Dec 2011 14:04:48 +0100 (CET)\r
27 Received: by mail.jade-hamburg.de (Postfix, from userid 401)\r
28         id 7CCBADF2A1; Wed, 14 Dec 2011 14:04:47 +0100 (CET)\r
29 Received: from thinkbox.jade-hamburg.de (unknown [85.183.11.228])\r
30         (using TLSv1 with cipher AES256-SHA (256/256 bits))\r
31         (No client certificate requested) (Authenticated sender: teythoon)\r
32         by mail.jade-hamburg.de (Postfix) with ESMTPSA id E77F4DF29F;\r
33         Wed, 14 Dec 2011 14:04:43 +0100 (CET)\r
34 Received: from teythoon by thinkbox.jade-hamburg.de with local (Exim 4.77)\r
35         (envelope-from <teythoon@thinkbox.jade-hamburg.de>)\r
36         id 1RaoVm-00086t-N6; Wed, 14 Dec 2011 14:04:42 +0100\r
37 From: Justus Winter <4winter@informatik.uni-hamburg.de>\r
38 To: notmuch@notmuchmail.org\r
39 Subject: [PATCH 6/7] py3k: Add and use a mixin class that implements __str__\r
40 Date: Wed, 14 Dec 2011 14:04:35 +0100\r
41 Message-Id:\r
42  <1323867875-30684-1-git-send-email-4winter@informatik.uni-hamburg.de>\r
43 X-Mailer: git-send-email 1.7.7.3\r
44 In-Reply-To: <E1RaoOA-0007ka-G7@thinkbox.jade-hamburg.de>\r
45 References: <E1RaoOA-0007ka-G7@thinkbox.jade-hamburg.de>\r
46 X-BeenThere: notmuch@notmuchmail.org\r
47 X-Mailman-Version: 2.1.13\r
48 Precedence: list\r
49 List-Id: "Use and development of the notmuch mail system."\r
50         <notmuch.notmuchmail.org>\r
51 List-Unsubscribe: <http://notmuchmail.org/mailman/options/notmuch>,\r
52         <mailto:notmuch-request@notmuchmail.org?subject=unsubscribe>\r
53 List-Archive: <http://notmuchmail.org/pipermail/notmuch>\r
54 List-Post: <mailto:notmuch@notmuchmail.org>\r
55 List-Help: <mailto:notmuch-request@notmuchmail.org?subject=help>\r
56 List-Subscribe: <http://notmuchmail.org/mailman/listinfo/notmuch>,\r
57         <mailto:notmuch-request@notmuchmail.org?subject=subscribe>\r
58 X-List-Received-Date: Wed, 14 Dec 2011 13:04:51 -0000\r
59 \r
60 ---\r
61  bindings/python/notmuch/filename.py |    7 ++-----\r
62  bindings/python/notmuch/globals.py  |   15 +++++++++++----\r
63  bindings/python/notmuch/message.py  |    8 +++-----\r
64  bindings/python/notmuch/tag.py      |    7 ++-----\r
65  bindings/python/notmuch/thread.py   |    7 ++-----\r
66  5 files changed, 20 insertions(+), 24 deletions(-)\r
67 \r
68 diff --git a/bindings/python/notmuch/filename.py b/bindings/python/notmuch/filename.py\r
69 index a7cd7e6..969931a 100644\r
70 --- a/bindings/python/notmuch/filename.py\r
71 +++ b/bindings/python/notmuch/filename.py\r
72 @@ -18,10 +18,10 @@ Copyright 2010 Sebastian Spaeth <Sebastian@SSpaeth.de>'\r
73  """\r
74  from ctypes import c_char_p\r
75  from notmuch.globals import (nmlib, STATUS, NotmuchError,\r
76 -    NotmuchFilenamesP, NotmuchMessageP)\r
77 +    NotmuchFilenamesP, NotmuchMessageP, _str, Python3StringMixIn)\r
78  \r
79  \r
80 -class Filenames(object):\r
81 +class Filenames(Python3StringMixIn):\r
82      """Represents a list of filenames as returned by notmuch\r
83  \r
84      This object contains the Filenames iterator. The main function is\r
85 @@ -98,9 +98,6 @@ class Filenames(object):\r
86  \r
87          self._files = None\r
88  \r
89 -    def __str__(self):\r
90 -        return unicode(self).encode('utf-8')\r
91 -\r
92      def __unicode__(self):\r
93          """Represent Filenames() as newline-separated list of full paths\r
94  \r
95 diff --git a/bindings/python/notmuch/globals.py b/bindings/python/notmuch/globals.py\r
96 index c52790c..2111b86 100644\r
97 --- a/bindings/python/notmuch/globals.py\r
98 +++ b/bindings/python/notmuch/globals.py\r
99 @@ -28,6 +28,16 @@ except:\r
100      raise ImportError("Could not find shared 'notmuch' library.")\r
101  \r
102  \r
103 +if sys.version_info[0] == 2:\r
104 +    class Python3StringMixIn(object):\r
105 +        def __str__(self):\r
106 +            return unicode(self).encode('utf-8')\r
107 +else:\r
108 +    class Python3StringMixIn(object):\r
109 +        def __str__(self):\r
110 +            return self.__unicode__()\r
111 +\r
112 +\r
113  class Enum(object):\r
114      """Provides ENUMS as "code=Enum(['a','b','c'])" where code.a=0 etc..."""\r
115      def __init__(self, names):\r
116 @@ -90,7 +100,7 @@ argument to receive a human readable string"""\r
117  STATUS.__name__ = 'STATUS'\r
118  \r
119  \r
120 -class NotmuchError(Exception):\r
121 +class NotmuchError(Exception, Python3StringMixIn):\r
122      """Is initiated with a (notmuch.STATUS[, message=None]). It will not\r
123      return an instance of the class NotmuchError, but a derived instance\r
124      of a more specific Error Message, e.g. OutOfMemoryError. Each status\r
125 @@ -134,9 +144,6 @@ class NotmuchError(Exception):\r
126          self.status = status\r
127          self.message = message\r
128  \r
129 -    def __str__(self):\r
130 -        return unicode(self).encode('utf-8')\r
131 -\r
132      def __unicode__(self):\r
133          if self.message is not None:\r
134              return self.message\r
135 diff --git a/bindings/python/notmuch/message.py b/bindings/python/notmuch/message.py\r
136 index bf0c4da..955382d 100644\r
137 --- a/bindings/python/notmuch/message.py\r
138 +++ b/bindings/python/notmuch/message.py\r
139 @@ -21,7 +21,8 @@ Copyright 2010 Sebastian Spaeth <Sebastian@SSpaeth.de>'\r
140  \r
141  from ctypes import c_char_p, c_long, c_uint, c_int\r
142  from datetime import date\r
143 -from notmuch.globals import (nmlib, STATUS, NotmuchError, Enum, _str,\r
144 +from notmuch.globals import (\r
145 +    nmlib, STATUS, NotmuchError, Enum, _str, Python3StringMixIn,\r
146      NotmuchTagsP, NotmuchMessagesP, NotmuchMessageP, NotmuchFilenamesP)\r
147  from notmuch.tag import Tags\r
148  from notmuch.filename import Filenames\r
149 @@ -239,7 +240,7 @@ class Messages(object):\r
150          sys.stdout.write(set_end)\r
151  \r
152  \r
153 -class Message(object):\r
154 +class Message(Python3StringMixIn):\r
155      """Represents a single Email message\r
156  \r
157      Technically, this wraps the underlying *notmuch_message_t*\r
158 @@ -796,9 +797,6 @@ class Message(object):\r
159          """Represent a Message() object by str()"""\r
160          return self.__str__()\r
161  \r
162 -    def __str__(self):\r
163 -        return unicode(self).encode('utf-8')\r
164 -\r
165      def __unicode__(self):\r
166          format = "%s (%s) (%s)"\r
167          return format % (self.get_header('from'),\r
168 diff --git a/bindings/python/notmuch/tag.py b/bindings/python/notmuch/tag.py\r
169 index d42ba77..ceb7244 100644\r
170 --- a/bindings/python/notmuch/tag.py\r
171 +++ b/bindings/python/notmuch/tag.py\r
172 @@ -17,10 +17,10 @@ along with notmuch.  If not, see <http://www.gnu.org/licenses/>.\r
173  Copyright 2010 Sebastian Spaeth <Sebastian@SSpaeth.de>'\r
174  """\r
175  from ctypes import c_char_p\r
176 -from notmuch.globals import nmlib, STATUS, NotmuchError, NotmuchTagsP\r
177 +from notmuch.globals import nmlib, STATUS, NotmuchError, NotmuchTagsP, _str, Python3StringMixIn\r
178  \r
179  \r
180 -class Tags(object):\r
181 +class Tags(Python3StringMixIn):\r
182      """Represents a list of notmuch tags\r
183  \r
184      This object provides an iterator over a list of notmuch tags (which\r
185 @@ -111,9 +111,6 @@ class Tags(object):\r
186              left."""\r
187          return self._valid(self._tags) > 0\r
188  \r
189 -    def __str__(self):\r
190 -        return unicode(self).encode('utf-8')\r
191 -\r
192      def __unicode__(self):\r
193          """string representation of :class:`Tags`: a space separated list of tags\r
194  \r
195 diff --git a/bindings/python/notmuch/thread.py b/bindings/python/notmuch/thread.py\r
196 index 39285d6..7393097 100644\r
197 --- a/bindings/python/notmuch/thread.py\r
198 +++ b/bindings/python/notmuch/thread.py\r
199 @@ -20,13 +20,13 @@ Copyright 2010 Sebastian Spaeth <Sebastian@SSpaeth.de>'\r
200  from ctypes import c_char_p, c_long, c_int\r
201  from notmuch.globals import (nmlib, STATUS,\r
202      NotmuchError, NotmuchThreadP, NotmuchThreadsP, NotmuchMessagesP,\r
203 -    NotmuchTagsP,)\r
204 +    NotmuchTagsP, Python3StringMixIn)\r
205  from notmuch.message import Messages\r
206  from notmuch.tag import Tags\r
207  from datetime import date\r
208  \r
209  \r
210 -class Threads(object):\r
211 +class Threads(Python3StringMixIn):\r
212      """Represents a list of notmuch threads\r
213  \r
214      This object provides an iterator over a list of notmuch threads\r
215 @@ -392,9 +392,6 @@ class Thread(object):\r
216              raise NotmuchError(STATUS.NULL_POINTER)\r
217          return Tags(tags_p, self)\r
218  \r
219 -    def __str__(self):\r
220 -        return unicode(self).encode('utf-8')\r
221 -\r
222      def __unicode__(self):\r
223          frm = "thread:%s %12s [%d/%d] %s; %s (%s)"\r
224  \r
225 -- \r
226 1.7.7.3\r
227 \r