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
CFLAGS = -Og -g -Wall -Wextra -Werror
CFLAGS = -Og -Wall -Wextra -Werror
objects = main.o input.o output.o encode.o

103
encode.c
View file

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

13
input.c
View file

@ -1,8 +1,21 @@
#include "input.h"
#define PADDING '='
#define OCTETBUF 3
#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
getsxts(FILE *fp, unsigned char *s)
{

View file

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

12
main.c
View file

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