File Coverage

inc/CryptX_Stream_Sober128.xs.inc
Criterion Covered Total %
statement 39 45 86.6
branch 17 38 44.7
condition n/a
subroutine n/a
pod n/a
total 56 83 67.4


line stmt bran cond sub pod time code
1             MODULE = CryptX PACKAGE = Crypt::Stream::Sober128
2              
3             PROTOTYPES: DISABLE
4              
5             Crypt::Stream::Sober128
6             new(Class, SV * key, SV * nonce)
7             CODE:
8             {
9             int rv;
10 13           STRLEN iv_len=0, k_len=0;
11 13           unsigned char *iv=NULL, *k=NULL;
12              
13 13 50         if (!SvPOK_spec(key)) croak("FATAL: key must be string/buffer scalar");
    50          
    0          
    0          
    0          
14 13 50         if (!SvPOK_spec(nonce)) croak("FATAL: nonce must be string/buffer scalar");
    50          
    0          
    0          
    0          
15 13           k = (unsigned char *) SvPVbyte(key, k_len);
16 13           iv = (unsigned char *) SvPVbyte(nonce, iv_len);
17              
18 13           Newz(0, RETVAL, 1, sober128_state);
19 13 50         if (!RETVAL) croak("FATAL: Newz failed");
20              
21 13           rv = sober128_stream_setup(RETVAL, k, (unsigned long)k_len);
22 13 50         if (rv != CRYPT_OK) {
23 0           Safefree(RETVAL);
24 0           croak("FATAL: sober128_stream_setup failed: %s", error_to_string(rv));
25             }
26              
27 13           rv = sober128_stream_setiv(RETVAL, iv, (unsigned long)iv_len);
28 13 100         if (rv != CRYPT_OK) {
29 1           sober128_stream_done(RETVAL);
30 1           Safefree(RETVAL);
31 1           croak("FATAL: sober128_stream_setiv failed: %s", error_to_string(rv));
32             }
33             }
34             OUTPUT:
35             RETVAL
36              
37             void
38             DESTROY(Crypt::Stream::Sober128 self)
39             CODE:
40 14           sober128_stream_done(self);
41 14           zeromem(self, sizeof(*self));
42 14           Safefree(self);
43              
44             Crypt::Stream::Sober128
45             clone(Crypt::Stream::Sober128 self)
46             CODE:
47 2           Newz(0, RETVAL, 1, sober128_state);
48 2 50         if (!RETVAL) croak("FATAL: Newz failed");
49 2           Copy(self, RETVAL, 1, sober128_state);
50             OUTPUT:
51             RETVAL
52              
53             SV *
54             keystream(Crypt::Stream::Sober128 self, unsigned long out_len)
55             CODE:
56             {
57             int rv;
58             unsigned char *out_data;
59              
60 5 100         if (out_len == 0) {
61 1           RETVAL = newSVpvn("", 0);
62             }
63             else {
64 4 100         if (out_len == ULONG_MAX) croak("FATAL: output length too large");
65 2           RETVAL = NEWSV(0, out_len); /* avoid zero! */
66 2           SvPOK_only(RETVAL);
67 2           SvCUR_set(RETVAL, out_len);
68 2           out_data = (unsigned char *)SvPVX(RETVAL);
69 2           rv = sober128_stream_keystream(self, out_data, out_len);
70 2 50         if (rv != CRYPT_OK) {
71 0           SvREFCNT_dec(RETVAL);
72 0           croak("FATAL: sober128_stream_keystream failed: %s", error_to_string(rv));
73             }
74             }
75             }
76             OUTPUT:
77             RETVAL
78              
79             SV *
80             crypt(Crypt::Stream::Sober128 self, SV * data)
81             CODE:
82             {
83             int rv;
84             STRLEN in_data_len;
85             unsigned char *in_data, *out_data;
86              
87 11           in_data = (unsigned char *)SvPVbyte(data, in_data_len);
88 11 100         if (in_data_len == 0) {
89 1           RETVAL = newSVpvn("", 0);
90             }
91             else {
92 10           RETVAL = NEWSV(0, in_data_len); /* avoid zero! */
93 10           SvPOK_only(RETVAL);
94 10           SvCUR_set(RETVAL, in_data_len);
95 10           out_data = (unsigned char *)SvPVX(RETVAL);
96 10           rv = sober128_stream_crypt(self, in_data, (unsigned long)in_data_len, out_data);
97 10 50         if (rv != CRYPT_OK) {
98 0           SvREFCNT_dec(RETVAL);
99 0           croak("FATAL: sober128_stream_crypt failed: %s", error_to_string(rv));
100             }
101             }
102             }
103             OUTPUT:
104             RETVAL