Skip to content

Commit

Permalink
Merge branch 'master' of github.com:micropython/micropython
Browse files Browse the repository at this point in the history
  • Loading branch information
dpgeorge committed May 3, 2014
2 parents 977a0ce + fb9ca7c commit 1549f17
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 4 deletions.
4 changes: 0 additions & 4 deletions unix/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -394,11 +394,7 @@ int main(int argc, char **argv) {
return usage(argv);
}
} else {
#ifdef __MINGW32__
char *basedir = _fullpath(NULL, argv[a], _MAX_PATH);
#else
char *basedir = realpath(argv[a], NULL);
#endif
if (basedir == NULL) {
fprintf(stderr, "%s: can't open file '%s': [Errno %d] ", argv[0], argv[1], errno);
perror("");
Expand Down
1 change: 1 addition & 0 deletions windows/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ endif
SRC_C = \
unix/main.c \
unix/file.c \
realpath.c \

OBJ = $(PY_O) $(addprefix $(BUILD)/, $(SRC_C:.c=.o))

Expand Down
2 changes: 2 additions & 0 deletions windows/mpconfigport.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,3 +36,5 @@ typedef const void *machine_const_ptr_t; // must be of pointer size
extern const struct _mp_obj_fun_native_t mp_builtin_open_obj;
#define MICROPY_EXTRA_BUILTINS \
{ MP_OBJ_NEW_QSTR(MP_QSTR_open), (mp_obj_t)&mp_builtin_open_obj },

#include "realpath.h"
42 changes: 42 additions & 0 deletions windows/realpath.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
#include <stdlib.h>
#include <errno.h>
#include <io.h>

#ifndef R_OK
#define R_OK 4
#endif

// Make sure a path only has forward slashes.
char *to_unix_path(char *p) {
if (p != NULL) {
char *pp = p;
while (*pp != 0) {
if (*pp == '\\')
*pp = '/';
++pp;
}
}
return p;
}

// Implement realpath() using _fullpath and make it use the same error codes as realpath() on unix.
// Also have it return a path with forward slashes only as some code relies on this,
// but _fullpath() returns backward slashes no matter what.
char *realpath(const char *path, char *resolved_path) {
char *ret = NULL;
if (path == NULL) {
errno = EINVAL;
} else if (access(path, R_OK) == 0) {
ret = resolved_path;
if (ret == NULL)
ret = malloc(_MAX_PATH);
if (ret == NULL) {
errno = ENOMEM;
} else {
ret = _fullpath(ret, path, _MAX_PATH);
if (ret == NULL)
errno = EIO;
}
}
return to_unix_path(ret);
}
2 changes: 2 additions & 0 deletions windows/realpath.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@

extern char *realpath(const char *path, char *resolved_path);

0 comments on commit 1549f17

Please sign in to comment.