tst note{ check for win32 .exe botches }end output{ #include <unistd.h> #include <fcntl.h> #include <sys/types.h> #include <sys/stat.h> static int cp(const char* from, const char* to) { ssize_t n; int fd; int td; struct stat fs; char buf[1024]; if ((fd = _open(from, O_RDONLY|O_BINARY)) < 0) return -1; if (_fstat(fd, &fs) || (td = _open(to, O_CREAT|O_WRONLY|O_TRUNC|O_BINARY, fs.st_mode & 0777)) < 0) { _close(fd); return -1; } while ((n = _read(fd, buf, sizeof(buf))) > 0 && _write(td, buf, n) == n); _close(fd); _close(td); return n ? -1 : 0; } int main(int argc, char** argv) { int fd; int fix; struct stat st; char buf[256]; snprintf(buf, sizeof(buf), "rm -rf /tmp/iff-%d", getpid()); if (_mkdir(buf+7, 0755)) return 1; if (_chdir(buf+7)) return 1; if (cp("/bin/cat.exe", "foo.exe")) return 1; fix = 0; if (_access("foo", X_OK)) fix++,printf("#define _win32_botch_access 1\n"); if (_chmod("foo", 0755)) fix++,printf("#define _win32_botch_chmod 1\n"); if (cp("/bin/cat", "bam") || _access("bam.exe", X_OK)) fix++,printf("#define _win32_botch_copy 1\n"); if (_getpagesize() != 64 * 1024) fix++,printf("#define _win32_botch_getpagesize 1\n"); #if !__EMX__ if (_link("foo", "bar") || _access("bar.exe", X_OK)) fix++,printf("#define _win32_botch_link 1\n"); else #endif cp("foo.exe", "bar.exe"); if ((fd = _open("foo", O_RDONLY)) < 0) fix++,printf("#define _win32_botch_open 1\n"); else _close(fd); if (_pathconf("huh", _PC_NAME_MAX) >= 0) fix++,printf("#define _win32_botch_pathconf 1\n"); if (_rename("foo", "aha") || _access("aha.exe", X_OK)) fix++,printf("#define _win32_botch_rename 1\n"); else _rename("foo.exe", "aha.exe"); if (_stat("bar", &st)) { fix++,printf("#define _win32_botch_stat 1\n"); if (sizeof(st.st_ino) == 8) printf("#define _stat _stat64\n"); } if (_truncate("aha", 0)) fix++,printf("#define _win32_botch_truncate 1\n"); if (_unlink("bar")) fix++,printf("#define _win32_botch_unlink 1\n"); if (_utime("aha", 0)) fix++,printf("#define _win32_botch_utime 1\n"); if (fix) { printf("#define _win32_botch_execve 1\n"); printf("#define _win32_botch 1\n"); } _chdir("/tmp"); system(buf); return 0; } }end tst win32_botch_alarm note{ win32 alarm(2) return botched }end noexecute{ #include <signal.h> #include <unistd.h> #include <time.h> static int sigalrm = 0; static void handler(int sig) { sigalrm++; } int main(int argc, char** argv) { signal(SIGALRM, handler); alarm(2); pause(); return sigalrm != 1 || alarm(0) != 0; } }end