This issue tracker has been migrated to GitHub ,
and is currently read-only.
For more information,
see the GitHub FAQs in the Python's Developer Guide.
Created on 2011年07月11日 18:31 by r.david.murray, last changed 2022年04月11日 14:57 by admin. This issue is now closed.
| Files | ||||
|---|---|---|---|---|
| File name | Uploaded | Description | Edit | |
| 12537.patch | dlam, 2011年09月19日 10:31 | review | ||
| 12537.find.attribute.differences.patch | dlam, 2011年09月19日 10:35 | What I used in test_mailbox.py to find special attribute differences between message formats | ||
| Messages (10) | |||
|---|---|---|---|
| msg140157 - (view) | Author: R. David Murray (r.david.murray) * (Python committer) | Date: 2011年07月11日 18:31 | |
The mailbox module has a method _become_message that copies attributes from an object that is an email.message.Message subclass to the calling object (which is also a subclass of email.message.Message). This method is very fragile in the face of any changes to the email.message.Message attribute set. Instead it would be better to decouple the mailbox and email modules by copying *all* __dict__ attributes from the source message to the new object, and then rewrite the _explain_to methods to not only convert the 'special attributes' to the correct format for the new subclass, but also delete any leftover "special" attributes. |
|||
| msg140163 - (view) | Author: José María Ruiz Aguilera (josemaria) | Date: 2011年07月11日 21:11 | |
Hi, I will be working on this issue. This is the first time I will work on a issue in Python so please patient. |
|||
| msg144061 - (view) | Author: David Lam (dlam) * | Date: 2011年09月15日 00:29 | |
Hi hi, noob here. I found this today after clicking 'Easy issues' link. Would something like this work? test_mailbox.py seems to pass. However, I'm not too sure what more needs to be done in the _explain_to. It seems like everything to convert headers/flags between message formats are already there ? diff -r 63bf3bae20ef Lib/mailbox.py --- a/Lib/mailbox.py Wed Sep 14 11:46:17 2011 -0400 +++ b/Lib/mailbox.py Wed Sep 14 17:12:51 2011 -0700 @@ -1467,8 +1467,7 @@ def _become_message(self, message): """Assume the non-format-specific state of message.""" - for name in ('_headers', '_unixfrom', '_payload', '_charset', - 'preamble', 'epilogue', 'defects', '_default_type'): + for name in message.__dict__: self.__dict__[name] = message.__dict__[name] |
|||
| msg144063 - (view) | Author: R. David Murray (r.david.murray) * (Python committer) | Date: 2011年09月15日 01:27 | |
That is the first step, yes. In addition to that we need to have the various explain_to methods delete the special attributes that aren't valid for the new Message subtype. |
|||
| msg144112 - (view) | Author: David Lam (dlam) * | Date: 2011年09月16日 01:42 | |
Hm, it seems right now that the only time that happens is when creating a message based on an mbox message. The 'status' and 'x-status' attributes are deleted. Any hints on what I could to do figure out what special attributes should be deleted? I was thinking I might try to find and go through the mailbox specs, and find out what headers are mandatory for each of them. I think I see some hints on... http://docs.python.org/library/mailbox.html#mailbox.mboxMessage. |
|||
| msg144169 - (view) | Author: R. David Murray (r.david.murray) * (Python committer) | Date: 2011年09月17日 00:59 | |
Unfortunately I don't think there is any way except going through each subclass to see what special attributes it creates. |
|||
| msg144265 - (view) | Author: David Lam (dlam) * | Date: 2011年09月19日 10:31 | |
This patch deletes the leftover special attributes. Thanks for guiding me through my confusion and/or cluelessness! |
|||
| msg157831 - (view) | Author: Roundup Robot (python-dev) (Python triager) | Date: 2012年04月09日 02:36 | |
New changeset 5c1c402a63e5 by R David Murray in branch 'default': #12537: in mailbox avoid depending on knowledge of email package internals http://hg.python.org/cpython/rev/5c1c402a63e5 |
|||
| msg157832 - (view) | Author: R. David Murray (r.david.murray) * (Python committer) | Date: 2012年04月09日 02:43 | |
David, thanks for your assistance. I didn't wind up using your patch, but the work you did was valuable in preparing the patch I committed. What I did was turn your 'detect the attributes' recipe into a unit test. I then applied your patch, but it didn't quite work. I eventually figured out that the fix I suggested wasn't quite right, that in fact the right place to delete the attributes is in _become_message. So I moved the list of attributes you developed in your patch into class attributes, so that what the final patch does is to copy everything *except* the attributes you found. So, a successful resolution, thank you. |
|||
| msg158112 - (view) | Author: David Lam (dlam) * | Date: 2012年04月12日 07:53 | |
Wow, cool! Thanks for the update. |
|||
| History | |||
|---|---|---|---|
| Date | User | Action | Args |
| 2022年04月11日 14:57:19 | admin | set | github: 56746 |
| 2012年04月12日 07:53:11 | dlam | set | messages: + msg158112 |
| 2012年04月09日 02:43:23 | r.david.murray | set | status: open -> closed type: behavior messages: + msg157832 resolution: fixed stage: resolved |
| 2012年04月09日 02:36:39 | python-dev | set | nosy:
+ python-dev messages: + msg157831 |
| 2011年09月19日 10:35:02 | dlam | set | files: + 12537.find.attribute.differences.patch |
| 2011年09月19日 10:31:27 | dlam | set | files:
+ 12537.patch keywords: + patch messages: + msg144265 |
| 2011年09月17日 00:59:52 | r.david.murray | set | messages: + msg144169 |
| 2011年09月16日 01:42:32 | dlam | set | messages: + msg144112 |
| 2011年09月15日 01:27:09 | r.david.murray | set | messages: + msg144063 |
| 2011年09月15日 00:29:48 | dlam | set | nosy:
+ dlam messages: + msg144061 |
| 2011年09月01日 20:13:26 | me | set | nosy:
+ me |
| 2011年08月28日 16:39:46 | kasun | set | nosy:
+ kasun |
| 2011年07月11日 21:11:23 | josemaria | set | nosy:
+ josemaria messages: + msg140163 |
| 2011年07月11日 18:50:18 | thomas.holmes | set | nosy:
+ thomas.holmes |
| 2011年07月11日 18:31:14 | r.david.murray | create | |