X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=linux%2Fplat.c;h=5788d1d53e90c02afab193464113d0a73e1d9fb7;hb=2b9f9c51e68d4d5746c4ca2cd62b5f7b564ebf8a;hp=f5742b92f678b8259a3e2f034ab36f0f0042c582;hpb=6fb01dd38017e4f4435ef89cef922282478286b9;p=libpicofe.git diff --git a/linux/plat.c b/linux/plat.c index f5742b9..5788d1d 100644 --- a/linux/plat.c +++ b/linux/plat.c @@ -1,6 +1,7 @@ #define _GNU_SOURCE #include #include +#include #include #include #include @@ -22,17 +23,22 @@ int plat_is_dir(const char *path) int plat_get_root_dir(char *dst, int len) { - extern char **g_argv; - int j; + int j, ret; + + ret = readlink("/proc/self/exe", dst, len - 1); + if (ret < 0) { + perror("readlink"); + ret = 0; + } + dst[ret] = 0; - strncpy(dst, g_argv[0], len); - len -= 32; // reserve - if (len < 0) len = 0; - dst[len] = 0; for (j = strlen(dst); j > 0; j--) - if (dst[j] == '/') { dst[j+1] = 0; break; } + if (dst[j] == '/') { + dst[++j] = 0; + break; + } - return j + 1; + return 0; } #ifdef __GP2X__ @@ -142,3 +148,13 @@ void plat_munmap(void *ptr, size_t size) munmap(ptr, size); } +/* lprintf */ +void lprintf(const char *fmt, ...) +{ + va_list vl; + + va_start(vl, fmt); + vprintf(fmt, vl); + va_end(vl); +} +