[PATCH 6 of 6] osutil: export a "getfstype" method
Augie Fackler
raf at durin42.com
Tue Mar 21 18:41:09 EDT 2017
On Mon, Mar 20, 2017 at 05:04:39PM -0700, Jun Wu wrote:
> # HG changeset patch
> # User Jun Wu <quark at fb.com>
> # Date 1490052852 25200
> # Mon Mar 20 16:34:12 2017 -0700
> # Node ID c8693bc1191b3ac1af0a67e97068777b13cfa672
> # Parent f710d54d1985975d7d37aa58e9d5740ebdcf5b7b
> # Available At https://bitbucket.org/quark-zju/hg-draft
> # hg pull https://bitbucket.org/quark-zju/hg-draft -r c8693bc1191b
> osutil: export a "getfstype" method
Thank you for sticking with this - this looks like what I had hoped
the first round could be. The statfs method is exactly what we needed.
Queued the whole thing.
>
> This patch exports the "getfstype" method. So we can use it to enable
> hardlinks for known safe filesystems.
>
> The patch was tested manually via debugshell on a Linux system.
> "mercurial.osutil.getfstype" works as expected. It's hard to mount
> filesystem on user-space easily. I will add a test for real hardlink support
> to indirectly test this patch, after turning on real hardlinks support for
> certain whitelisted filesystems.
>
> diff --git a/mercurial/osutil.c b/mercurial/osutil.c
> --- a/mercurial/osutil.c
> +++ b/mercurial/osutil.c
> @@ -1080,4 +1080,18 @@ const char *getfstype(const char *path)
> return NULL;
> }
> +
> +static PyObject *pygetfstype(PyObject *self, PyObject *args)
> +{
> + const char *path = NULL;
> + if (!PyArg_ParseTuple(args, "s", &path))
> + return NULL;
> +
> + const char *type = getfstype(path);
> + if (type == NULL)
> + Py_RETURN_NONE;
> +
> + PyObject *result = Py_BuildValue("s", type);
> + return result;
> +}
> #endif /* def HAVE_STATFS */
>
> @@ -1258,4 +1272,8 @@ static PyMethodDef methods[] = {
> "set process title (best-effort)\n"},
> #endif
> +#ifdef HAVE_STATFS
> + {"getfstype", (PyCFunction)pygetfstype, METH_VARARGS,
> + "get filesystem type (best-effort)\n"},
> +#endif
> #endif /* ndef _WIN32 */
> #ifdef __APPLE__
> _______________________________________________
> Mercurial-devel mailing list
> Mercurial-devel at mercurial-scm.org
> https://www.mercurial-scm.org/mailman/listinfo/mercurial-devel
More information about the Mercurial-devel
mailing list