users are confused by "tahoe rm" #776

Closed
opened 2009-07-28 03:10:07 +00:00 by zooko · 25 comments

I found the following conversation log between a new user (PovAddict) and an experienced user (soul9). They are confused about what "tahoe rm" means. Possible changes that could improve this include renaming it to "tahoe unlink", improving the error messages (see below), and improving the docs.

<PovAddict> I just installed a tahoe client and attached it to the "volunteer grid"							[19:01]
...
<PovAddict> also, too many Python exceptions to take tahoe seriously...	[19:17]
<soul9> PovAddict: what python exceptions.				[19:19]
<soul9> ?
<soul9> python2.6?
<PovAddict> 2.5.2
<soul9> hm
<soul9> i didn't have python exceptions, except deprecationwarnings in python
	2.6
<PovAddict> http://pastebin.com/df3bfddf				[19:20]

      nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe ls
      Traceback (most recent call last):
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module>
          load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')()
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run
          rc = runner(sys.argv[1:])
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner
          rc = cli.dispatch[command](so)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 380, in list
          rc = tahoe_ls.list(options)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_ls.py", line 18, in list
          rootcap, path = get_alias(aliases, where, DEFAULT_ALIAS)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/common.py", line 148, in get_alias
          return aliases[default], path
      KeyError: 'tahoe'
      nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe ls URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946
      Traceback (most recent call last):
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module>
          load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')()
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run
          rc = runner(sys.argv[1:])
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner
          rc = cli.dispatch[command](so)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 380, in list
          rc = tahoe_ls.list(options)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_ls.py", line 67, in list
          childtype = child[0]
      KeyError: 0
      nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe rm URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946
      Traceback (most recent call last):
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module>
          load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')()
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run
          rc = runner(sys.argv[1:])
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner
          rc = cli.dispatch[command](so)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 409, in rm
          rc = tahoe_rm.rm(options)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_rm.py", line 25, in rm
          assert path
      AssertionError

<PovAddict> I uploaded a file to the VolunteerGrid from the web interface
<PovAddict> I can download it back from there, or using "tahoe get"
<soul9> yes, well
<PovAddict> and that's it; is 'rm' supposed to work?
<soul9> i think that has to do with a not defined default rootcap	[19:21]
<soul9> yes, it is, of course
<PovAddict> no matter what the problem really is, the command line tool should
	    give a proper error message, instead of dumping a stacktrace...
<soul9> er								[19:22]
<PovAddict> "KeyError: 0" might only mean something to people who know the
	    code and know the causes of this situation
<PovAddict> definitely means nothing to me
<soul9> it's not dumping it's core at all
<PovAddict> it printed a stacktrace on the console			[19:23]
<soul9> it's trying to tell you you didn't give it where to ls
<soul9> no, that's warnings
<soul9> if you don't want that do tahoe cmd ... blabla 2> /dev/null
<PovAddict> "KeyError: 0" and "AssertionError" are not warnings, they are
	    exceptions							[19:24]
<soul9> they end in error because there is nothing to ls
<soul9> tahoe has no "root"
<soul9> so you can't do an ls without giving it a default rootcap
<PovAddict> my point is: why does it say "KeyError: 0" instead of "rootcap
	    required"?
<soul9> which is the tahoe "alias"
<PovAddict> is it an argument I'm supposed to pass after 'ls'?		[19:25]
<soul9> well, that's a good point, and you should definitely open a bug if
	there isn't one allready
<PovAddict> "tahoe ls something"?
<soul9> tahoe ls ROOT:cap:thisisasecuretahoeurlwhateverhexblah
<soul9> yeah, it's an tahoe rootcap
<PovAddict> "tahoe ls --help" doesn't say there are required arguments	[19:26]
<soul9> so e.g. you do tahoe mkdir foo
<soul9> gives you a rootcap back
<soul9> then you can save the rootcap as an alias
<soul9> so you don't need to remember the horridly long hash
<soul9> you can give it a name
<soul9> because if you add an tahoe alias
<soul9> then that will be used as default
<PovAddict> okay, actually, --help doesn't even mention any argument	[19:27]
<PovAddict> just the options
<soul9> which is why it's looking for the tahoe key
<PovAddict> and "tahoe <command> [command options] mkdir [options]" makes no
	    sense :) mkdir *is* the <command>
<PovAddict> anyway; what about the rm error?
* soul9 → bugs
<soul9> try it with a rootcap						[19:28]
<soul9> it'll work
<soul9> tahoe is well coded for the purpose it serves
<soul9> wich is uploading big files using the web ui
<soul9> because the cmdline client also just uses the webui in the backend
									[19:29]
<soul9> hell, the fuse client just uses the webui aswell
<PovAddict> I don't know how I'm supposed to get that 'rootcap'
<PovAddict> I uploaded a file from the web ui, now I want to delete it
*** jsgf (n=jeremy@adsl-69-107-65-92.dsl.pltn13.pacbell.net) has quit: Read
    error: 110 (Connection timed out)
<PovAddict> I have the URI I got after uploading			[19:30]
<soul9> that's the cap
<PovAddict> and I can use it to download the file
<soul9> that big hash
<PovAddict> yup
<soul9> so you do tahoe rm HASH
<soul9> tahoe ls HASH
<PovAddict> and it throws an AssertionError, as shown on my paste	[19:31]
<soul9> tahoe cp foo HASH:dor/you/want
<soul9> hm								[19:32]
<soul9> dunno
<soul9> worksforme™
<PovAddict> also note line 16 of paste was wrapped; I *did* pass a hash to ls
<PovAddict> and it just throws a different error			[19:33]
<soul9> then you have a problem in your setup, or the directory is empty
<soul9> iirc
<PovAddict> I didn't create a directory					[19:34]
<PovAddict> I uploaded it from here: http://nooxie.zooko.com:9798/ using the
	    "Upload a file" form, I didn't create a directory first
									[19:35]
<PovAddict> unfortunately none of the shares ended up on my own node, which is
	    kind of what I wanted to try				[19:36]
<PovAddict> so, now, I want to delete the file from the grid; and I only have
	    the one hash it gave me
<soul9> yeah, tahoe ls file doesn't work				[19:38]
<soul9> you can't ls a file
<soul9> use the hash to delete it
<soul9> it's as simple as tahoe rm HASH
<PovAddict> I did and it throws AssertionError
<PovAddict> the hash is in the pastebin; can you try rm yourself?
<soul9> is the file still there tho?					[19:39]
<soul9> i'm not connected to the volounteer grid
<soul9> i have my own ;)
<PovAddict> 'check' says the file is healthy
<PovAddict> Summary: Healthy
<soul9> weird, it should work
<PovAddict>  storage index: xetcmqax6bi5eozzggamxh7gg4			[19:40]
<PovAddict>  good-shares: 10 (encoding is 3-of-10)
<soul9> mmmm								[19:41]
<soul9> º what is the introducer furl to the volounteer grid?		[19:42]
<PovAddict>
	    pb://6cypm5tfsv6ag43g3j5z74qx5nfxa2qq@207.7.145.200:64228,nooxie.zooko.com:64228/introducer
