mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-06-27 14:58:30 +00:00
Strongly link glob() into system() and popen()
This commit is contained in:
parent
4e9566cd33
commit
cafdb456ed
24 changed files with 216 additions and 59 deletions
81
libc/system/BUILD.mk
Normal file
81
libc/system/BUILD.mk
Normal file
|
@ -0,0 +1,81 @@
|
|||
#-*-mode:makefile-gmake;indent-tabs-mode:t;tab-width:8;coding:utf-8-*-┐
|
||||
#── vi: set noet ft=make ts=8 sw=8 fenc=utf-8 :vi ────────────────────┘
|
||||
|
||||
PKGS += LIBC_SYSTEM
|
||||
|
||||
LIBC_SYSTEM_ARTIFACTS += LIBC_SYSTEM_A
|
||||
LIBC_SYSTEM = $(LIBC_SYSTEM_A_DEPS) $(LIBC_SYSTEM_A)
|
||||
LIBC_SYSTEM_A = o/$(MODE)/libc/system/system.a
|
||||
LIBC_SYSTEM_A_FILES := $(wildcard libc/system/*)
|
||||
LIBC_SYSTEM_A_HDRS = $(filter %.h,$(LIBC_SYSTEM_A_FILES))
|
||||
LIBC_SYSTEM_A_INCS = $(filter %.inc,$(LIBC_SYSTEM_A_FILES))
|
||||
LIBC_SYSTEM_A_SRCS_S = $(filter %.S,$(LIBC_SYSTEM_A_FILES))
|
||||
LIBC_SYSTEM_A_SRCS_C = $(filter %.c,$(LIBC_SYSTEM_A_FILES))
|
||||
|
||||
LIBC_SYSTEM_A_SRCS = \
|
||||
$(LIBC_SYSTEM_A_SRCS_S) \
|
||||
$(LIBC_SYSTEM_A_SRCS_C)
|
||||
|
||||
LIBC_SYSTEM_A_OBJS = \
|
||||
$(LIBC_SYSTEM_A_SRCS_S:%.S=o/$(MODE)/%.o) \
|
||||
$(LIBC_SYSTEM_A_SRCS_C:%.c=o/$(MODE)/%.o)
|
||||
|
||||
LIBC_SYSTEM_A_CHECKS = \
|
||||
$(LIBC_SYSTEM_A).pkg \
|
||||
$(LIBC_SYSTEM_A_HDRS:%=o/$(MODE)/%.ok)
|
||||
|
||||
LIBC_SYSTEM_A_DIRECTDEPS = \
|
||||
LIBC_CALLS \
|
||||
LIBC_FMT \
|
||||
LIBC_INTRIN \
|
||||
LIBC_NEXGEN32E \
|
||||
LIBC_PROC \
|
||||
LIBC_RUNTIME \
|
||||
LIBC_STDIO \
|
||||
LIBC_STR \
|
||||
LIBC_SYSV \
|
||||
THIRD_PARTY_MUSL \
|
||||
|
||||
LIBC_SYSTEM_A_DEPS := \
|
||||
$(call uniq,$(foreach x,$(LIBC_SYSTEM_A_DIRECTDEPS),$($(x))))
|
||||
|
||||
$(LIBC_SYSTEM_A):libc/system/ \
|
||||
$(LIBC_SYSTEM_A).pkg \
|
||||
$(LIBC_SYSTEM_A_OBJS)
|
||||
|
||||
$(LIBC_SYSTEM_A).pkg: \
|
||||
$(LIBC_SYSTEM_A_OBJS) \
|
||||
$(foreach x,$(LIBC_SYSTEM_A_DIRECTDEPS),$($(x)_A).pkg)
|
||||
|
||||
# offer assurances about the stack safety of cosmo libc
|
||||
$(LIBC_SYSTEM_A_OBJS): private COPTS += -Wframe-larger-than=4096 -Walloca-larger-than=4096
|
||||
|
||||
$(LIBC_SYSTEM_A_OBJS): private \
|
||||
CFLAGS += \
|
||||
-fno-sanitize=all \
|
||||
-Wframe-larger-than=4096 \
|
||||
-Walloca-larger-than=4096
|
||||
|
||||
o/$(MODE)/libc/system/fputc.o: private \
|
||||
CFLAGS += \
|
||||
-O3
|
||||
|
||||
o//libc/system/appendw.o: private \
|
||||
CFLAGS += \
|
||||
-Os
|
||||
|
||||
o/$(MODE)/libc/system/dirstream.o \
|
||||
o/$(MODE)/libc/system/mt19937.o: private \
|
||||
CFLAGS += \
|
||||
-ffunction-sections
|
||||
|
||||
LIBC_SYSTEM_LIBS = $(foreach x,$(LIBC_SYSTEM_ARTIFACTS),$($(x)))
|
||||
LIBC_SYSTEM_SRCS = $(foreach x,$(LIBC_SYSTEM_ARTIFACTS),$($(x)_SRCS))
|
||||
LIBC_SYSTEM_HDRS = $(foreach x,$(LIBC_SYSTEM_ARTIFACTS),$($(x)_HDRS))
|
||||
LIBC_SYSTEM_INCS = $(foreach x,$(LIBC_SYSTEM_ARTIFACTS),$($(x)_INCS))
|
||||
LIBC_SYSTEM_CHECKS = $(foreach x,$(LIBC_SYSTEM_ARTIFACTS),$($(x)_CHECKS))
|
||||
LIBC_SYSTEM_OBJS = $(foreach x,$(LIBC_SYSTEM_ARTIFACTS),$($(x)_OBJS))
|
||||
$(LIBC_SYSTEM_OBJS): $(BUILD_FILES) libc/system/BUILD.mk
|
||||
|
||||
.PHONY: o/$(MODE)/libc/system
|
||||
o/$(MODE)/libc/system: $(LIBC_SYSTEM_CHECKS)
|
|
@ -1055,12 +1055,9 @@ int _cocmd(int argc, char **argv, char **envp) {
|
|||
unsupported['('] = true;
|
||||
unsupported[')'] = true;
|
||||
unsupported['{'] = true;
|
||||
unsupported['}'] = false; // Perl t/op/exec.t depends on unpaired } being
|
||||
// passed from the shell to Perl
|
||||
if (!_weaken(glob)) {
|
||||
unsupported['*'] = true;
|
||||
unsupported['?'] = true;
|
||||
}
|
||||
// Perl t/op/exec.t depends on unpaired } being
|
||||
// passed from the shell to Perl
|
||||
unsupported['}'] = false;
|
||||
|
||||
if (argc >= 3 && !strcmp(argv[1], "--")) {
|
||||
for (i = 2; i < argc; ++i) {
|
||||
|
@ -1121,18 +1118,16 @@ int _cocmd(int argc, char **argv, char **envp) {
|
|||
Open(GetRedirectArg(prog, arg, 1), 0, O_RDONLY);
|
||||
} else {
|
||||
int globrc = GLOB_NOMATCH;
|
||||
if (_weaken(glob)) {
|
||||
globrc = _weaken(glob)(arg, globFlags, NULL, &globTheBuilder);
|
||||
if (globrc == 0) {
|
||||
for (; globCount < globTheBuilder.gl_pathc; globCount++) {
|
||||
args[n++] = globTheBuilder.gl_pathv[globCount];
|
||||
}
|
||||
} else if (globrc != GLOB_NOMATCH) {
|
||||
tinyprint(2, prog, ": error: with glob\n", NULL);
|
||||
_Exit(16);
|
||||
globrc = glob(arg, globFlags, NULL, &globTheBuilder);
|
||||
if (globrc == 0) {
|
||||
for (; globCount < globTheBuilder.gl_pathc; globCount++) {
|
||||
args[n++] = globTheBuilder.gl_pathv[globCount];
|
||||
}
|
||||
globFlags |= GLOB_APPEND;
|
||||
} else if (globrc != GLOB_NOMATCH) {
|
||||
tinyprint(2, prog, ": error: with glob\n", NULL);
|
||||
_Exit(16);
|
||||
}
|
||||
globFlags |= GLOB_APPEND;
|
||||
if (globrc == GLOB_NOMATCH) {
|
||||
args[n++] = arg;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue