Skip to content

Commit b022394

Browse files
committed
Basic hash context implementation
1 parent b6be67a commit b022394

File tree

2 files changed

+50
-0
lines changed

2 files changed

+50
-0
lines changed

Classes/FCryptoContext.uc

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
/*
2+
* Copyright (c) 2024 Tuomo Kriikkula <tuokri@tuta.io>
3+
* Copyright (c) 2017 Thomas Pornin <pornin@bolet.org>
4+
*
5+
* Permission is hereby granted, free of charge, to any person obtaining
6+
* a copy of this software and associated documentation files (the
7+
* "Software"), to deal in the Software without restriction, including
8+
* without limitation the rights to use, copy, modify, merge, publish,
9+
* distribute, sublicense, and/or sell copies of the Software, and to
10+
* permit persons to whom the Software is furnished to do so, subject to
11+
* the following conditions:
12+
*
13+
* The above copyright notice and this permission notice shall be
14+
* included in all copies or substantial portions of the Software.
15+
*
16+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17+
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18+
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19+
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
20+
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
21+
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22+
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23+
* SOFTWARE.
24+
*/
25+
26+
class FCryptoContext extends Object
27+
abstract
28+
notplaceable;
29+
30+
struct FCryptoHashContext
31+
{
32+
var int Count; // TODO: might need to use QWORD for this.
33+
};
34+
35+
struct FCryptoSHA224Context extends FCryptoHashContext
36+
{
37+
};

Classes/FCryptoSHA2.uc

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -233,6 +233,19 @@ static final function Sha2SmallRound(
233233
Val[7] += h;
234234
}
235235

236+
static final function Sha2SmallUpdate(
237+
FCryptoSHA224Context Cc,
238+
const out array<byte> Data,
239+
int Len
240+
)
241+
{
242+
local int Ptr;
243+
244+
// TODO: can we simply use 32 bit integers here?
245+
// TODO: if not, use QWORDs?
246+
Ptr = Cc.Count & 63;
247+
}
248+
236249
// TODO: make this a macro for performance?
237250
static final function RangeDec32BE(
238251
out array<int> V,

0 commit comments

Comments
 (0)