<soul9> mm								[19:45]
<soul9> that's a bug!							[19:46]
<soul9> can't rm it
<soul9> :D
<PovAddict> too bad the contest is about hacking tahoe and not just breaking
	    it :)							[19:47]
<soul9> :D
<soul9> include that hash in the bugreport				[19:49]
<soul9> what version of tahoe are you using
<soul9> ?
<PovAddict> 1.4.1
<PovAddict> I'm currently running it under a debugger, stepping through
	    get_alias							[19:50]
<PovAddict> ok so, if the path starts with "URI: but doesn't contain ":./",
	    then get_alias returns "" for path				[19:51]
<PovAddict> and then 'assert path' explodes
<soul9> really, this is weird man					[19:52]
<soul9> i have put stuff and deleted through the cmdline and the webui and
	mixes
<soul9> never encountered this
<PovAddict> I think I got it						[19:53]
<PovAddict> but I'll upload another file and try again
<PovAddict> 'rm' seems not to be prepared to delete files out of directories...
									[20:03]
<PovAddict> hmm looks like you can't delete files actually!		[20:06]
<PovAddict> "Note that this does not actually delete the file or directory
	    that the name points to from the tahoe grid -- it only removes the
	    named reference from this directory."			[20:07]
<PovAddict> the object will just become "unreachable" (but the data still
	    there?) if no reachable directories have the file, and everybody
	    loses the readcap						[20:08]
<PovAddict> so when do shares actually disappear?			[20:10]
<soul9> i think the crawxler is the garbage collector			[20:14]
I found the following conversation log between a new user (PovAddict) and an experienced user (soul9). They are confused about what "tahoe rm" means. Possible changes that could improve this include renaming it to "tahoe unlink", improving the error messages (see below), and improving the docs. ``` <PovAddict> I just installed a tahoe client and attached it to the "volunteer grid" [19:01] ... <PovAddict> also, too many Python exceptions to take tahoe seriously... [19:17] <soul9> PovAddict: what python exceptions. [19:19] <soul9> ? <soul9> python2.6? <PovAddict> 2.5.2 <soul9> hm <soul9> i didn't have python exceptions, except deprecationwarnings in python 2.6 <PovAddict> http://pastebin.com/df3bfddf [19:20] nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe ls Traceback (most recent call last): File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module> load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')() File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run rc = runner(sys.argv[1:]) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner rc = cli.dispatch[command](so) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 380, in list rc = tahoe_ls.list(options) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_ls.py", line 18, in list rootcap, path = get_alias(aliases, where, DEFAULT_ALIAS) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/common.py", line 148, in get_alias return aliases[default], path KeyError: 'tahoe' nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe ls URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946 Traceback (most recent call last): File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module> load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')() File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run rc = runner(sys.argv[1:]) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner rc = cli.dispatch[command](so) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 380, in list rc = tahoe_ls.list(options) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_ls.py", line 67, in list childtype = child[0] KeyError: 0 nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe rm URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946 Traceback (most recent call last): File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module> load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')() File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run rc = runner(sys.argv[1:]) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner rc = cli.dispatch[command](so) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 409, in rm rc = tahoe_rm.rm(options) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_rm.py", line 25, in rm assert path AssertionError <PovAddict> I uploaded a file to the VolunteerGrid from the web interface <PovAddict> I can download it back from there, or using "tahoe get" <soul9> yes, well <PovAddict> and that's it; is 'rm' supposed to work? <soul9> i think that has to do with a not defined default rootcap [19:21] <soul9> yes, it is, of course <PovAddict> no matter what the problem really is, the command line tool should give a proper error message, instead of dumping a stacktrace... <soul9> er [19:22] <PovAddict> "KeyError: 0" might only mean something to people who know the code and know the causes of this situation <PovAddict> definitely means nothing to me <soul9> it's not dumping it's core at all <PovAddict> it printed a stacktrace on the console [19:23] <soul9> it's trying to tell you you didn't give it where to ls <soul9> no, that's warnings <soul9> if you don't want that do tahoe cmd ... blabla 2> /dev/null <PovAddict> "KeyError: 0" and "AssertionError" are not warnings, they are exceptions [19:24] <soul9> they end in error because there is nothing to ls <soul9> tahoe has no "root" <soul9> so you can't do an ls without giving it a default rootcap <PovAddict> my point is: why does it say "KeyError: 0" instead of "rootcap required"? <soul9> which is the tahoe "alias" <PovAddict> is it an argument I'm supposed to pass after 'ls'? [19:25] <soul9> well, that's a good point, and you should definitely open a bug if there isn't one allready <PovAddict> "tahoe ls something"? <soul9> tahoe ls ROOT:cap:thisisasecuretahoeurlwhateverhexblah <soul9> yeah, it's an tahoe rootcap <PovAddict> "tahoe ls --help" doesn't say there are required arguments [19:26] <soul9> so e.g. you do tahoe mkdir foo <soul9> gives you a rootcap back <soul9> then you can save the rootcap as an alias <soul9> so you don't need to remember the horridly long hash <soul9> you can give it a name <soul9> because if you add an tahoe alias <soul9> then that will be used as default <PovAddict> okay, actually, --help doesn't even mention any argument [19:27] <PovAddict> just the options <soul9> which is why it's looking for the tahoe key <PovAddict> and "tahoe <command> [command options] mkdir [options]" makes no sense :) mkdir *is* the <command> <PovAddict> anyway; what about the rm error? * soul9 → bugs <soul9> try it with a rootcap [19:28] <soul9> it'll work <soul9> tahoe is well coded for the purpose it serves <soul9> wich is uploading big files using the web ui <soul9> because the cmdline client also just uses the webui in the backend [19:29] <soul9> hell, the fuse client just uses the webui aswell <PovAddict> I don't know how I'm supposed to get that 'rootcap' <PovAddict> I uploaded a file from the web ui, now I want to delete it *** jsgf (n=jeremy@adsl-69-107-65-92.dsl.pltn13.pacbell.net) has quit: Read error: 110 (Connection timed out) <PovAddict> I have the URI I got after uploading [19:30] <soul9> that's the cap <PovAddict> and I can use it to download the file <soul9> that big hash <PovAddict> yup <soul9> so you do tahoe rm HASH <soul9> tahoe ls HASH <PovAddict> and it throws an AssertionError, as shown on my paste [19:31] <soul9> tahoe cp foo HASH:dor/you/want <soul9> hm [19:32] <soul9> dunno <soul9> worksforme™ <PovAddict> also note line 16 of paste was wrapped; I *did* pass a hash to ls <PovAddict> and it just throws a different error [19:33] <soul9> then you have a problem in your setup, or the directory is empty <soul9> iirc <PovAddict> I didn't create a directory [19:34] <PovAddict> I uploaded it from here: http://nooxie.zooko.com:9798/ using the "Upload a file" form, I didn't create a directory first [19:35] <PovAddict> unfortunately none of the shares ended up on my own node, which is kind of what I wanted to try [19:36] <PovAddict> so, now, I want to delete the file from the grid; and I only have the one hash it gave me <soul9> yeah, tahoe ls file doesn't work [19:38] <soul9> you can't ls a file <soul9> use the hash to delete it <soul9> it's as simple as tahoe rm HASH <PovAddict> I did and it throws AssertionError <PovAddict> the hash is in the pastebin; can you try rm yourself? <soul9> is the file still there tho? [19:39] <soul9> i'm not connected to the volounteer grid <soul9> i have my own ;) <PovAddict> 'check' says the file is healthy <PovAddict> Summary: Healthy <soul9> weird, it should work <PovAddict> storage index: xetcmqax6bi5eozzggamxh7gg4 [19:40] <PovAddict> good-shares: 10 (encoding is 3-of-10) <soul9> mmmm [19:41] <soul9> º what is the introducer furl to the volounteer grid? [19:42] <PovAddict> pb://6cypm5tfsv6ag43g3j5z74qx5nfxa2qq@207.7.145.200:64228,nooxie.zooko.com:64228/introducer <soul9> mm [19:45] <soul9> that's a bug! [19:46] <soul9> can't rm it <soul9> :D <PovAddict> too bad the contest is about hacking tahoe and not just breaking it :) [19:47] <soul9> :D <soul9> include that hash in the bugreport [19:49] <soul9> what version of tahoe are you using <soul9> ? <PovAddict> 1.4.1 <PovAddict> I'm currently running it under a debugger, stepping through get_alias [19:50] <PovAddict> ok so, if the path starts with "URI: but doesn't contain ":./", then get_alias returns "" for path [19:51] <PovAddict> and then 'assert path' explodes <soul9> really, this is weird man [19:52] <soul9> i have put stuff and deleted through the cmdline and the webui and mixes <soul9> never encountered this <PovAddict> I think I got it [19:53] <PovAddict> but I'll upload another file and try again <PovAddict> 'rm' seems not to be prepared to delete files out of directories... [20:03] <PovAddict> hmm looks like you can't delete files actually! [20:06] <PovAddict> "Note that this does not actually delete the file or directory that the name points to from the tahoe grid -- it only removes the named reference from this directory." [20:07] <PovAddict> the object will just become "unreachable" (but the data still there?) if no reachable directories have the file, and everybody loses the readcap [20:08] <PovAddict> so when do shares actually disappear? [20:10] <soul9> i think the crawxler is the garbage collector [20:14] ```
zooko added the
c/code-frontend-cli
p/major
t/defect
v/1.4.1
labels 2009-07-28 03:10:07 +00:00
zooko added this to the undecided milestone 2009-07-28 03:10:07 +00:00

