mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-10-06 06:31:02 +00:00
Bring back gc() function
Renaming gc() to _gc() was a mistake since the better thing to do is put it behind the _COSMO_SOURCE macro. We need this change because I haven't wanted to use my amazing garbage collector ever since we renamed it. You now need to define _COSMO_SOURCE yourself when using amalgamation header and cosmocc users need to pass the -mcosmo flag to get the gc() function Some other issues relating to cancelation have been fixed along the way. We're also now putting cosmocc in a folder named `.cosmocc` so it can be more safely excluded by grep --exclude-dir=.cosmocc --exclude-dir=o etc.
This commit is contained in:
parent
6cb0354e19
commit
a4b455185b
280 changed files with 1362 additions and 1407 deletions
|
@ -29,7 +29,7 @@
|
|||
#include "libc/limits.h"
|
||||
#include "libc/macros.internal.h"
|
||||
#include "libc/mem/gc.h"
|
||||
#include "libc/mem/gc.internal.h"
|
||||
#include "libc/mem/gc.h"
|
||||
#include "libc/mem/mem.h"
|
||||
#include "libc/nexgen32e/nexgen32e.h"
|
||||
#include "libc/nexgen32e/vendor.internal.h"
|
||||
|
@ -177,8 +177,8 @@ TEST(pthread_create, testCustomStack_withReallySmallSize) {
|
|||
void *JoinMainWorker(void *arg) {
|
||||
void *rc;
|
||||
pthread_t main_thread = (pthread_t)arg;
|
||||
_gc(malloc(32));
|
||||
_gc(malloc(32));
|
||||
gc(malloc(32));
|
||||
gc(malloc(32));
|
||||
ASSERT_EQ(0, pthread_join(main_thread, &rc));
|
||||
ASSERT_EQ(123, (intptr_t)rc);
|
||||
return 0;
|
||||
|
@ -186,8 +186,8 @@ void *JoinMainWorker(void *arg) {
|
|||
|
||||
TEST(pthread_join, mainThread) {
|
||||
pthread_t id;
|
||||
_gc(malloc(32));
|
||||
_gc(malloc(32));
|
||||
gc(malloc(32));
|
||||
gc(malloc(32));
|
||||
SPAWN(fork);
|
||||
ASSERT_EQ(0, pthread_create(&id, 0, JoinMainWorker, (void *)pthread_self()));
|
||||
pthread_exit((void *)123);
|
||||
|
@ -196,8 +196,8 @@ TEST(pthread_join, mainThread) {
|
|||
|
||||
TEST(pthread_join, mainThreadDelayed) {
|
||||
pthread_t id;
|
||||
_gc(malloc(32));
|
||||
_gc(malloc(32));
|
||||
gc(malloc(32));
|
||||
gc(malloc(32));
|
||||
SPAWN(fork);
|
||||
ASSERT_EQ(0, pthread_create(&id, 0, JoinMainWorker, (void *)pthread_self()));
|
||||
usleep(10000);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue