Mercurial > hg-stable
changeset 5424:005638db9d0c
osutil: fold stat paths together
- simplify st/py_st logic
- use stp to point to stat buffer
- combine stat paths
author | Matt Mackall <mpm@selenic.com> |
---|---|
date | Mon, 08 Oct 2007 18:47:15 -0500 |
parents | e5f238a8b0d2 |
children | 830f6e280c90 |
files | mercurial/osutil.c |
diffstat | 1 files changed, 17 insertions(+), 37 deletions(-) [+] |
line wrap: on
line diff
--- a/mercurial/osutil.c Mon Oct 08 18:47:14 2007 -0500 +++ b/mercurial/osutil.c Mon Oct 08 18:47:15 2007 -0500 @@ -223,6 +223,9 @@ char *name = PyString_AsString(PyTuple_GET_ITEM(elt, 0)); PyObject *py_st = NULL; PyObject *py_kind = PyTuple_GET_ITEM(elt, 1); + struct listdir_stat *st; + struct stat buf; + struct stat *stp = &buf; int kind; kind = py_kind == Py_None ? -1 : PyInt_AsLong(py_kind); @@ -234,48 +237,33 @@ full_path[PATH_MAX] = 0; if (do_stat) { - struct listdir_stat *st; - if (!ctor_args) { ctor_args = PyTuple_New(0); if (!ctor_args) goto bail; } - st = (struct listdir_stat *) - PyObject_CallObject((PyObject *)&listdir_stat_type, + py_st = PyObject_CallObject((PyObject *)&listdir_stat_type, ctor_args); - + st = (struct listdir_stat *)py_st; if (!st) goto bail; + stp = &st->st; + PyTuple_SET_ITEM(elt, 2, py_st); + } + #ifdef AT_SYMLINK_NOFOLLOW - ret = fstatat(dfd, name, &st->st, AT_SYMLINK_NOFOLLOW); + ret = fstatat(dfd, name, stp, AT_SYMLINK_NOFOLLOW); #else - ret = lstat(full_path, &st->st); + ret = lstat(full_path, stp); #endif - if (ret == -1) { - list = PyErr_SetFromErrnoWithFilename(PyExc_OSError, - full_path); - goto bail; - } - if (kind == -1) - kind = mode_to_kind(st->st.st_mode); - py_st = (PyObject *)st; - } else { - struct stat buf; -#ifdef AT_SYMLINK_NOFOLLOW - ret = fstatat(dfd, ent->d_name, &buf, AT_SYMLINK_NOFOLLOW); -#else - ret = lstat(full_path, &buf); -#endif - if (ret == -1) { - list = PyErr_SetFromErrnoWithFilename(PyExc_OSError, - full_path); - goto bail; - } - if (kind == -1) - kind = mode_to_kind(buf.st_mode); + if (ret == -1) { + list = PyErr_SetFromErrnoWithFilename(PyExc_OSError, + full_path); + goto bail; } + if (kind == -1) + kind = mode_to_kind(stp->st_mode); if (py_kind == Py_None && kind != -1) { py_kind = PyInt_FromLong(kind); @@ -284,14 +272,6 @@ Py_XDECREF(Py_None); PyTuple_SET_ITEM(elt, 1, py_kind); } - - if (do_stat) { - if (!py_st) { - py_st = Py_None; - Py_INCREF(Py_None); - } - PyTuple_SET_ITEM(elt, 2, py_st); - } } goto done;