* lscp & friends: indicate filesystem by directory
@ 2011-03-07 9:51 dexen deVries
[not found] ` <201103071051.25290.dexen.devries-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
0 siblings, 1 reply; 2+ messages in thread
From: dexen deVries @ 2011-03-07 9:51 UTC (permalink / raw)
To: linux-nilfs-u79uwXL29TY76Z2rM5mHXA
Hi,
I've suspended issuing my current patches for lscp & friends till I implement
the functionality Ryusuke mentioned.
Please review the following sketch of algorithm for all interactive utils:
char *dev, *dir, *object;
char canonical[PATH_MAX + 2];
struct stat statbuffer;
dev = dir = object = NULL;
if (optind < argc)
object = argv[optind++];
if (object) {
stat(object, &statbuffer);
if (S_ISDIR(statbuffer))
dir = myrealpath(object, canonical, sizeof(canonical));
else
dev = myrealpath(object, canonical, sizeof(canonical));
}
else
dir = getwd(canonical);
/* a new function; traverses directory hierarchy up till it reaches nilfs
mountpoint */
if (dir)
dir = up_to_nilfs_mountpoint(dir);
nilfs_open(dev, dir, ...);
The main difference to the current version is:
if no object is explicitly indicated on the command line, the tool uses
current working directory. Thus by default it'd operate on the filesystem
holding the current working directory -- rather than the first NILFS2 in
/proc/mounts as it does currently.
To indicate which filesystem is to be used, I'd like to print a header line
roughly like:
# device: /dev/sdb3
What's your opinion?
--
dexen deVries
[[[↓][→]]]
47. As Will Rogers would have said, "There is no such thing as a free
variable."
(Alan Perlis, `Epigrams on Programming')
--
To unsubscribe from this list: send the line "unsubscribe linux-nilfs" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: lscp & friends: indicate filesystem by directory
[not found] ` <201103071051.25290.dexen.devries-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
@ 2011-03-08 2:31 ` Ryusuke Konishi
0 siblings, 0 replies; 2+ messages in thread
From: Ryusuke Konishi @ 2011-03-08 2:31 UTC (permalink / raw)
To: dexen.devries-Re5JQEeQqe8AvxtiuMwx3w; +Cc: linux-nilfs-u79uwXL29TY76Z2rM5mHXA
Hi,
On Mon, 7 Mar 2011 10:51:25 +0100, dexen deVries wrote:
> Hi,
>
> I've suspended issuing my current patches for lscp & friends till I implement
> the functionality Ryusuke mentioned.
>
> Please review the following sketch of algorithm for all interactive utils:
>
> char *dev, *dir, *object;
> char canonical[PATH_MAX + 2];
> struct stat statbuffer;
>
> dev = dir = object = NULL;
>
> if (optind < argc)
> object = argv[optind++];
>
> if (object) {
> stat(object, &statbuffer);
> if (S_ISDIR(statbuffer))
> dir = myrealpath(object, canonical, sizeof(canonical));
> else
> dev = myrealpath(object, canonical, sizeof(canonical));
> }
> else
> dir = getwd(canonical);
>
> /* a new function; traverses directory hierarchy up till it reaches nilfs
> mountpoint */
> if (dir)
> dir = up_to_nilfs_mountpoint(dir);
>
> nilfs_open(dev, dir, ...);
Roughly seems OK to me. (error handling is required at least for the
stat syscall, you know)
> The main difference to the current version is:
> if no object is explicitly indicated on the command line, the tool uses
> current working directory. Thus by default it'd operate on the filesystem
> holding the current working directory -- rather than the first NILFS2 in
> /proc/mounts as it does currently.
Yeah, I think this is a nice idea.
If the current working directory is outside nilfs, it should work same
as before. But this seems to be naturally achieved by the successive
up_to_nilfs_mountpoint() call if it returns NULL for out-of-nilfs
directories. Looks well conceived.
> To indicate which filesystem is to be used, I'd like to print a header line
> roughly like:
> # device: /dev/sdb3
>
> What's your opinion?
This may break compatibility of applications which parse lscp or lssu
output. A separate device line seems a bad idea; it would change the
result for applications just doing a dummy read to skip the header.
I think users do not care about the device name for lscp or lssu
unless they actually want to check it. So, making it an option (and
turning it off by default) would be better.
Also, looks like the device line does not have to be commented out ;)
Thanks,
Ryusuke Konishi
--
To unsubscribe from this list: send the line "unsubscribe linux-nilfs" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2011-03-08 2:31 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-03-07 9:51 lscp & friends: indicate filesystem by directory dexen deVries
[not found] ` <201103071051.25290.dexen.devries-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2011-03-08 2:31 ` Ryusuke Konishi
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.