1 /*[clinic input]
2 preserve
3 [clinic start generated code]*/
4 
5 PyDoc_STRVAR(SHA256Type_copy__doc__,
6 "copy($self, /)\n"
7 "--\n"
8 "\n"
9 "Return a copy of the hash object.");
10 
11 #define SHA256TYPE_COPY_METHODDEF    \
12     {"copy", _PyCFunction_CAST(SHA256Type_copy), METH_METHOD|METH_FASTCALL|METH_KEYWORDS, SHA256Type_copy__doc__},
13 
14 static PyObject *
15 SHA256Type_copy_impl(SHAobject *self, PyTypeObject *cls);
16 
17 static PyObject *
SHA256Type_copy(SHAobject * self,PyTypeObject * cls,PyObject * const * args,Py_ssize_t nargs,PyObject * kwnames)18 SHA256Type_copy(SHAobject *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
19 {
20     if (nargs) {
21         PyErr_SetString(PyExc_TypeError, "copy() takes no arguments");
22         return NULL;
23     }
24     return SHA256Type_copy_impl(self, cls);
25 }
26 
27 PyDoc_STRVAR(SHA256Type_digest__doc__,
28 "digest($self, /)\n"
29 "--\n"
30 "\n"
31 "Return the digest value as a bytes object.");
32 
33 #define SHA256TYPE_DIGEST_METHODDEF    \
34     {"digest", (PyCFunction)SHA256Type_digest, METH_NOARGS, SHA256Type_digest__doc__},
35 
36 static PyObject *
37 SHA256Type_digest_impl(SHAobject *self);
38 
39 static PyObject *
SHA256Type_digest(SHAobject * self,PyObject * Py_UNUSED (ignored))40 SHA256Type_digest(SHAobject *self, PyObject *Py_UNUSED(ignored))
41 {
42     return SHA256Type_digest_impl(self);
43 }
44 
45 PyDoc_STRVAR(SHA256Type_hexdigest__doc__,
46 "hexdigest($self, /)\n"
47 "--\n"
48 "\n"
49 "Return the digest value as a string of hexadecimal digits.");
50 
51 #define SHA256TYPE_HEXDIGEST_METHODDEF    \
52     {"hexdigest", (PyCFunction)SHA256Type_hexdigest, METH_NOARGS, SHA256Type_hexdigest__doc__},
53 
54 static PyObject *
55 SHA256Type_hexdigest_impl(SHAobject *self);
56 
57 static PyObject *
SHA256Type_hexdigest(SHAobject * self,PyObject * Py_UNUSED (ignored))58 SHA256Type_hexdigest(SHAobject *self, PyObject *Py_UNUSED(ignored))
59 {
60     return SHA256Type_hexdigest_impl(self);
61 }
62 
63 PyDoc_STRVAR(SHA256Type_update__doc__,
64 "update($self, obj, /)\n"
65 "--\n"
66 "\n"
67 "Update this hash object\'s state with the provided string.");
68 
69 #define SHA256TYPE_UPDATE_METHODDEF    \
70     {"update", (PyCFunction)SHA256Type_update, METH_O, SHA256Type_update__doc__},
71 
72 PyDoc_STRVAR(_sha256_sha256__doc__,
73 "sha256($module, /, string=b\'\', *, usedforsecurity=True)\n"
74 "--\n"
75 "\n"
76 "Return a new SHA-256 hash object; optionally initialized with a string.");
77 
78 #define _SHA256_SHA256_METHODDEF    \
79     {"sha256", _PyCFunction_CAST(_sha256_sha256), METH_FASTCALL|METH_KEYWORDS, _sha256_sha256__doc__},
80 
81 static PyObject *
82 _sha256_sha256_impl(PyObject *module, PyObject *string, int usedforsecurity);
83 
84 static PyObject *
_sha256_sha256(PyObject * module,PyObject * const * args,Py_ssize_t nargs,PyObject * kwnames)85 _sha256_sha256(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
86 {
87     PyObject *return_value = NULL;
88     static const char * const _keywords[] = {"string", "usedforsecurity", NULL};
89     static _PyArg_Parser _parser = {NULL, _keywords, "sha256", 0};
90     PyObject *argsbuf[2];
91     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0;
92     PyObject *string = NULL;
93     int usedforsecurity = 1;
94 
95     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 1, 0, argsbuf);
96     if (!args) {
97         goto exit;
98     }
99     if (!noptargs) {
100         goto skip_optional_pos;
101     }
102     if (args[0]) {
103         string = args[0];
104         if (!--noptargs) {
105             goto skip_optional_pos;
106         }
107     }
108 skip_optional_pos:
109     if (!noptargs) {
110         goto skip_optional_kwonly;
111     }
112     usedforsecurity = PyObject_IsTrue(args[1]);
113     if (usedforsecurity < 0) {
114         goto exit;
115     }
116 skip_optional_kwonly:
117     return_value = _sha256_sha256_impl(module, string, usedforsecurity);
118 
119 exit:
120     return return_value;
121 }
122 
123 PyDoc_STRVAR(_sha256_sha224__doc__,
124 "sha224($module, /, string=b\'\', *, usedforsecurity=True)\n"
125 "--\n"
126 "\n"
127 "Return a new SHA-224 hash object; optionally initialized with a string.");
128 
129 #define _SHA256_SHA224_METHODDEF    \
130     {"sha224", _PyCFunction_CAST(_sha256_sha224), METH_FASTCALL|METH_KEYWORDS, _sha256_sha224__doc__},
131 
132 static PyObject *
133 _sha256_sha224_impl(PyObject *module, PyObject *string, int usedforsecurity);
134 
135 static PyObject *
_sha256_sha224(PyObject * module,PyObject * const * args,Py_ssize_t nargs,PyObject * kwnames)136 _sha256_sha224(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
137 {
138     PyObject *return_value = NULL;
139     static const char * const _keywords[] = {"string", "usedforsecurity", NULL};
140     static _PyArg_Parser _parser = {NULL, _keywords, "sha224", 0};
141     PyObject *argsbuf[2];
142     Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0;
143     PyObject *string = NULL;
144     int usedforsecurity = 1;
145 
146     args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 1, 0, argsbuf);
147     if (!args) {
148         goto exit;
149     }
150     if (!noptargs) {
151         goto skip_optional_pos;
152     }
153     if (args[0]) {
154         string = args[0];
155         if (!--noptargs) {
156             goto skip_optional_pos;
157         }
158     }
159 skip_optional_pos:
160     if (!noptargs) {
161         goto skip_optional_kwonly;
162     }
163     usedforsecurity = PyObject_IsTrue(args[1]);
164     if (usedforsecurity < 0) {
165         goto exit;
166     }
167 skip_optional_kwonly:
168     return_value = _sha256_sha224_impl(module, string, usedforsecurity);
169 
170 exit:
171     return return_value;
172 }
173 /*[clinic end generated code: output=58b48051890d3fde input=a9049054013a1b77]*/
174