1/*[clinic input]
2preserve
3[clinic start generated code]*/
4
5PyDoc_STRVAR(SHA512Type_copy__doc__,
6"copy($self, /)\n"
7"--\n"
8"\n"
9"Return a copy of the hash object.");
10
11#define SHA512TYPE_COPY_METHODDEF \
12 {"copy", (PyCFunction)(void(*)(void))SHA512Type_copy, METH_METHOD|METH_FASTCALL|METH_KEYWORDS, SHA512Type_copy__doc__},
13
14static PyObject *
15SHA512Type_copy_impl(SHAobject *self, PyTypeObject *cls);
16
17static PyObject *
18SHA512Type_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 SHA512Type_copy_impl(self, cls);
25}
26
27PyDoc_STRVAR(SHA512Type_digest__doc__,
28"digest($self, /)\n"
29"--\n"
30"\n"
31"Return the digest value as a bytes object.");
32
33#define SHA512TYPE_DIGEST_METHODDEF \
34 {"digest", (PyCFunction)SHA512Type_digest, METH_NOARGS, SHA512Type_digest__doc__},
35
36static PyObject *
37SHA512Type_digest_impl(SHAobject *self);
38
39static PyObject *
40SHA512Type_digest(SHAobject *self, PyObject *Py_UNUSED(ignored))
41{
42 return SHA512Type_digest_impl(self);
43}
44
45PyDoc_STRVAR(SHA512Type_hexdigest__doc__,
46"hexdigest($self, /)\n"
47"--\n"
48"\n"
49"Return the digest value as a string of hexadecimal digits.");
50
51#define SHA512TYPE_HEXDIGEST_METHODDEF \
52 {"hexdigest", (PyCFunction)SHA512Type_hexdigest, METH_NOARGS, SHA512Type_hexdigest__doc__},
53
54static PyObject *
55SHA512Type_hexdigest_impl(SHAobject *self);
56
57static PyObject *
58SHA512Type_hexdigest(SHAobject *self, PyObject *Py_UNUSED(ignored))
59{
60 return SHA512Type_hexdigest_impl(self);
61}
62
63PyDoc_STRVAR(SHA512Type_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 SHA512TYPE_UPDATE_METHODDEF \
70 {"update", (PyCFunction)SHA512Type_update, METH_O, SHA512Type_update__doc__},
71
72PyDoc_STRVAR(_sha512_sha512__doc__,
73"sha512($module, /, string=b\'\', *, usedforsecurity=True)\n"
74"--\n"
75"\n"
76"Return a new SHA-512 hash object; optionally initialized with a string.");
77
78#define _SHA512_SHA512_METHODDEF \
79 {"sha512", (PyCFunction)(void(*)(void))_sha512_sha512, METH_FASTCALL|METH_KEYWORDS, _sha512_sha512__doc__},
80
81static PyObject *
82_sha512_sha512_impl(PyObject *module, PyObject *string, int usedforsecurity);
83
84static PyObject *
85_sha512_sha512(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, "sha512", 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 }
108skip_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 }
116skip_optional_kwonly:
117 return_value = _sha512_sha512_impl(module, string, usedforsecurity);
118
119exit:
120 return return_value;
121}
122
123PyDoc_STRVAR(_sha512_sha384__doc__,
124"sha384($module, /, string=b\'\', *, usedforsecurity=True)\n"
125"--\n"
126"\n"
127"Return a new SHA-384 hash object; optionally initialized with a string.");
128
129#define _SHA512_SHA384_METHODDEF \
130 {"sha384", (PyCFunction)(void(*)(void))_sha512_sha384, METH_FASTCALL|METH_KEYWORDS, _sha512_sha384__doc__},
131
132static PyObject *
133_sha512_sha384_impl(PyObject *module, PyObject *string, int usedforsecurity);
134
135static PyObject *
136_sha512_sha384(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, "sha384", 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 }
159skip_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 }
167skip_optional_kwonly:
168 return_value = _sha512_sha384_impl(module, string, usedforsecurity);
169
170exit:
171 return return_value;
172}
173/*[clinic end generated code: output=26d2fe27b9673ac2 input=a9049054013a1b77]*/
174