]> granicus.if.org Git - python/commitdiff
SHA_hexdigest(): A couple of small patches to this function, added
authorBarry Warsaw <barry@python.org>
Tue, 15 Aug 2000 06:03:35 +0000 (06:03 +0000)
committerBarry Warsaw <barry@python.org>
Tue, 15 Aug 2000 06:03:35 +0000 (06:03 +0000)
after a brief conversation with TP.  First, the return values of the
PyString_* function calls should be checked for errors.  Second,
bit-manipulations should be used instead of division for spliting the
byte up into its 4 bit digits.

Modules/shamodule.c

index 6f7a60de8775e36d4ff4fde6039280a1d00dad11..3761cf58ceb77a0b97ae8817e0ed483fb9ce58cd 100644 (file)
@@ -422,14 +422,22 @@ SHA_hexdigest(SHAobject *self, PyObject *args)
 
     /* Create a new string */
     retval = PyString_FromStringAndSize(NULL, sizeof(digest) * 2);
+    if (!retval)
+           return NULL;
     hex_digest = PyString_AsString(retval);
+    if (!hex_digest) {
+           Py_DECREF(retval);
+           return NULL;
+    }
 
     /* Make hex version of the digest */
     for(i=j=0; i<sizeof(digest); i++) {
         char c;
-        c = digest[i] / 16; c = (c>9) ? c+'a'-10 : c + '0';
+        c = (digest[i] >> 4) & 0xf;
+       c = (c>9) ? c+'a'-10 : c + '0';
         hex_digest[j++] = c;
-        c = digest[i] % 16; c = (c>9) ? c+'a'-10 : c + '0';
+        c = (digest[i] & 0xf);
+       c = (c>9) ? c+'a'-10 : c + '0';
         hex_digest[j++] = c;
     }
     return retval;