Hmm. This is how Unix rm has always worked -- it doesn't delete a file if there is another link or open fd to it. The only difference on Tahoe is that since it uses capabilities that have a string representation, there can always be a copy of that representation somewhere.

I'm not sure that renaming it to unlink would help much. The docs could certainly be improved, though -- for example tahoe rm --help says nothing about what rm actually does! Fixing that would be easy.

Hmm. This is how Unix `rm` has always worked -- it doesn't delete a file if there is another link or open fd to it. The only difference on Tahoe is that since it uses capabilities that have a string representation, there can always be a copy of that representation somewhere. I'm not sure that renaming it to `unlink` would help much. The docs could certainly be improved, though -- for example `tahoe rm --help` says nothing about what `rm` actually does! Fixing that would be easy.
daira modified the milestone from undecided to 1.6.0 2009-12-06 17:30:45 +00:00
Author

I'm not sure "This is how unix has always done it." is a sufficient response to the criticism of "Users are confused by it.". :-)

Also, unix traditionally disallows hardlinks to directories (which Tahoe-LAFS doesn't), and also unix users traditionally abjure hardlinks and regard them as mysterious and as trouble waiting to happen.

I'm not sure "This is how unix has always done it." is a sufficient response to the criticism of "Users are confused by it.". :-) Also, unix traditionally disallows hardlinks to directories (which Tahoe-LAFS doesn't), and also unix users traditionally abjure hardlinks and regard them as mysterious and as trouble waiting to happen.

I think part of the problem has to do with how users visualize their filesystems. The notion that a file is "always there", and that a name is an inherent property of the file itself (rather than a path by which you reach the anonymous file), gets in the way.

Maybe our docs need an animated movie.. a first-person perspective that starts with a bunch of swirling blobs of ciphertext (labeled with their storage-index values), then shows your private/aliases file as a book, then shows a readcap in that book, then shows that leading to a ciphertext blob, that gets decrypted and unwraps into a directory table, with filecaps and subdircaps, then you follow a name in that table to the next node, etc. Showing somebody zooming along a link named "foo" to reach a file (that happens to be a picture or a movie or something) might help teach the idea that names are outbound links from directories, rather than inbound properties of their target files/subdirs. And having that concept firmly grounded would make it more clear why "tahoe rm" acts on directories, not files.

Or maybe I'm just looking for another excuse to learn Blender..

I think part of the problem has to do with how users visualize their filesystems. The notion that a file is "always there", and that a name is an inherent property of the file itself (rather than a path by which you reach the anonymous file), gets in the way. Maybe our docs need an animated movie.. a first-person perspective that starts with a bunch of swirling blobs of ciphertext (labeled with their storage-index values), then shows your private/aliases file as a book, then shows a readcap in that book, then shows that leading to a ciphertext blob, that gets decrypted and unwraps into a directory table, with filecaps and subdircaps, then you follow a name in that table to the next node, etc. Showing somebody zooming along a link named "foo" to reach a file (that happens to be a picture or a movie or something) might help teach the idea that names are outbound links from directories, rather than inbound properties of their target files/subdirs. And having that concept firmly grounded would make it more clear why "tahoe rm" acts on directories, not files. Or maybe I'm just looking for another excuse to learn Blender..

Replying to zooko:

I'm not sure "This is how unix has always done it." is a sufficient response to the criticism of "Users are confused by it.". :-)

