1 /* Generated by Nim Compiler v1.6.2 */
2 #define NIM_INTBITS 32
3 
4 #include "nimbase.h"
5 #include <string.h>
6 #include <stdio.h>
7 #undef LANGUAGE_C
8 #undef MIPSEB
9 #undef MIPSEL
10 #undef PPC
11 #undef R3000
12 #undef R4000
13 #undef i386
14 #undef linux
15 #undef mips
16 #undef near
17 #undef far
18 #undef powerpc
19 #undef unix
20 #define nimfr_(x, y)
21 #define nimln_(x, y)
22 typedef struct NimStringDesc NimStringDesc;
23 typedef struct TGenericSeq TGenericSeq;
24 typedef struct tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow;
25 struct TGenericSeq {
26 NI len;
27 NI reserved;
28 };
29 struct NimStringDesc {
30   TGenericSeq Sup;
31 NIM_CHAR data[SEQ_DECL_SIZE];
32 };
33 typedef NU8 tySet_tyChar__nmiMWKVIe46vacnhAFrQvw[32];
34 typedef NU8 tyArray__YtcvxHNKV4YiecPE9ap1mcA[20];
35 typedef NU32 tyArray__xsE8WL1yT5DKfrMdYB89bYA[5];
36 typedef NU8 tyArray__w5VB8h5K8DB3oWrO5U2wqg[64];
37 struct tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow {
38 NI count;
39 tyArray__xsE8WL1yT5DKfrMdYB89bYA state;
40 tyArray__w5VB8h5K8DB3oWrO5U2wqg buf;
41 };
42 typedef NU32 tyArray__BhDmUZcWSpYFIy5J8Xi8mQ[80];
43 typedef NIM_CHAR tyArray__1NlJ8ipZDU6GZ9bDFAyQjfQ[8];
44 typedef NU8 tyEnum_FileMode__ZJfK20XeZ9bv2j1pZjw9aswg;
45 N_LIB_PRIVATE N_NIMCALL(NIM_BOOL, allCharsInSet__pureZstrutils_1341)(NimStringDesc* s, tySet_tyChar__nmiMWKVIe46vacnhAFrQvw theSet);
46 static N_INLINE(void, nimZeroMem)(void* p, NI size);
47 static N_INLINE(void, nimSetMem__systemZmemory_7)(void* a, int v, NI size);
48 N_LIB_PRIVATE N_NIMCALL(void, newSha1State__stdZsha49_10)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* Result);
49 N_LIB_PRIVATE N_NIMCALL(void, update__stdZsha49_777)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* ctx, NIM_CHAR* data, NI dataLen_0);
50 static N_INLINE(void, copyMem__system_1727)(void* dest, void* source, NI size);
51 static N_INLINE(void, nimCopyMem)(void* dest, void* source, NI size);
52 N_LIB_PRIVATE N_NIMCALL(void, transform__stdZsha49_27)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* ctx);
53 static N_INLINE(void, bigEndian32__pureZendians_65)(void* outp, void* inp);
54 static N_INLINE(void, swapEndian32__pureZendians_25)(void* outp, void* inp);
55 N_LIB_PRIVATE N_NIMCALL(void, finalize__stdZsha49_821)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* ctx, tyArray__YtcvxHNKV4YiecPE9ap1mcA Result);
56 static N_INLINE(void, bigEndian64__pureZendians_62)(void* outp, void* inp);
57 static N_INLINE(void, swapEndian64__pureZendians_13)(void* outp, void* inp);
58 N_LIB_PRIVATE N_NIMCALL(NimStringDesc*, toHex__pureZstrutils_1792)(NI x, NI len);
59 static N_INLINE(void, appendString)(NimStringDesc* dest, NimStringDesc* src);
60 N_LIB_PRIVATE N_NIMCALL(NimStringDesc*, resizeString)(NimStringDesc* dest, NI addlen);
61 N_LIB_PRIVATE N_NIMCALL(FILE*, open__systemZio_518)(NimStringDesc* filename, tyEnum_FileMode__ZJfK20XeZ9bv2j1pZjw9aswg mode, NI bufSize);
62 N_NIMCALL(NimStringDesc*, mnewString)(NI len);
63 N_LIB_PRIVATE N_NIMCALL(NI, readChars__systemZio_156)(FILE* f, NIM_CHAR* a, NI aLen_0);
64 N_LIB_PRIVATE N_NIMCALL(NimStringDesc*, setLengthStr)(NimStringDesc* s, NI newLen);
65 N_LIB_PRIVATE N_NIMCALL(void, close__systemZio_237)(FILE* f);
66 N_LIB_PRIVATE N_NIMCALL(NI, nsuParseHexInt)(NimStringDesc* s);
67 static N_INLINE(void, appendChar)(NimStringDesc* dest, NIM_CHAR c);
68 N_LIB_PRIVATE N_NIMCALL(NimStringDesc*, rawNewString)(NI space);
69 N_LIB_PRIVATE N_NIMCALL(NIM_BOOL, eqeq___stdZsha49_924)(tyArray__YtcvxHNKV4YiecPE9ap1mcA x, tyArray__YtcvxHNKV4YiecPE9ap1mcA y);
70 static NIM_CONST tySet_tyChar__nmiMWKVIe46vacnhAFrQvw TM__SpWH4VocI3fFoiOGE4MzWw_2 = {
71 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0x03,
72 0x7e, 0x00, 0x00, 0x00, 0x7e, 0x00, 0x00, 0x00,
73 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
74 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}
75 ;
76 STRING_LITERAL(TM__SpWH4VocI3fFoiOGE4MzWw_3, "\200", 1);
77 STRING_LITERAL(TM__SpWH4VocI3fFoiOGE4MzWw_4, "\000", 1);
N_NIMCALL(NIM_BOOL,isValidSha1Hash__stdZsha49_949)78 N_LIB_PRIVATE N_NIMCALL(NIM_BOOL, isValidSha1Hash__stdZsha49_949)(NimStringDesc* s) {
79 	NIM_BOOL result;
80 	NIM_BOOL T1_;
81 	result = (NIM_BOOL)0;
82 	T1_ = (NIM_BOOL)0;
83 	T1_ = ((s ? s->Sup.len : 0) == ((NI) 40));
84 	if (!(T1_)) goto LA2_;
85 	T1_ = allCharsInSet__pureZstrutils_1341(s, TM__SpWH4VocI3fFoiOGE4MzWw_2);
86 	LA2_: ;
87 	result = T1_;
88 	return result;
89 }
N_INLINE(void,nimSetMem__systemZmemory_7)90 static N_INLINE(void, nimSetMem__systemZmemory_7)(void* a, int v, NI size) {
91 	void* T1_;
92 	T1_ = (void*)0;
93 	T1_ = memset(a, v, ((size_t) (size)));
94 }
N_INLINE(void,nimZeroMem)95 static N_INLINE(void, nimZeroMem)(void* p, NI size) {
96 	nimSetMem__systemZmemory_7(p, ((int) 0), size);
97 }
N_NIMCALL(void,newSha1State__stdZsha49_10)98 N_LIB_PRIVATE N_NIMCALL(void, newSha1State__stdZsha49_10)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* Result) {
99 	nimZeroMem((void*)Result, sizeof(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow));
100 	(*Result).count = ((NI) 0);
101 	(*Result).state[(((NI) 0))- 0] = ((NU32) 1732584193);
102 	(*Result).state[(((NI) 1))- 0] = ((NU32) IL64(4023233417));
103 	(*Result).state[(((NI) 2))- 0] = ((NU32) IL64(2562383102));
104 	(*Result).state[(((NI) 3))- 0] = ((NU32) 271733878);
105 	(*Result).state[(((NI) 4))- 0] = ((NU32) IL64(3285377520));
106 }
N_INLINE(void,nimCopyMem)107 static N_INLINE(void, nimCopyMem)(void* dest, void* source, NI size) {
108 	void* T1_;
109 	T1_ = (void*)0;
110 	T1_ = memcpy(dest, source, ((size_t) (size)));
111 }
N_INLINE(void,copyMem__system_1727)112 static N_INLINE(void, copyMem__system_1727)(void* dest, void* source, NI size) {
113 	nimCopyMem(dest, source, size);
114 }
N_INLINE(void,swapEndian32__pureZendians_25)115 static N_INLINE(void, swapEndian32__pureZendians_25)(void* outp, void* inp) {
116 	NU32 tmpX60gensym1_;
117 	tmpX60gensym1_ = (NU32)0;
118 	copyMem__system_1727(((void*) ((&tmpX60gensym1_))), inp, ((NI) 4));
119 	tmpX60gensym1_ = __builtin_bswap32(tmpX60gensym1_);
120 	copyMem__system_1727(outp, ((void*) ((&tmpX60gensym1_))), ((NI) 4));
121 }
N_INLINE(void,bigEndian32__pureZendians_65)122 static N_INLINE(void, bigEndian32__pureZendians_65)(void* outp, void* inp) {
123 	swapEndian32__pureZendians_25(outp, inp);
124 }
N_NIMCALL(void,transform__stdZsha49_27)125 N_LIB_PRIVATE N_NIMCALL(void, transform__stdZsha49_27)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* ctx) {
126 	tyArray__BhDmUZcWSpYFIy5J8Xi8mQ w;
127 	NU32 a;
128 	NU32 b;
129 	NU32 c;
130 	NU32 d;
131 	NU32 e;
132 	NI t;
133 	nimZeroMem((void*)w, sizeof(tyArray__BhDmUZcWSpYFIy5J8Xi8mQ));
134 	a = (NU32)0;
135 	b = (NU32)0;
136 	c = (NU32)0;
137 	d = (NU32)0;
138 	e = (NU32)0;
139 	t = ((NI) 0);
140 	a = (*ctx).state[(((NI) 0))- 0];
141 	b = (*ctx).state[(((NI) 1))- 0];
142 	c = (*ctx).state[(((NI) 2))- 0];
143 	d = (*ctx).state[(((NI) 3))- 0];
144 	e = (*ctx).state[(((NI) 4))- 0];
145 	{
146 		while (1) {
147 			if (!(t < ((NI) 15))) goto LA2;
148 			bigEndian32__pureZendians_65(((void*) ((&w[((NI)(t + ((NI) 0)))- 0]))), ((void*) ((&(*ctx).buf[((NI)((NI)(t + ((NI) 0)) * ((NI) 4)))- 0]))));
149 			e += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 27))) | (NU32)((NU32)(a) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 0)))- 0]))) + (NU32)((NU32)(d ^ (NU32)(b & (NU32)(c ^ d)))))) + (NU32)(((NU32) 1518500249)));
150 			b = (NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 2))) | (NU32)((NU32)(b) << (NU32)(((NI) 30))));
151 			bigEndian32__pureZendians_65(((void*) ((&w[((NI)(t + ((NI) 1)))- 0]))), ((void*) ((&(*ctx).buf[((NI)((NI)(t + ((NI) 1)) * ((NI) 4)))- 0]))));
152 			d += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 27))) | (NU32)((NU32)(e) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 1)))- 0]))) + (NU32)((NU32)(c ^ (NU32)(a & (NU32)(b ^ c)))))) + (NU32)(((NU32) 1518500249)));
153 			a = (NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 2))) | (NU32)((NU32)(a) << (NU32)(((NI) 30))));
154 			bigEndian32__pureZendians_65(((void*) ((&w[((NI)(t + ((NI) 2)))- 0]))), ((void*) ((&(*ctx).buf[((NI)((NI)(t + ((NI) 2)) * ((NI) 4)))- 0]))));
155 			c += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 27))) | (NU32)((NU32)(d) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 2)))- 0]))) + (NU32)((NU32)(b ^ (NU32)(e & (NU32)(a ^ b)))))) + (NU32)(((NU32) 1518500249)));
156 			e = (NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 2))) | (NU32)((NU32)(e) << (NU32)(((NI) 30))));
157 			bigEndian32__pureZendians_65(((void*) ((&w[((NI)(t + ((NI) 3)))- 0]))), ((void*) ((&(*ctx).buf[((NI)((NI)(t + ((NI) 3)) * ((NI) 4)))- 0]))));
158 			b += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 27))) | (NU32)((NU32)(c) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 3)))- 0]))) + (NU32)((NU32)(a ^ (NU32)(d & (NU32)(e ^ a)))))) + (NU32)(((NU32) 1518500249)));
159 			d = (NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 2))) | (NU32)((NU32)(d) << (NU32)(((NI) 30))));
160 			bigEndian32__pureZendians_65(((void*) ((&w[((NI)(t + ((NI) 4)))- 0]))), ((void*) ((&(*ctx).buf[((NI)((NI)(t + ((NI) 4)) * ((NI) 4)))- 0]))));
161 			a += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 27))) | (NU32)((NU32)(b) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 4)))- 0]))) + (NU32)((NU32)(e ^ (NU32)(c & (NU32)(d ^ e)))))) + (NU32)(((NU32) 1518500249)));
162 			c = (NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 2))) | (NU32)((NU32)(c) << (NU32)(((NI) 30))));
163 			t += ((NI) 5);
164 		} LA2: ;
165 	}
166 	bigEndian32__pureZendians_65(((void*) ((&w[((NI)(t + ((NI) 0)))- 0]))), ((void*) ((&(*ctx).buf[((NI)((NI)(t + ((NI) 0)) * ((NI) 4)))- 0]))));
167 	e += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 27))) | (NU32)((NU32)(a) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 0)))- 0]))) + (NU32)((NU32)(d ^ (NU32)(b & (NU32)(c ^ d)))))) + (NU32)(((NU32) 1518500249)));
168 	b = (NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 2))) | (NU32)((NU32)(b) << (NU32)(((NI) 30))));
169 	w[((NI)(t + ((NI) 1)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
170 	d += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 27))) | (NU32)((NU32)(e) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 1)))- 0]))) + (NU32)((NU32)(c ^ (NU32)(a & (NU32)(b ^ c)))))) + (NU32)(((NU32) 1518500249)));
171 	a = (NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 2))) | (NU32)((NU32)(a) << (NU32)(((NI) 30))));
172 	w[((NI)(t + ((NI) 2)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
173 	c += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 27))) | (NU32)((NU32)(d) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 2)))- 0]))) + (NU32)((NU32)(b ^ (NU32)(e & (NU32)(a ^ b)))))) + (NU32)(((NU32) 1518500249)));
174 	e = (NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 2))) | (NU32)((NU32)(e) << (NU32)(((NI) 30))));
175 	w[((NI)(t + ((NI) 3)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
176 	b += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 27))) | (NU32)((NU32)(c) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 3)))- 0]))) + (NU32)((NU32)(a ^ (NU32)(d & (NU32)(e ^ a)))))) + (NU32)(((NU32) 1518500249)));
177 	d = (NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 2))) | (NU32)((NU32)(d) << (NU32)(((NI) 30))));
178 	w[((NI)(t + ((NI) 4)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
179 	a += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 27))) | (NU32)((NU32)(b) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 4)))- 0]))) + (NU32)((NU32)(e ^ (NU32)(c & (NU32)(d ^ e)))))) + (NU32)(((NU32) 1518500249)));
180 	c = (NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 2))) | (NU32)((NU32)(c) << (NU32)(((NI) 30))));
181 	t = ((NI) 20);
182 	{
183 		while (1) {
184 			if (!(t < ((NI) 40))) goto LA4;
185 			w[((NI)(t + ((NI) 0)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 0)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 0)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
186 			e += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 27))) | (NU32)((NU32)(a) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 0)))- 0]))) + (NU32)((NU32)((NU32)(b ^ c) ^ d)))) + (NU32)(((NU32) 1859775393)));
187 			b = (NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 2))) | (NU32)((NU32)(b) << (NU32)(((NI) 30))));
188 			w[((NI)(t + ((NI) 1)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
189 			d += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 27))) | (NU32)((NU32)(e) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 1)))- 0]))) + (NU32)((NU32)((NU32)(a ^ b) ^ c)))) + (NU32)(((NU32) 1859775393)));
190 			a = (NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 2))) | (NU32)((NU32)(a) << (NU32)(((NI) 30))));
191 			w[((NI)(t + ((NI) 2)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
192 			c += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 27))) | (NU32)((NU32)(d) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 2)))- 0]))) + (NU32)((NU32)((NU32)(e ^ a) ^ b)))) + (NU32)(((NU32) 1859775393)));
193 			e = (NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 2))) | (NU32)((NU32)(e) << (NU32)(((NI) 30))));
194 			w[((NI)(t + ((NI) 3)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
195 			b += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 27))) | (NU32)((NU32)(c) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 3)))- 0]))) + (NU32)((NU32)((NU32)(d ^ e) ^ a)))) + (NU32)(((NU32) 1859775393)));
196 			d = (NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 2))) | (NU32)((NU32)(d) << (NU32)(((NI) 30))));
197 			w[((NI)(t + ((NI) 4)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
198 			a += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 27))) | (NU32)((NU32)(b) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 4)))- 0]))) + (NU32)((NU32)((NU32)(c ^ d) ^ e)))) + (NU32)(((NU32) 1859775393)));
199 			c = (NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 2))) | (NU32)((NU32)(c) << (NU32)(((NI) 30))));
200 			t += ((NI) 5);
201 		} LA4: ;
202 	}
203 	{
204 		while (1) {
205 			if (!(t < ((NI) 60))) goto LA6;
206 			w[((NI)(t + ((NI) 0)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 0)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 0)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
207 			e += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 27))) | (NU32)((NU32)(a) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 0)))- 0]))) + (NU32)((NU32)((NU32)(b & c) | (NU32)(d & (NU32)(b | c)))))) + (NU32)(((NU32) IL64(2400959708))));
208 			b = (NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 2))) | (NU32)((NU32)(b) << (NU32)(((NI) 30))));
209 			w[((NI)(t + ((NI) 1)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
210 			d += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 27))) | (NU32)((NU32)(e) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 1)))- 0]))) + (NU32)((NU32)((NU32)(a & b) | (NU32)(c & (NU32)(a | b)))))) + (NU32)(((NU32) IL64(2400959708))));
211 			a = (NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 2))) | (NU32)((NU32)(a) << (NU32)(((NI) 30))));
212 			w[((NI)(t + ((NI) 2)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
213 			c += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 27))) | (NU32)((NU32)(d) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 2)))- 0]))) + (NU32)((NU32)((NU32)(e & a) | (NU32)(b & (NU32)(e | a)))))) + (NU32)(((NU32) IL64(2400959708))));
214 			e = (NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 2))) | (NU32)((NU32)(e) << (NU32)(((NI) 30))));
215 			w[((NI)(t + ((NI) 3)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
216 			b += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 27))) | (NU32)((NU32)(c) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 3)))- 0]))) + (NU32)((NU32)((NU32)(d & e) | (NU32)(a & (NU32)(d | e)))))) + (NU32)(((NU32) IL64(2400959708))));
217 			d = (NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 2))) | (NU32)((NU32)(d) << (NU32)(((NI) 30))));
218 			w[((NI)(t + ((NI) 4)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
219 			a += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 27))) | (NU32)((NU32)(b) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 4)))- 0]))) + (NU32)((NU32)((NU32)(c & d) | (NU32)(e & (NU32)(c | d)))))) + (NU32)(((NU32) IL64(2400959708))));
220 			c = (NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 2))) | (NU32)((NU32)(c) << (NU32)(((NI) 30))));
221 			t += ((NI) 5);
222 		} LA6: ;
223 	}
224 	{
225 		while (1) {
226 			if (!(t < ((NI) 80))) goto LA8;
227 			w[((NI)(t + ((NI) 0)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 0)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 0)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 0)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
228 			e += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 27))) | (NU32)((NU32)(a) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 0)))- 0]))) + (NU32)((NU32)((NU32)(b ^ c) ^ d)))) + (NU32)(((NU32) IL64(3395469782))));
229 			b = (NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 2))) | (NU32)((NU32)(b) << (NU32)(((NI) 30))));
230 			w[((NI)(t + ((NI) 1)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 1)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 1)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
231 			d += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 27))) | (NU32)((NU32)(e) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 1)))- 0]))) + (NU32)((NU32)((NU32)(a ^ b) ^ c)))) + (NU32)(((NU32) IL64(3395469782))));
232 			a = (NU32)((NU32)((NU32)(a) >> (NU32)(((NI) 2))) | (NU32)((NU32)(a) << (NU32)(((NI) 30))));
233 			w[((NI)(t + ((NI) 2)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 2)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 2)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
234 			c += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 27))) | (NU32)((NU32)(d) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 2)))- 0]))) + (NU32)((NU32)((NU32)(e ^ a) ^ b)))) + (NU32)(((NU32) IL64(3395469782))));
235 			e = (NU32)((NU32)((NU32)(e) >> (NU32)(((NI) 2))) | (NU32)((NU32)(e) << (NU32)(((NI) 30))));
236 			w[((NI)(t + ((NI) 3)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 3)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 3)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
237 			b += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 27))) | (NU32)((NU32)(c) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 3)))- 0]))) + (NU32)((NU32)((NU32)(d ^ e) ^ a)))) + (NU32)(((NU32) IL64(3395469782))));
238 			d = (NU32)((NU32)((NU32)(d) >> (NU32)(((NI) 2))) | (NU32)((NU32)(d) << (NU32)(((NI) 30))));
239 			w[((NI)(t + ((NI) 4)))- 0] = (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) >> (NU32)(((NI) 31))) | (NU32)((NU32)((NU32)((NU32)((NU32)(w[((NI)((NI)(t + ((NI) 4)) - ((NI) 3)))- 0] ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 8)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 14)))- 0]) ^ w[((NI)((NI)(t + ((NI) 4)) - ((NI) 16)))- 0])) << (NU32)(((NI) 1))));
240 			a += (NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)((NU32)(b) >> (NU32)(((NI) 27))) | (NU32)((NU32)(b) << (NU32)(((NI) 5))))) + (NU32)(w[((NI)(t + ((NI) 4)))- 0]))) + (NU32)((NU32)((NU32)(c ^ d) ^ e)))) + (NU32)(((NU32) IL64(3395469782))));
241 			c = (NU32)((NU32)((NU32)(c) >> (NU32)(((NI) 2))) | (NU32)((NU32)(c) << (NU32)(((NI) 30))));
242 			t += ((NI) 5);
243 		} LA8: ;
244 	}
245 	(*ctx).state[(((NI) 0))- 0] += a;
246 	(*ctx).state[(((NI) 1))- 0] += b;
247 	(*ctx).state[(((NI) 2))- 0] += c;
248 	(*ctx).state[(((NI) 3))- 0] += d;
249 	(*ctx).state[(((NI) 4))- 0] += e;
250 }
N_NIMCALL(void,update__stdZsha49_777)251 N_LIB_PRIVATE N_NIMCALL(void, update__stdZsha49_777)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* ctx, NIM_CHAR* data, NI dataLen_0) {
252 	NI i;
253 	NI j;
254 	NI len;
255 	i = (NI)((*ctx).count % ((NI) 64));
256 	j = ((NI) 0);
257 	len = dataLen_0;
258 	{
259 		if (!((NI)(((NI) 64) - i) < len)) goto LA3_;
260 		copyMem__system_1727(((void*) ((&(*ctx).buf[(i)- 0]))), ((void*) ((&data[j]))), ((NI) ((NI)(((NI) 64) - i))));
261 		len -= (NI)(((NI) 64) - i);
262 		j += (NI)(((NI) 64) - i);
263 		transform__stdZsha49_27(ctx);
264 		i = ((NI) 0);
265 	}
266 	LA3_: ;
267 	{
268 		while (1) {
269 			if (!(((NI) 64) <= len)) goto LA6;
270 			copyMem__system_1727(((void*) ((&(*ctx).buf[(((NI) 0))- 0]))), ((void*) ((&data[j]))), ((NI) 64));
271 			len -= ((NI) 64);
272 			j += ((NI) 64);
273 			transform__stdZsha49_27(ctx);
274 		} LA6: ;
275 	}
276 	{
277 		while (1) {
278 			if (!(((NI) 0) < len)) goto LA8;
279 			len -= ((NI) 1);
280 			(*ctx).buf[(i)- 0] = ((NU8) (((NU8)(data[j]))));
281 			i += ((NI) 1);
282 			j += ((NI) 1);
283 			{
284 				if (!(i == ((NI) 64))) goto LA11_;
285 				transform__stdZsha49_27(ctx);
286 				i = ((NI) 0);
287 			}
288 			LA11_: ;
289 		} LA8: ;
290 	}
291 	(*ctx).count += dataLen_0;
292 }
N_INLINE(void,swapEndian64__pureZendians_13)293 static N_INLINE(void, swapEndian64__pureZendians_13)(void* outp, void* inp) {
294 	NU64 tmpX60gensym0_;
295 	tmpX60gensym0_ = (NU64)0;
296 	copyMem__system_1727(((void*) ((&tmpX60gensym0_))), inp, ((NI) 8));
297 	tmpX60gensym0_ = __builtin_bswap64(tmpX60gensym0_);
298 	copyMem__system_1727(outp, ((void*) ((&tmpX60gensym0_))), ((NI) 8));
299 }
N_INLINE(void,bigEndian64__pureZendians_62)300 static N_INLINE(void, bigEndian64__pureZendians_62)(void* outp, void* inp) {
301 	swapEndian64__pureZendians_13(outp, inp);
302 }
N_NIMCALL(void,finalize__stdZsha49_821)303 N_LIB_PRIVATE N_NIMCALL(void, finalize__stdZsha49_821)(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow* ctx, tyArray__YtcvxHNKV4YiecPE9ap1mcA Result) {
304 	NU64 cnt;
305 	tyArray__1NlJ8ipZDU6GZ9bDFAyQjfQ tmp;
306 	nimZeroMem((void*)Result, sizeof(tyArray__YtcvxHNKV4YiecPE9ap1mcA));
307 	cnt = ((NU64) ((NI)((*ctx).count * ((NI) 8))));
308 	update__stdZsha49_777(ctx, ((NimStringDesc*) &TM__SpWH4VocI3fFoiOGE4MzWw_3)->data, (((NimStringDesc*) &TM__SpWH4VocI3fFoiOGE4MzWw_3) ? ((NimStringDesc*) &TM__SpWH4VocI3fFoiOGE4MzWw_3)->Sup.len : 0));
309 	{
310 		while (1) {
311 			if (!!(((NI)((*ctx).count % ((NI) 64)) == ((NI) 56)))) goto LA2;
312 			update__stdZsha49_777(ctx, ((NimStringDesc*) &TM__SpWH4VocI3fFoiOGE4MzWw_4)->data, (((NimStringDesc*) &TM__SpWH4VocI3fFoiOGE4MzWw_4) ? ((NimStringDesc*) &TM__SpWH4VocI3fFoiOGE4MzWw_4)->Sup.len : 0));
313 		} LA2: ;
314 	}
315 	nimZeroMem((void*)tmp, sizeof(tyArray__1NlJ8ipZDU6GZ9bDFAyQjfQ));
316 	bigEndian64__pureZendians_62(((void*) ((&tmp[(((NI) 0))- 0]))), ((void*) ((&cnt))));
317 	update__stdZsha49_777(ctx, tmp, 8);
318 	{
319 		NI i;
320 		NI i_2;
321 		i = (NI)0;
322 		i_2 = ((NI) 0);
323 		{
324 			while (1) {
325 				if (!(i_2 < ((NI) 5))) goto LA5;
326 				i = i_2;
327 				bigEndian32__pureZendians_65(((void*) ((&(*ctx).state[(i)- 0]))), ((void*) ((&(*ctx).state[(i)- 0]))));
328 				i_2 += ((NI) 1);
329 			} LA5: ;
330 		}
331 	}
332 	copyMem__system_1727(((void*) ((&Result[(((NI) 0))- 0]))), ((void*) ((&(*ctx).state[(((NI) 0))- 0]))), ((NI) 20));
333 }
N_NIMCALL(void,secureHash__stdZsha49_840)334 N_LIB_PRIVATE N_NIMCALL(void, secureHash__stdZsha49_840)(NIM_CHAR* str, NI strLen_0, tyArray__YtcvxHNKV4YiecPE9ap1mcA Result) {
335 	tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow state;
336 	nimZeroMem((void*)(&state), sizeof(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow));
337 	newSha1State__stdZsha49_10((&state));
338 	update__stdZsha49_777((&state), str, strLen_0);
339 	finalize__stdZsha49_821((&state), Result);
340 }
N_INLINE(void,appendString)341 static N_INLINE(void, appendString)(NimStringDesc* dest, NimStringDesc* src) {
342 	{
343 		if (!!((src == ((NimStringDesc*) NIM_NIL)))) goto LA3_;
344 		copyMem__system_1727(((void*) ((&(*dest).data[(*dest).Sup.len]))), ((void*) ((*src).data)), ((NI) ((NI)((*src).Sup.len + ((NI) 1)))));
345 		(*dest).Sup.len += (*src).Sup.len;
346 	}
347 	LA3_: ;
348 }
N_NIMCALL(NimStringDesc *,dollar___stdZsha49_879)349 N_LIB_PRIVATE N_NIMCALL(NimStringDesc*, dollar___stdZsha49_879)(tyArray__YtcvxHNKV4YiecPE9ap1mcA self) {
350 	NimStringDesc* result;
351 	result = NIM_NIL;
352 	result = ((NimStringDesc*) NIM_NIL);
353 	{
354 		NU8 v;
355 		tyArray__YtcvxHNKV4YiecPE9ap1mcA colontmp_;
356 		NI i;
357 		v = (NU8)0;
358 		nimZeroMem((void*)colontmp_, sizeof(tyArray__YtcvxHNKV4YiecPE9ap1mcA));
359 		nimCopyMem((void*)colontmp_, (NIM_CONST void*)self, sizeof(tyArray__YtcvxHNKV4YiecPE9ap1mcA));
360 		i = ((NI) 0);
361 		{
362 			while (1) {
363 				NimStringDesc* T4_;
364 				v = colontmp_[(i)- 0];
365 				T4_ = NIM_NIL;
366 				T4_ = toHex__pureZstrutils_1792(((NI) (v)), ((NI) 2));
367 				result = resizeString(result, (T4_ ? T4_->Sup.len : 0) + 0);
368 appendString(result, T4_);
369 				{
370 					if (!(((NI) 19) <= ((NI) (i)))) goto LA7_;
371 					goto LA2;
372 				}
373 				LA7_: ;
374 				i += ((NI) 1);
375 			}
376 		} LA2: ;
377 	}
378 	return result;
379 }
N_NIMCALL(void,secureHashFile__stdZsha49_871)380 N_LIB_PRIVATE N_NIMCALL(void, secureHashFile__stdZsha49_871)(NimStringDesc* filename, tyArray__YtcvxHNKV4YiecPE9ap1mcA Result) {
381 	FILE* f;
382 	tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow state;
383 	NimStringDesc* buffer;
384 	f = open__systemZio_518(filename, ((tyEnum_FileMode__ZJfK20XeZ9bv2j1pZjw9aswg) 0), ((NI) -1));
385 	nimZeroMem((void*)(&state), sizeof(tyObject_Sha1State__cBZm1tX9aK4Wngq1jVLZUow));
386 	newSha1State__stdZsha49_10((&state));
387 	buffer = mnewString(((NI) 8192));
388 	{
389 		while (1) {
390 			NI length;
391 			length = readChars__systemZio_156(f, buffer->data, (buffer ? buffer->Sup.len : 0));
392 			{
393 				if (!(length == ((NI) 0))) goto LA5_;
394 				goto LA1;
395 			}
396 			LA5_: ;
397 			buffer = setLengthStr(buffer, ((NI) (length)));
398 			update__stdZsha49_777((&state), buffer->data, (buffer ? buffer->Sup.len : 0));
399 			{
400 				if (!!((length == ((NI) 8192)))) goto LA9_;
401 				goto LA1;
402 			}
403 			LA9_: ;
404 		}
405 	} LA1: ;
406 	close__systemZio_237(f);
407 	finalize__stdZsha49_821((&state), Result);
408 }
N_INLINE(void,appendChar)409 static N_INLINE(void, appendChar)(NimStringDesc* dest, NIM_CHAR c) {
410 	(*dest).data[(*dest).Sup.len] = c;
411 	(*dest).data[(NI)((*dest).Sup.len + ((NI) 1))] = 0;
412 	(*dest).Sup.len += ((NI) 1);
413 }
N_NIMCALL(void,parseSecureHash__stdZsha49_912)414 N_LIB_PRIVATE N_NIMCALL(void, parseSecureHash__stdZsha49_912)(NimStringDesc* hash, tyArray__YtcvxHNKV4YiecPE9ap1mcA Result) {
415 	nimZeroMem((void*)Result, sizeof(tyArray__YtcvxHNKV4YiecPE9ap1mcA));
416 	{
417 		NI i;
418 		NI i_2;
419 		i = (NI)0;
420 		i_2 = ((NI) 0);
421 		{
422 			while (1) {
423 				NimStringDesc* T4_;
424 				NI T5_;
425 				if (!(i_2 < ((NI) 20))) goto LA3;
426 				i = i_2;
427 				T4_ = NIM_NIL;
428 				T4_ = rawNewString(2);
429 appendChar(T4_, hash->data[(NI)(i * ((NI) 2))]);
430 appendChar(T4_, hash->data[(NI)((NI)(i * ((NI) 2)) + ((NI) 1))]);
431 				T5_ = (NI)0;
432 				T5_ = nsuParseHexInt(T4_);
433 				Result[(i)- 0] = ((NU8) (T5_));
434 				i_2 += ((NI) 1);
435 			} LA3: ;
436 		}
437 	}
438 }
N_NIMCALL(NIM_BOOL,eqeq___stdZsha49_924)439 N_LIB_PRIVATE N_NIMCALL(NIM_BOOL, eqeq___stdZsha49_924)(tyArray__YtcvxHNKV4YiecPE9ap1mcA x, tyArray__YtcvxHNKV4YiecPE9ap1mcA y) {
440 	NIM_BOOL result;
441 {	result = (NIM_BOOL)0;
442 	{
443 		NI f;
444 		NI res;
445 		f = (NI)0;
446 		res = ((NI) 0);
447 		{
448 			while (1) {
449 				if (!(res <= ((NI) 19))) goto LA3;
450 				f = ((NI) (res));
451 				{
452 					if (!!((x[(f)- 0] == y[(f)- 0]))) goto LA6_;
453 					goto BeforeRet_;
454 				}
455 				LA6_: ;
456 				res += ((NI) 1);
457 			} LA3: ;
458 		}
459 	}
460 	result = NIM_TRUE;
461 	}BeforeRet_: ;
462 	return result;
463 }
N_NIMCALL(NIM_BOOL,eqeq___stdZsha49_920)464 N_LIB_PRIVATE N_NIMCALL(NIM_BOOL, eqeq___stdZsha49_920)(tyArray__YtcvxHNKV4YiecPE9ap1mcA a, tyArray__YtcvxHNKV4YiecPE9ap1mcA b) {
465 	NIM_BOOL result;
466 	result = (NIM_BOOL)0;
467 	result = eqeq___stdZsha49_924(a, b);
468 	return result;
469 }
470