Add Cosmopolitan Honeybadger to README.md

This commit is contained in:
Justine Tunney
2021-02-04 03:30:47 -08:00
parent d934f38c99
commit c93a4661a3
8 changed files with 32 additions and 58 deletions

View File

@ -1,3 +1,5 @@
![Cosmopolitan Honeybadger](usr/share/img/honeybadger.png)
# Cosmopolitan # Cosmopolitan
[Cosmopolitan Libc](https://justine.lol/cosmopolitan/index.html) makes C [Cosmopolitan Libc](https://justine.lol/cosmopolitan/index.html) makes C

View File

@ -321,7 +321,7 @@ static size_t __asan_int2str(int64_t i, char *a) {
return 1 + __asan_uint2str(-i, a); return 1 + __asan_uint2str(-i, a);
} }
flattenout void __asan_poison(uintptr_t p, size_t n, int kind) { void __asan_poison(uintptr_t p, size_t n, int kind) {
int k; int k;
char *s; char *s;
if (!n) return; if (!n) return;
@ -343,7 +343,7 @@ flattenout void __asan_poison(uintptr_t p, size_t n, int kind) {
} }
} }
flattenout void __asan_unpoison(uintptr_t p, size_t n) { void __asan_unpoison(uintptr_t p, size_t n) {
int k; int k;
char *s; char *s;
if (!n) return; if (!n) return;

View File

@ -1,41 +0,0 @@
/*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:2;tab-width:8;coding:utf-8 -*-│
│vi: set net ft=c ts=2 sts=2 sw=2 fenc=utf-8 :vi│
╞══════════════════════════════════════════════════════════════════════════════╡
│ Copyright 2020 Justine Alexandra Roberts Tunney │
│ │
│ Permission to use, copy, modify, and/or distribute this software for │
│ any purpose with or without fee is hereby granted, provided that the │
│ above copyright notice and this permission notice appear in all copies. │
│ │
│ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL │
│ WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED │
│ WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE │
│ AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL │
│ DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR │
│ PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER │
│ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │
│ PERFORMANCE OF THIS SOFTWARE. │
╚─────────────────────────────────────────────────────────────────────────────*/
#include "libc/str/str.h"
#include "libc/str/utf16.h"
/**
* Helps runtime decode UTF-16 with slightly smaller code size.
*/
wint_t DecodeNtsUtf16(const char16_t **s) {
wint_t x, y;
for (;;) {
if (!(x = *(*s)++)) break;
if (IsUtf16Cont(x)) continue;
if (IsUcs2(x)) {
return x;
} else {
if ((y = *(*s)++)) {
return MergeUtf16(x, y);
} else {
return 0;
}
}
}
return x;
}

View File

@ -69,7 +69,7 @@ static const struct DeflateConsts {
{{144, 8}, {112, 9}, {24, 7}, {8, 8}, {32, 5}, {0, 0}}, {{144, 8}, {112, 9}, {24, 7}, {8, 8}, {32, 5}, {0, 0}},
}; };
static noasan uint32_t undeflatetree(struct DeflateState *ds, uint32_t *tree, static uint32_t undeflatetree(struct DeflateState *ds, uint32_t *tree,
const uint8_t *lens, size_t symcount) { const uint8_t *lens, size_t symcount) {
size_t i, len; size_t i, len;
uint32_t code, slot; uint32_t code, slot;
@ -96,7 +96,7 @@ static noasan uint32_t undeflatetree(struct DeflateState *ds, uint32_t *tree,
return first[15]; return first[15];
} }
static noasan struct DeflateHold undeflatesymbol(struct DeflateHold hold, static struct DeflateHold undeflatesymbol(struct DeflateHold hold,
const uint32_t *tree, const uint32_t *tree,
size_t treecount, size_t treecount,
uint32_t *out_symbol) { uint32_t *out_symbol) {
@ -122,8 +122,6 @@ static noasan struct DeflateHold undeflatesymbol(struct DeflateHold hold,
return hold; return hold;
} }
/* TODO(jart): Do we really need noasan? */
/** /**
* Decompresses raw DEFLATE data. * Decompresses raw DEFLATE data.
* *
@ -134,7 +132,7 @@ static noasan struct DeflateHold undeflatesymbol(struct DeflateHold hold,
* are part of the design of this algorithm * are part of the design of this algorithm
* @note h/t Phil Katz, David Huffman, Claude Shannon * @note h/t Phil Katz, David Huffman, Claude Shannon
*/ */
noasan ssize_t undeflate(void *output, size_t outputsize, void *input, ssize_t undeflate(void *output, size_t outputsize, void *input,
size_t inputsize, struct DeflateState *ds) { size_t inputsize, struct DeflateState *ds) {
struct DeflateHold hold; struct DeflateHold hold;
bool isfinalblock; bool isfinalblock;

View File

@ -50,6 +50,7 @@
#include "libc/str/str.h" #include "libc/str/str.h"
#include "libc/str/thompike.h" #include "libc/str/thompike.h"
#include "libc/str/tpdecode.internal.h" #include "libc/str/tpdecode.internal.h"
#include "libc/str/tpenc.h"
#include "libc/str/tpencode.internal.h" #include "libc/str/tpencode.internal.h"
#include "libc/sysv/consts/auxv.h" #include "libc/sysv/consts/auxv.h"
#include "libc/sysv/consts/ex.h" #include "libc/sysv/consts/ex.h"
@ -1957,12 +1958,16 @@ static int GetVidyaByte(unsigned char b) {
} }
static void OnVidyaServiceWriteCharacter(void) { static void OnVidyaServiceWriteCharacter(void) {
uint64_t w;
int i, n, y, x; int i, n, y, x;
char *p, buf[32]; char *p, buf[32];
p = buf; p = buf;
p += FormatCga(m->bx[0], p); p += FormatCga(m->bx[0], p);
p = stpcpy(p, "\e7"); p = stpcpy(p, "\e7");
p += tpencode(p, 8, GetVidyaByte(m->ax[0]), false); w = tpenc(GetVidyaByte(m->ax[0]));
do {
*p++ = w;
} while ((w >>= 8));
p = stpcpy(p, "\e8"); p = stpcpy(p, "\e8");
for (i = Read16(m->cx); i--;) { for (i = Read16(m->cx); i--;) {
PtyWrite(pty, buf, p - buf); PtyWrite(pty, buf, p - buf);
@ -1984,9 +1989,13 @@ static char16_t VidyaServiceXlatTeletype(uint8_t c) {
static void OnVidyaServiceTeletypeOutput(void) { static void OnVidyaServiceTeletypeOutput(void) {
int n; int n;
uint64_t w;
char buf[12]; char buf[12];
n = FormatCga(m->bx[0], buf); n = FormatCga(m->bx[0], buf);
n += tpencode(buf + n, 6, VidyaServiceXlatTeletype(m->ax[0]), false); w = tpenc(VidyaServiceXlatTeletype(m->ax[0]));
do {
buf[n++] = w;
} while ((w >>= 8));
PtyWrite(pty, buf, n); PtyWrite(pty, buf, n);
} }

View File

@ -28,7 +28,7 @@
#include "libc/mem/mem.h" #include "libc/mem/mem.h"
#include "libc/runtime/runtime.h" #include "libc/runtime/runtime.h"
#include "libc/str/str.h" #include "libc/str/str.h"
#include "libc/str/tpencode.internal.h" #include "libc/str/tpenc.h"
#include "third_party/xed/x86.h" #include "third_party/xed/x86.h"
#include "tool/build/lib/case.h" #include "tool/build/lib/case.h"
#include "tool/build/lib/demangle.h" #include "tool/build/lib/demangle.h"
@ -134,12 +134,18 @@ static char *DisLineCode(struct Dis *d, char *p) {
static char *DisLineData(struct Dis *d, char *p, const uint8_t *b, size_t n) { static char *DisLineData(struct Dis *d, char *p, const uint8_t *b, size_t n) {
size_t i; size_t i;
uint64_t w;
p = DisColumn(DisAddr(d, p), p, ADDRLEN); p = DisColumn(DisAddr(d, p), p, ADDRLEN);
p = DisColumn(DisByte(p, b, n), p, 64); p = DisColumn(DisByte(p, b, n), p, 64);
p = HighStart(p, g_high.comment); p = HighStart(p, g_high.comment);
*p++ = '#'; *p++ = '#';
*p++ = ' '; *p++ = ' ';
for (i = 0; i < n; ++i) p += tpencode(p, 8, bing(b[i], 0), false); for (i = 0; i < n; ++i) {
w = tpenc(bing(b[i], 0));
do {
*p++ = w;
} while ((w >>= 8));
}
p = HighEnd(p); p = HighEnd(p);
*p = '\0'; *p = '\0';
return p; return p;

View File

@ -140,7 +140,7 @@ void LoadProgram(struct Machine *m, const char *prog, char **args, char **vars,
size_t i, mappedsize; size_t i, mappedsize;
DCHECK_NOTNULL(prog); DCHECK_NOTNULL(prog);
elf->prog = prog; elf->prog = prog;
if ((fd = open(prog, O_RDONLY)) == -1 || if ((fd = open(prog, O_RDWR)) == -1 ||
(fstat(fd, &st) == -1 || !st.st_size)) { (fstat(fd, &st) == -1 || !st.st_size)) {
fputs(prog, stderr); fputs(prog, stderr);
fputs(": not found\n", stderr); fputs(": not found\n", stderr);

Binary file not shown.

After

Width:  |  Height:  |  Size: 21 KiB