Didn't intend to suggest it was. I do think this is basically a documentation bug rather than a problem with tahoe rm's behaviour, though. (A "destroy" operation as described half-way down http://allmydata.org/pipermail/tahoe-dev/2009-September/002861.html and in http://allmydata.org/pipermail/tahoe-dev/2009-October/002957.html , in contrast, would act on files, not directory entries.)

How about having rm output a message such as "n directory entries removed (rm does not delete files)."?

Replying to [zooko](/tahoe-lafs/trac/issues/776#issuecomment-373205): > I'm not sure "This is how unix has always done it." is a sufficient response to the criticism of "Users are confused by it.". :-) Didn't intend to suggest it was. I do think this is basically a documentation bug rather than a problem with `tahoe rm`'s behaviour, though. (A "destroy" operation as described half-way down <http://allmydata.org/pipermail/tahoe-dev/2009-September/002861.html> and in <http://allmydata.org/pipermail/tahoe-dev/2009-October/002957.html> , in contrast, would act on files, not directory entries.) How about having `rm` output a message such as "*n* directory entries removed (rm does not delete files)."?
daira self-assigned this 2009-12-20 01:08:15 +00:00
Author

David-Sarah: I like your suggestion about the output message!

Brian: I've been teaching Irby unix. I explained that he is in a room, and he can use the following spells: the "look and see" spell, which is performed with the magical incantation "ls", to see what is in the room, the "cross door" spell, incantation "cd" to exit the room through the door with the given sign on it, and the "vigorously interact" spell, incantation "vi" to pick up and use one of the scrolls that are lying around. Also he eventually learned the "copy" spell ("cp").

Therefore, it has always been perfectly intuitive to Irby that rooms don't have signs on them -- doors do -- and that different doors can lead into the same room, and so on. :-)

David-Sarah: I like your suggestion about the output message! Brian: I've been teaching Irby unix. I explained that he is in a room, and he can use the following spells: the "look and see" spell, which is performed with the magical incantation "ls", to see what is in the room, the "cross door" spell, incantation "cd" to exit the room through the door with the given sign on it, and the "vigorously interact" spell, incantation "vi" to pick up and use one of the scrolls that are lying around. Also he eventually learned the "copy" spell ("cp"). Therefore, it has always been perfectly intuitive to Irby that rooms don't have signs on them -- doors do -- and that different doors can lead into the same room, and so on. :-)

Replying to zooko:

David-Sarah: I like your suggestion about the output message!

Will do. I should have time to work on the bugs assigned to me in the next few days. (Off-topic for this bug, but is there a target date for the 1.6 release?)

Brian: I've been teaching Irby unix.

... and you're also teaching him reference/capability semantics in general :-)

Replying to [zooko](/tahoe-lafs/trac/issues/776#issuecomment-373209): > David-Sarah: I like your suggestion about the output message! Will do. I should have time to work on the bugs assigned to me in the next few days. (Off-topic for this bug, but is there a target date for the 1.6 release?) > Brian: I've been teaching Irby unix. ... and you're also teaching him reference/capability semantics in general :-)
zooko modified the milestone from 1.6.0 to eventually 2010-01-26 15:44:21 +00:00
daira modified the milestone from eventually to 1.7.0 2010-02-01 19:42:00 +00:00
kevan commented 2010-02-19 17:20:42 +00:00
Owner

It'd also be nice if this:

nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe rm URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946
      Traceback (most recent call last):
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module>
          load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')()
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run
          rc = runner(sys.argv[1:])
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner
          rc = cli.dispatch[command](so)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 409, in rm
          rc = tahoe_rm.rm(options)
        File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_rm.py", line 25, in rm
          assert path
      AssertionError

said something like this:

nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe rm URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946
error: 'tahoe rm' can only be used to unlink a file within a directory. Please specify the file that you wish to unlink as alias:path/to/file.

or something similar. Users are rightly confused if our CLI tools output stack traces instead of meaningful error messages; see http://allmydata.org/pipermail/tahoe-dev/2010-February/003950.html for a recent example.

(the first exception message should have been fixed in #939; the second in #771)

It'd also be nice if this: ``` nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe rm URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946 Traceback (most recent call last): File "/home/nicolas/src/allmydata-tahoe-1.4.1/support/bin/tahoe", line 8, in <module> load_entry_point('allmydata-tahoe==1.4.1', 'console_scripts', 'tahoe')() File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 91, in run rc = runner(sys.argv[1:]) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/runner.py", line 78, in runner rc = cli.dispatch[command](so) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/cli.py", line 409, in rm rc = tahoe_rm.rm(options) File "/home/nicolas/src/allmydata-tahoe-1.4.1/src/allmydata/scripts/tahoe_rm.py", line 25, in rm assert path AssertionError ``` said something like this: ``` nicolas@ubuntu /tmp/tahoe-c$ ~/src/allmydata-tahoe-1.4.1/bin/tahoe rm URI:CHK:2nxmn6eew3y5e5y7ejzwfr2jiq:6mi2hcbpuvkfcttuezi4x3fxwrnmwidql2rtwwtczpccxgz3ez2q:3:10:310946 error: 'tahoe rm' can only be used to unlink a file within a directory. Please specify the file that you wish to unlink as alias:path/to/file. ``` or something similar. Users are rightly confused if our CLI tools output stack traces instead of meaningful error messages; see <http://allmydata.org/pipermail/tahoe-dev/2010-February/003950.html> for a recent example. (the first exception message should have been fixed in #939; the second in #771)
daira modified the milestone from 1.7.0 to 1.7.1 2010-06-12 20:57:52 +00:00

Related to #1104 (the button to unlink a child from a directory should not be labelled "del")

Related to #1104 (the button to unlink a child from a directory should not be labelled "del")

Attachment tahoe-unlink-alias.dpatch (7366 bytes) added

CLI: add 'tahoe unlink' as an alias to 'tahoe rm', for forward-compatibility.

**Attachment** tahoe-unlink-alias.dpatch (7366 bytes) added CLI: add 'tahoe unlink' as an alias to 'tahoe rm', for forward-compatibility.

My suggestion is to add tahoe unlink as an alias in 1.7.1, and then remove tahoe rm in 1.8.0.

(A minor nit with the patch is that tahoe unlink --help gives its synopsis as tahoe rm REMOTE_FILE, but I don't think that matters.)

My suggestion is to add `tahoe unlink` as an alias in 1.7.1, and then remove `tahoe rm` in 1.8.0. (A minor nit with the patch is that `tahoe unlink --help` gives its synopsis as `tahoe rm REMOTE_FILE`, but I don't think that matters.)
Author

I don't at this time agree to remove tahoe rm as soon as 1.8.0. However, I reviewed the patch and it looked good.

I don't at this time agree to remove `tahoe rm` as soon as 1.8.0. However, I reviewed the patch and it looked good.

tahoe-unlink-alias.dpatch (actually a slightly different version with changes to NEWS and CREDITS) applied in changeset:809078571610ad93.

tahoe-unlink-alias.dpatch (actually a slightly different version with changes to NEWS and CREDITS) applied in changeset:809078571610ad93.

We can make the documentation and code use 'unlink' for 1.8 (or 1.8beta), but leave tahoe rm as an alias until some future version.

We can make the documentation and code use 'unlink' for 1.8 (or 1.8beta), but leave `tahoe rm` as an alias until some future version.
daira modified the milestone from 1.7.1 to 1.8β 2010-07-17 22:43:51 +00:00

Replying to davidsarah:

tahoe-unlink-alias.dpatch (actually a slightly different version with changes to NEWS and CREDITS) applied in changeset:809078571610ad93.

This patch had been manually edited and so applied incorrectly. Fixed in changeset:0d79a4a7d14e4689 (which should refer to this ticket, not #1072).

Replying to [davidsarah](/tahoe-lafs/trac/issues/776#issuecomment-373218): > tahoe-unlink-alias.dpatch (actually a slightly different version with changes to NEWS and CREDITS) applied in changeset:809078571610ad93. This patch had been manually edited and so applied incorrectly. Fixed in changeset:0d79a4a7d14e4689 (which should refer to this ticket, not #1072).

The 'tahoe unlink' alias is in place; doc changes are for 1.9.

The 'tahoe unlink' alias is in place; doc changes are for 1.9.
daira modified the milestone from 1.8β to 1.9.0 2010-09-11 00:35:50 +00:00

Attachment rm-unlink-cleanup.darcs.patch (37832 bytes) added

cleanup: implement rm as a synonym for unlink rather than vice-versa. refs #776 (This depends on the patch for #1359.)

**Attachment** rm-unlink-cleanup.darcs.patch (37832 bytes) added cleanup: implement rm as a synonym for unlink rather than vice-versa. refs #776 (This depends on the patch for #1359.)
daira removed their assignment 2011-07-25 00:16:46 +00:00
kevan commented 2011-08-01 18:03:07 +00:00
Owner

There's a conflict between this patch and trunk: darcs doesn't know what to do about the _create_test_file function in test_cli.Rm.

On my system, test_cli.py tries to import tahoe_rm, which isn't there anymore, and also tries to quiet pyflakes for tahoe_rm. I changed these to tahoe_unlink; without that, the CLI tests don't run.

There's a test in test_cli.Unlink, test_rm_without_path, that still refers to the rm command. I'm not sure if that's an oversight; to me, it seems like it'd be more consistent if it used unlink terminology.

Is it worthwhile to test that tahoe rm behaves like tahoe unlink? Unless I'm mistaken, the only test we have of that is the one that is left with rm terminology in the Unlink class.

The error message on line 26 of tahoe_unlink.py still refers to tahoe rm.

Not particularly related to this ticket, save for the fact that the patches were in the same bundle, but you missed a couple of places when adding the self.command_name value:

  • CpOptions in cli.py
  • CreateKeyGeneratorOptions in keygen.py
  • CreateStatsGathererOptions in stats_gatherer.py
There's a conflict between this patch and trunk: darcs doesn't know what to do about the `_create_test_file` function in `test_cli.Rm`. On my system, `test_cli.py` tries to import `tahoe_rm`, which isn't there anymore, and also tries to quiet pyflakes for `tahoe_rm`. I changed these to `tahoe_unlink`; without that, the CLI tests don't run. There's a test in `test_cli.Unlink`, `test_rm_without_path`, that still refers to the `rm` command. I'm not sure if that's an oversight; to me, it seems like it'd be more consistent if it used unlink terminology. Is it worthwhile to test that `tahoe rm` behaves like `tahoe unlink`? Unless I'm mistaken, the only test we have of that is the one that is left with `rm` terminology in the `Unlink` class. The error message on line 26 of `tahoe_unlink.py` still refers to `tahoe rm`. Not particularly related to this ticket, save for the fact that the patches were in the same bundle, but you missed a couple of places when adding the `self.command_name` value: * `CpOptions` in `cli.py` * `CreateKeyGeneratorOptions` in `keygen.py` * `CreateStatsGathererOptions` in `stats_gatherer.py`

In changeset:06a5d0c1a3135b8c:

cleanup: implement rm as a synonym for unlink rather than vice-versa. refs #776
In changeset:06a5d0c1a3135b8c: ``` cleanup: implement rm as a synonym for unlink rather than vice-versa. refs #776 ```

In changeset:9ba8a1b83e3d598e:

docs/frontends/webapi.rst: change some more instances of 'delete' or 'remove' to 'unlink', change some section titles, and use two blank lines between all sections. refs #776, #1104
In changeset:9ba8a1b83e3d598e: ``` docs/frontends/webapi.rst: change some more instances of 'delete' or 'remove' to 'unlink', change some section titles, and use two blank lines between all sections. refs #776, #1104 ```

In changeset:2da3f69f25645ca6:

Address Kevan's comment in #776 about Options classes missed when adding 'self.command_name'. refs #776, #1359
In changeset:2da3f69f25645ca6: ``` Address Kevan's comment in #776 about Options classes missed when adding 'self.command_name'. refs #776, #1359 ```

For 1.10, I want to implement the output message suggestion I made in comment:4.

For 1.10, I want to implement the output message suggestion I made in comment:4.
daira modified the milestone from 1.9.0 to 1.10.0 2011-08-14 01:11:39 +00:00
Author

Okay here are all the ideas on this ticket for how to improve this. The ones we've already done are marked with strikethru.

  • Make an animated 3D movie showing how to traverse and manipulate a Tahoe-LAFS filesystem (comment:373206).
  • Teach your children unix/capabilities/reference semantics in terms of a text-based dungeon crawling adventure (comment:373209).
  • Add a command named tahoe unlink and make it be the primary documented command (comment:373216).
  • Have tahoe rm or tahoe unlink output a message such as "n directory entries removed (tahoe unlink does not delete files)." (comment:4).
  • Make tahoe rm $CAP or tahoe unlink $CAP emit a nice and explanatory error message instead of a mysterious stack trace. (comment:373213)
  • Remove the tahoe rm command now that tahoe unlink has been the primary documented command for a couple of major releases (comment:373216).

The ones that we haven't done yet are still good ideas! Maybe we should open separate tickets for them since they are separately closeable and then people will be able to better remember to do them.

Okay here are all the ideas on this ticket for how to improve this. The ones we've already done are marked with ~~strikethru~~. * Make an animated 3D movie showing how to traverse and manipulate a Tahoe-LAFS filesystem ([comment:373206](/tahoe-lafs/trac/issues/776#issuecomment-373206)). * ~~Teach your children unix/capabilities/reference semantics in terms of a text-based dungeon crawling adventure ([comment:373209](/tahoe-lafs/trac/issues/776#issuecomment-373209)).~~ * ~~Add a command named `tahoe unlink` and make it be the primary documented command ([comment:373216](/tahoe-lafs/trac/issues/776#issuecomment-373216)).~~ * Have `tahoe rm` or `tahoe unlink` output a message such as "n directory entries removed (`tahoe unlink` does not delete files)." (comment:4). * Make `tahoe rm $CAP` or `tahoe unlink $CAP` emit a nice and explanatory error message instead of a mysterious stack trace. ([comment:373213](/tahoe-lafs/trac/issues/776#issuecomment-373213)) * Remove the `tahoe rm` command now that `tahoe unlink` has been the primary documented command for a couple of major releases ([comment:373216](/tahoe-lafs/trac/issues/776#issuecomment-373216)). The ones that we haven't done yet are still good ideas! Maybe we should open separate tickets for them since they are separately closeable and then people will be able to better remember to do them.

Replying to zooko:

Okay here are all the ideas on this ticket for how to improve this. The ones we've already done are marked with strikethru.
[...]

  • Make tahoe rm $CAP or tahoe unlink $CAP emit a nice and explanatory error message instead of a mysterious stack trace. (comment:373213)

This was fixed in #695 / #1292. The message is

'tahoe unlink' can only unlink directory entries, so a path must be given.

(It says 'tahoe rm' if invoked as that.)

Replying to [zooko](/tahoe-lafs/trac/issues/776#issuecomment-373217): > Okay here are all the ideas on this ticket for how to improve this. The ones we've already done are marked with ~~strikethru~~. [...] > * ~~Make `tahoe rm $CAP` or `tahoe unlink $CAP` emit a nice and explanatory error message instead of a mysterious stack trace. ([comment:373213](/tahoe-lafs/trac/issues/776#issuecomment-373213))~~ This was fixed in #695 / #1292. The message is ``` 'tahoe unlink' can only unlink directory entries, so a path must be given. ``` (It says `'tahoe rm'` if invoked as that.)
Author

Okay, now, per comment:373219, another one is checked off. I'm opening new tickets for the remaining tasks. Remaining to do:

  • Make an animated 3D movie showing how to traverse and manipulate a Tahoe-LAFS filesystem (comment:373206) (#1826).
  • Teach your children unix/capabilities/reference semantics in terms of a text-based dungeon crawling adventure (comment:373209).
  • Add a command named tahoe unlink and make it be the primary documented command (comment:373216).
  • Have tahoe rm or tahoe unlink output a message such as "n directory entries removed (tahoe unlink does not delete files)." (comment:4) (#1825).
  • Make tahoe rm $CAP or tahoe unlink $CAP emit a nice and explanatory error message instead of a mysterious stack trace. (comment:373213)
  • Remove the tahoe rm command now that tahoe unlink has been the primary documented command for a couple of major releases (comment:373216). (#1827).
Okay, now, per [comment:373219](/tahoe-lafs/trac/issues/776#issuecomment-373219), another one is checked off. I'm opening new tickets for the remaining tasks. Remaining to do: * Make an animated 3D movie showing how to traverse and manipulate a Tahoe-LAFS filesystem ([comment:373206](/tahoe-lafs/trac/issues/776#issuecomment-373206)) (#1826). * ~~Teach your children unix/capabilities/reference semantics in terms of a text-based dungeon crawling adventure ([comment:373209](/tahoe-lafs/trac/issues/776#issuecomment-373209)).~~ * ~~Add a command named `tahoe unlink` and make it be the primary documented command ([comment:373216](/tahoe-lafs/trac/issues/776#issuecomment-373216)).~~ * Have `tahoe rm` or `tahoe unlink` output a message such as "n directory entries removed (`tahoe unlink` does not delete files)." (comment:4) (#1825). * ~~Make `tahoe rm $CAP` or `tahoe unlink $CAP` emit a nice and explanatory error message instead of a mysterious stack trace. ([comment:373213](/tahoe-lafs/trac/issues/776#issuecomment-373213))~~ * Remove the `tahoe rm` command now that `tahoe unlink` has been the primary documented command for a couple of major releases ([comment:373216](/tahoe-lafs/trac/issues/776#issuecomment-373216)). (#1827).
Author

I've opened new tickets to hold all the unfinished tasks, closing this one.

I've opened new tickets to hold all the unfinished tasks, closing this one.
zooko added the
r/fixed
label 2012-10-15 23:44:46 +00:00
zooko modified the milestone from 1.11.0 to 1.9.0 2012-10-15 23:44:46 +00:00
zooko closed this issue 2012-10-15 23:44:46 +00:00
Sign in to join this conversation.
No labels
c/code
c/code-dirnodes
c/code-encoding
c/code-frontend
c/code-frontend-cli
c/code-frontend-ftp-sftp
c/code-frontend-magic-folder
c/code-frontend-web
c/code-mutable
c/code-network
c/code-nodeadmin
c/code-peerselection
c/code-storage
c/contrib
c/dev-infrastructure
c/docs
c/operational
c/packaging
c/unknown
c/website
kw:2pc
kw:410
kw:9p
kw:ActivePerl
kw:AttributeError
kw:DataUnavailable
kw:DeadReferenceError
kw:DoS
kw:FileZilla
kw:GetLastError
kw:IFinishableConsumer
kw:K
kw:LeastAuthority
kw:Makefile
kw:RIStorageServer
kw:StringIO
kw:UncoordinatedWriteError
kw:about
kw:access
kw:access-control
kw:accessibility
kw:accounting
kw:accounting-crawler
kw:add-only
kw:aes
kw:aesthetics
kw:alias
kw:aliases
kw:aliens
kw:allmydata
kw:amazon
kw:ambient
kw:annotations
kw:anonymity
kw:anonymous
kw:anti-censorship
kw:api_auth_token
kw:appearance
kw:appname
kw:apport
kw:archive
kw:archlinux
kw:argparse
kw:arm
kw:assertion
kw:attachment
kw:auth
kw:authentication
kw:automation
kw:avahi
kw:availability
kw:aws
kw:azure
kw:backend
kw:backoff
kw:backup
kw:backupdb
kw:backward-compatibility
kw:bandwidth
kw:basedir
kw:bayes
kw:bbfreeze
kw:beta
kw:binaries
kw:binutils
kw:bitcoin
kw:bitrot
kw:blacklist
kw:blocker
kw:blocks-cloud-deployment
kw:blocks-cloud-merge
kw:blocks-magic-folder-merge
kw:blocks-merge
kw:blocks-raic
kw:blocks-release
kw:blog
kw:bom
kw:bonjour
kw:branch
kw:branding
kw:breadcrumbs
kw:brians-opinion-needed
kw:browser
kw:bsd
kw:build
kw:build-helpers
kw:buildbot
kw:builders
kw:buildslave
kw:buildslaves
kw:cache
kw:cap
kw:capleak
kw:captcha
kw:cast
kw:centos
kw:cffi
kw:chacha
kw:charset
kw:check
kw:checker
kw:chroot
kw:ci
kw:clean
kw:cleanup
kw:cli
kw:cloud
kw:cloud-backend
kw:cmdline
kw:code
kw:code-checks
kw:coding-standards
kw:coding-tools
kw:coding_tools
kw:collection
kw:compatibility
kw:completion
kw:compression
kw:confidentiality
kw:config
kw:configuration
kw:configuration.txt
kw:conflict
kw:connection
kw:connectivity
kw:consistency
kw:content
kw:control
kw:control.furl
kw:convergence
kw:coordination
kw:copyright
kw:corruption
kw:cors
kw:cost
kw:coverage
kw:coveralls
kw:coveralls.io
kw:cpu-watcher
kw:cpyext
kw:crash
kw:crawler
kw:crawlers
kw:create-container
kw:cruft
kw:crypto
kw:cryptography
kw:cryptography-lib
kw:cryptopp
kw:csp
kw:curl
kw:cutoff-date
kw:cycle
kw:cygwin
kw:d3
kw:daemon
kw:darcs
kw:darcsver
kw:database
kw:dataloss
kw:db
kw:dead-code
kw:deb
kw:debian
kw:debug
kw:deep-check
kw:defaults
kw:deferred
kw:delete
kw:deletion
kw:denial-of-service
kw:dependency
kw:deployment
kw:deprecation
kw:desert-island
kw:desert-island-build
kw:design
kw:design-review-needed
kw:detection
kw:dev-infrastructure
kw:devpay
kw:directory
kw:directory-page
kw:dirnode
kw:dirnodes
kw:disconnect
kw:discovery
kw:disk
kw:disk-backend
kw:distribute
kw:distutils
kw:dns
kw:do_http
kw:doc-needed
kw:docker
kw:docs
kw:docs-needed
kw:dokan
kw:dos
kw:download
kw:downloader
kw:dragonfly
kw:drop-upload
kw:duplicity
kw:dusty
kw:earth-dragon
kw:easy
kw:ec2
kw:ecdsa
kw:ed25519
kw:egg-needed
kw:eggs
kw:eliot
kw:email
kw:empty
kw:encoding
kw:endpoint
kw:enterprise
kw:enum34
kw:environment
kw:erasure
kw:erasure-coding
kw:error
kw:escaping
kw:etag
kw:etch
kw:evangelism
kw:eventual
kw:example
kw:excess-authority
kw:exec
kw:exocet
kw:expiration
kw:extensibility
kw:extension
kw:failure
kw:fedora
kw:ffp
kw:fhs
kw:figleaf
kw:file
kw:file-descriptor
kw:filename
kw:filesystem
kw:fileutil
kw:fips
kw:firewall
kw:first
kw:floatingpoint
kw:flog
kw:foolscap
kw:forward-compatibility
kw:forward-secrecy
kw:forwarding
kw:free
kw:freebsd
kw:frontend
kw:fsevents
kw:ftp
kw:ftpd
kw:full
kw:furl
kw:fuse
kw:garbage
kw:garbage-collection
kw:gateway
kw:gatherer
kw:gc
kw:gcc
kw:gentoo
kw:get
kw:git
kw:git-annex
kw:github
kw:glacier
kw:globalcaps
kw:glossary
kw:google-cloud-storage
kw:google-drive-backend
kw:gossip
kw:governance
kw:grid
kw:grid-manager
kw:gridid
kw:gridsync
kw:grsec
kw:gsoc
kw:gvfs
kw:hackfest
kw:hacktahoe
kw:hang
kw:hardlink
kw:heartbleed
kw:heisenbug
kw:help
kw:helper
kw:hint
kw:hooks
kw:how
kw:how-to
kw:howto
kw:hp
kw:hp-cloud
kw:html
kw:http
kw:https
kw:i18n
kw:i2p
kw:i2p-collab
kw:illustration
kw:image
kw:immutable
kw:impressions
kw:incentives
kw:incident
kw:init
kw:inlineCallbacks
kw:inotify
kw:install
kw:installer
kw:integration
kw:integration-test
kw:integrity
kw:interactive
kw:interface
kw:interfaces
kw:interoperability
kw:interstellar-exploration
kw:introducer
kw:introduction
kw:iphone
kw:ipkg
kw:iputil
kw:ipv6
kw:irc
kw:jail
kw:javascript
kw:joke
kw:jquery
kw:json
kw:jsui
kw:junk
kw:key-value-store
kw:kfreebsd
kw:known-issue
kw:konqueror
kw:kpreid
kw:kvm
kw:l10n
kw:lae
kw:large
kw:latency
kw:leak
kw:leasedb
kw:leases
kw:libgmp
kw:license
kw:licenss
kw:linecount
kw:link
kw:linux
kw:lit
kw:localhost
kw:location
kw:locking
kw:logging
kw:logo
kw:loopback
kw:lucid
kw:mac
kw:macintosh
kw:magic-folder
kw:manhole
kw:manifest
kw:manual-test-needed
kw:map
kw:mapupdate
kw:max_space
kw:mdmf
kw:memcheck
kw:memory
kw:memory-leak
kw:mesh
kw:metadata
kw:meter
kw:migration
kw:mime
kw:mingw
kw:minimal
kw:misc
kw:miscapture
kw:mlp
kw:mock
kw:more-info-needed
kw:mountain-lion
kw:move
kw:multi-users
kw:multiple
kw:multiuser-gateway
kw:munin
kw:music
kw:mutability
kw:mutable
kw:mystery
kw:names
kw:naming
kw:nas
kw:navigation
kw:needs-review
kw:needs-spawn
kw:netbsd
kw:network
kw:nevow
kw:new-user
kw:newcaps
kw:news
kw:news-done
kw:news-needed
kw:newsletter
kw:newurls
kw:nfc
kw:nginx
kw:nixos
kw:no-clobber
kw:node
kw:node-url
kw:notification
kw:notifyOnDisconnect
kw:nsa310
kw:nsa320
kw:nsa325
kw:numpy
kw:objects
kw:old
kw:openbsd
kw:openitp-packaging
kw:openssl
kw:openstack
kw:opensuse
kw:operation-helpers
kw:operational
kw:operations
kw:ophandle
kw:ophandles
kw:ops
kw:optimization
kw:optional
kw:options
kw:organization
kw:os
kw:os.abort
kw:ostrom
kw:osx
kw:osxfuse
kw:otf-magic-folder-objective1
kw:otf-magic-folder-objective2
kw:otf-magic-folder-objective3
kw:otf-magic-folder-objective4
kw:otf-magic-folder-objective5
kw:otf-magic-folder-objective6
kw:p2p
kw:packaging
kw:partial
kw:password
kw:path
kw:paths
kw:pause
kw:peer-selection
kw:performance
kw:permalink
kw:permissions
kw:persistence
kw:phone
kw:pickle
kw:pip
kw:pipermail
kw:pkg_resources
kw:placement
kw:planning
kw:policy
kw:port
kw:portability
kw:portal
kw:posthook
kw:pratchett
kw:preformance
kw:preservation
kw:privacy
kw:process
kw:profile
kw:profiling
kw:progress
kw:proxy
kw:publish
kw:pyOpenSSL
kw:pyasn1
kw:pycparser
kw:pycrypto
kw:pycrypto-lib
kw:pycryptopp
kw:pyfilesystem
kw:pyflakes
kw:pylint
kw:pypi
kw:pypy
kw:pysqlite
kw:python
kw:python3
kw:pythonpath
kw:pyutil
kw:pywin32
kw:quickstart
kw:quiet
kw:quotas
kw:quoting
kw:raic
kw:rainhill
kw:random
kw:random-access
kw:range
kw:raspberry-pi
kw:reactor
kw:readonly
kw:rebalancing
kw:recovery
kw:recursive
kw:redhat
kw:redirect
kw:redressing
kw:refactor
kw:referer
kw:referrer
kw:regression
kw:rekey
kw:relay
kw:release
kw:release-blocker
kw:reliability
kw:relnotes
kw:remote
kw:removable
kw:removable-disk
kw:rename
kw:renew
kw:repair
kw:replace
kw:report
kw:repository
kw:research
kw:reserved_space
kw:response-needed
kw:response-time
kw:restore
kw:retrieve
kw:retry
kw:review
kw:review-needed
kw:reviewed
kw:revocation
kw:roadmap
kw:rollback
kw:rpm
kw:rsa
kw:rss
kw:rst
kw:rsync
kw:rusty
kw:s3
kw:s3-backend
kw:s3-frontend
kw:s4
kw:same-origin
kw:sandbox
kw:scalability
kw:scaling
kw:scheduling
kw:schema
kw:scheme
kw:scp
kw:scripts
kw:sdist
kw:sdmf
kw:security
kw:self-contained
kw:server
kw:servermap
kw:servers-of-happiness
kw:service
kw:setup
kw:setup.py
kw:setup_requires
kw:setuptools
kw:setuptools_darcs
kw:sftp
kw:shared
kw:shareset
kw:shell
kw:signals
kw:simultaneous
kw:six
kw:size
kw:slackware
kw:slashes
kw:smb
kw:sneakernet
kw:snowleopard
kw:socket
kw:solaris
kw:space
kw:space-efficiency
kw:spam
kw:spec
kw:speed
kw:sqlite
kw:ssh
kw:ssh-keygen
kw:sshfs
kw:ssl
kw:stability
kw:standards
kw:start
kw:startup
kw:static
kw:static-analysis
kw:statistics
kw:stats
kw:stats_gatherer
kw:status
kw:stdeb
kw:storage
kw:streaming
kw:strports
kw:style
kw:stylesheet
kw:subprocess
kw:sumo
kw:survey
kw:svg
kw:symlink
kw:synchronous
kw:tac
kw:tahoe-*
kw:tahoe-add-alias
kw:tahoe-admin
kw:tahoe-archive
kw:tahoe-backup
kw:tahoe-check
kw:tahoe-cp
kw:tahoe-create-alias
kw:tahoe-create-introducer
kw:tahoe-debug
kw:tahoe-deep-check
kw:tahoe-deepcheck
kw:tahoe-lafs-trac-stream
kw:tahoe-list-aliases
kw:tahoe-ls
kw:tahoe-magic-folder
kw:tahoe-manifest
kw:tahoe-mkdir
kw:tahoe-mount
kw:tahoe-mv
kw:tahoe-put
kw:tahoe-restart
kw:tahoe-rm
kw:tahoe-run
kw:tahoe-start
kw:tahoe-stats
kw:tahoe-unlink
kw:tahoe-webopen
kw:tahoe.css
kw:tahoe_files
kw:tahoewapi
kw:tarball
kw:tarballs
kw:tempfile
kw:templates
kw:terminology
kw:test
kw:test-and-set
kw:test-from-egg
kw:test-needed
kw:testgrid
kw:testing
kw:tests
kw:throttling
kw:ticket999-s3-backend
kw:tiddly
kw:time
kw:timeout
kw:timing
kw:to
kw:to-be-closed-on-2011-08-01
kw:tor
kw:tor-protocol
kw:torsocks
kw:tox
kw:trac
kw:transparency
kw:travis
kw:travis-ci
kw:trial
kw:trickle
kw:trivial
kw:truckee
kw:tub
kw:tub.location
kw:twine
kw:twistd
kw:twistd.log
kw:twisted
kw:twisted-14
kw:twisted-trial
kw:twitter
kw:twn
kw:txaws
kw:type
kw:typeerror
kw:ubuntu
kw:ucwe
kw:ueb
kw:ui
kw:unclean
kw:uncoordinated-writes
kw:undeletable
kw:unfinished-business
kw:unhandled-error
kw:unhappy
kw:unicode
kw:unit
kw:unix
kw:unlink
kw:update
kw:upgrade
kw:upload
kw:upload-helper
kw:uri
kw:url
kw:usability
kw:use-case
kw:utf-8
kw:util
kw:uwsgi
kw:ux
kw:validation
kw:variables
kw:vdrive
kw:verify
kw:verlib
kw:version
kw:versioning
kw:versions
kw:video
kw:virtualbox
kw:virtualenv
kw:vista
kw:visualization
kw:visualizer
kw:vm
kw:volunteergrid2
kw:volunteers
kw:vpn
kw:wapi
kw:warners-opinion-needed
kw:warning
kw:weapi
kw:web
kw:web.port
kw:webapi
kw:webdav
kw:webdrive
kw:webport
kw:websec
kw:website
kw:websocket
kw:welcome
kw:welcome-page
kw:welcomepage
kw:wiki
kw:win32
kw:win64
kw:windows
kw:windows-related
kw:winscp
kw:workaround
kw:world-domination
kw:wrapper
kw:write-enabler
kw:wui
kw:x86
kw:x86-64
kw:xhtml
kw:xml
kw:xss
kw:zbase32
kw:zetuptoolz
kw:zfec
kw:zookos-opinion-needed
kw:zope
kw:zope.interface
p/blocker
p/critical
p/major
p/minor
p/normal
p/supercritical
p/trivial
r/cannot reproduce
r/duplicate
r/fixed
r/invalid
r/somebody else's problem
r/was already fixed
r/wontfix
r/worksforme
t/defect
t/enhancement
t/task
v/0.2.0
v/0.3.0
v/0.4.0
v/0.5.0
v/0.5.1
v/0.6.0
v/0.6.1
v/0.7.0
v/0.8.0
v/0.9.0
v/1.0.0
v/1.1.0
v/1.10.0
v/1.10.1
v/1.10.2
v/1.10a2
v/1.11.0
v/1.12.0
v/1.12.1
v/1.13.0
v/1.14.0
v/1.15.0
v/1.15.1
v/1.2.0
v/1.3.0
v/1.4.1
v/1.5.0
v/1.6.0
v/1.6.1
v/1.7.0
v/1.7.1
v/1.7β
v/1.8.0
v/1.8.1
v/1.8.2
v/1.8.3
v/1.8β
v/1.9.0
v/1.9.0-s3branch
v/1.9.0a1
v/1.9.0a2
v/1.9.0b1
v/1.9.1
v/1.9.2
v/1.9.2a1
v/cloud-branch
v/unknown
No milestone
No project
No assignees
4 participants
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".

No due date set.

Dependencies

No dependencies set.

Reference: tahoe-lafs/trac#776
No description provided.