I&#39;m going to guess that this is because we use a static instance of&nbsp;MD5CryptoServiceProvider to do the hashing, something which may not be thread-safe. &nbsp;It looks like all of the IronPython crypto implementations do the same thing, so the SHA functions may have a similar issue.<div>
<br></div><div>Please file this as a bug on Codeplex.<br><br><div class="gmail_quote">On Sat, Dec 20, 2008 at 1:56 PM, Brian Merrell <span dir="ltr">&lt;<a href="mailto:brian@merrells.org">brian@merrells.org</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;"><div><font face="Arial" size="2">I get the following error 
periodically:</font></div>
<blockquote dir="ltr" style="margin-right:0px">
<div><font face="Arial" size="2">Exception in thread Thread-2:<br>Traceback (most 
recent call last):<br>&nbsp; File &quot;C:\Program Files\IronPython 2.0\Lib\threading.py&quot;, 
line 486, in _Thread__bootstrap_inner<br>&nbsp;&nbsp;&nbsp; self.run()<br>&nbsp; File 
&quot;initial_ingest.py&quot;, line 33, in run<br>&nbsp;&nbsp;&nbsp; md5 = 
hashlib.md5(contents).hexdigest()<br>SystemError: Hash not valid for use in 
specified state.</font></div></blockquote>
<div dir="ltr"><font face="Arial" size="2">I am not sharing a md5() object between threads and have tried to avoid any shared memory issues:</font></div>
<div dir="ltr"><font face="Arial" size="2"></font>&nbsp;</div>
<blockquote dir="ltr" style="margin-right:0px">
<div dir="ltr"><font face="Arial" size="2">class Convert(threading.Thread):<br>&nbsp;&nbsp;&nbsp; def 
__init__(self, queue):<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; threading.Thread.__init__(self)<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
self.queue = queue<br>&nbsp;&nbsp;&nbsp; def run(self):<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; import hashlib<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
while True:<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; abs_filename = self.queue.get()<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; f = 
open(abs_filename, &quot;rb&quot;)<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; contents = f.read()<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
f.close()<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; md5 = hashlib.md5(contents).hexdigest()<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
print md5, abs_filename<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
self.queue.task_done()</font></div></blockquote>
<div dir="ltr"><font face="Arial" size="2">Any ideas why this is failing? &nbsp;Thanks,</font></div><div dir="ltr"><br></div><font color="#888888"><div dir="ltr">-brian</div>
</font><br>_______________________________________________<br>
Users mailing list<br>
<a href="mailto:Users@lists.ironpython.com">Users@lists.ironpython.com</a><br>
<a href="http://lists.ironpython.com/listinfo.cgi/users-ironpython.com" target="_blank">http://lists.ironpython.com/listinfo.cgi/users-ironpython.com</a><br>
<br></blockquote></div><br></div>