Compare commits

..

No commits in common. "f0577d8ea0d2735195471a446fc8e08bd00ac9b2" and "4e8bb86ddd7c38b8248c1b19e66d058405cfc974" have entirely different histories.

5 changed files with 73 additions and 60 deletions

View file

@ -1,5 +1,5 @@
CC = gcc CC = gcc
CFLAGS = -Og -g -Wall -Wextra -Werror CFLAGS = -Og -Wall -Wextra -Werror
objects = main.o input.o output.o encode.o objects = main.o input.o output.o encode.o

103
encode.c
View file

@ -7,83 +7,80 @@ unsigned char b64[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \
"0123456789" \ "0123456789" \
"+/"; "+/";
unsigned char b64url[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \ unsigned char b64u[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \
"abcdefghijklmnopqrstuvwxyz" \ "abcdefghijklmnopqrstuvwxyz" \
"0123456789" \ "0123456789" \
"-_"; "-_";
int int
encode(unsigned char *op, int olen, unsigned char *sp, int url) encode(unsigned char *op, int olen, unsigned char *sp, int url)
{ {
int tmp; int n;
unsigned char *table; unsigned char *sb, *enc;
unsigned char *sbeg;
unsigned char *tend;
table = (!url) ? b64 : b64url; sb = sp;
enc = (!url) ? b64 : b64u;
sbeg = sp; switch (olen) {
tend = op + olen - (olen % 3); case 3:
while (op < tend) { *sp++ = enc[(*op & ~3) >> 2];
*sp++ = table[(*op & ~3) >> 2]; n = (*op++ & 3) << 4;
tmp = (*op++ & 3) << 4; *sp++ = enc[n + ((*op & ~15) >> 4)];
*sp++ = table[tmp + ((*op & ~15) >> 4)]; n = (*op++ & 15) << 2;
tmp = (*op++ & 15) << 2; *sp++ = enc[n + ((*op & 192) >> 6)];
*sp++ = table[tmp + ((*op & 192) >> 6)]; *sp = enc[*op & ~192];
*sp++ = table[*op++ & ~192]; break;
}
switch (olen % 3) {
case 2: case 2:
*sp++ = table[(*op & ~3) >> 2]; *sp++ = enc[(*op & ~3) >> 2];
tmp = (*op++ & 3) << 4; n = (*op++ & 3) << 4;
*sp++ = table[tmp + ((*op & ~15) >> 4)]; *sp++ = enc[n + ((*op & ~15) >> 4)];
*sp++ = table[(*op & 15) << 2]; *sp++ = enc[(*op & 15) << 2];
*sp++ = PADDING; *sp = PADDING;
break; break;
case 1: case 1:
*sp++ = table[(*op & ~3) >> 2]; *sp++ = enc[(*op & ~3) >> 2];
*sp++ = table[(*op & 3) << 4]; *sp++ = enc[(*op & 3) << 4];
*sp++ = PADDING;
*sp++ = PADDING; *sp++ = PADDING;
*sp = PADDING;
break; break;
} }
return sp-sbeg; return sp-sb+1;
} }
int int
decode(unsigned char *sp, int slen, unsigned char *op, int url) decode(unsigned char *sp, int slen, unsigned char *op, int url)
{ {
int tmp, b, atob(int c, int url); int n, b, atob(int c, int url);
unsigned char *obeg; unsigned char *ob;
unsigned char *qend;
obeg = op; ob = op;
qend = sp + slen - (slen % 4); switch (slen) {
while (sp < qend) { case 4:
tmp = atob(*sp++, url) << 2; n = atob(*sp++, url) << 2;
b = atob(*sp++, url);
*op++ = tmp + ((b & ~15) >> 4);
tmp = (b & 15) << 4;
b = atob(*sp++, url);
*op++ = tmp + ((b & ~3) >> 2);
*op++ = ((b & 3) << 6) + atob(*sp++, url);
}
switch (slen % 4) {
case 3:
tmp = atob(*sp++, url) << 2;
b = atob(*sp++, url); b = atob(*sp++, url);
*op++ = tmp + ((b & ~15) >> 4); *op++ = n + ((b & ~15) >> 4);
tmp = (b & 15) << 4;
*op++ = tmp + ((atob(*sp++, url) & ~3) >> 2); n = (b & 15) << 4;
b = atob(*sp++, url);
*op++ = n + ((b & ~3) >> 2);
*op = ((b & 3) << 6) + atob(*sp, url);
break;
case 3:
n = atob(*sp++, url) << 2;
b = atob(*sp++, url);
*op++ = n + ((b & ~15) >> 4);
n = (b & 15) << 4;
*op = n + ((atob(*sp, url) & ~3) >> 2);
break; break;
case 2: case 2:
tmp = atob(*sp++, url) << 2; n = atob(*sp++, url) << 2;
*op++ = tmp + ((atob(*sp++, url) & ~15) >> 4); *op = n + ((atob(*sp, url) & ~15) >> 4);
break; break;
} }
return op-obeg; return op-ob+1;
} }
int atob(int c, int url) int atob(int c, int url)

13
input.c
View file

@ -1,8 +1,21 @@
#include "input.h" #include "input.h"
#define PADDING '=' #define PADDING '='
#define OCTETBUF 3
#define SXTETBUF 4 #define SXTETBUF 4
int
getocts(FILE *fp, unsigned char *o)
{
int c, n;
n = 0;
while (n < OCTETBUF && (c = fgetc(fp)) != EOF)
o[n++] = c;
return n;
}
int int
getsxts(FILE *fp, unsigned char *s) getsxts(FILE *fp, unsigned char *s)
{ {

View file

@ -3,6 +3,9 @@
#include <stdio.h> #include <stdio.h>
int
getocts(FILE *fp, unsigned char *o);
int int
getsxts(FILE *fp, unsigned char *s); getsxts(FILE *fp, unsigned char *s);

12
main.c
View file

@ -4,8 +4,8 @@
#include "output.h" #include "output.h"
#include "encode.h" #include "encode.h"
#define OCTETBUF 300 #define OCTETBUF 4
#define SXTETBUF 400 #define SXTETBUF 5
unsigned char obuf[OCTETBUF]; unsigned char obuf[OCTETBUF];
unsigned char sbuf[SXTETBUF]; unsigned char sbuf[SXTETBUF];
@ -59,16 +59,16 @@ main(int argc, char *argv[])
} }
} else if (wrp) { } else if (wrp) {
last = 0; last = 0;
while ((n = fread(obuf, sizeof(*obuf), OCTETBUF, (in) ? in : stdin))) { while ((n = getocts((in) ? in : stdin, obuf))) {
n = encode(obuf, n, sbuf, url); n = encode(obuf, n, sbuf, url);
last = printw((out) ? out : stdout, sbuf, n); last = printw((out) ? out : stdout, sbuf, n);
} }
if (last != '\n') if (last != '\n')
fprintf((out) ? out : stdout, "\n"); fprintf((out) ? out : stdout, "\n");
} else { } else {
while ((n = fread(obuf, sizeof(*obuf), OCTETBUF, (in) ? in : stdin))) { while ((n = getocts((in) ? in : stdin, obuf))) {
n = encode(obuf, n, sbuf, url); encode(obuf, n, sbuf, url);
fwrite(sbuf, sizeof(*sbuf), n, (out) ? out : stdout); fprintf((out) ? out : stdout, "%s", sbuf);
} }
} }
if (in) if (in)