Interesting how a Windows command prompt exhibits similar behavior with ./ and ../ as does *nix.
I don't think that's a coincidence. DOS (and later windows) borrowed from UNIX in this respect.
But UNIX does it right in my opinion. When you create a directory (at the system call level) the directory automatically gets two entries:
. // This is a hard link to the current directory
.. // This is a hard link to the parent directory.
So there's no special code to use these directory entries, they simply EXIST. The only exception is the root directory, which has no .. entry.
But UNIX does it right in my opinion. When you create a directory (at the system call level) the directory automatically gets two entries:
. // This is a hard link to the current directory
.. // This is a hard link to the parent directory.
So there's no special code to use these directory entries, they simply EXIST. The only exception is the root directory, which has no .. entry.
I don't really understand the difference. "." and ".." are valid on any directory in Windows, as well (except on a drive's root, or the kernel's directory tree root).
I think the difference is that you could in UNIX create a different directory called '.' and make it point wherever you want. The UNIX directories are really just links without any special significance other than the fact that they are automatically created for you, whereas in Windows they are handled specially by the directory parser.
At least that's my understanding; maybe Windows also creates those as directories and handles them the same way, I haven't checked.
In both nix and Windows . and .. are special entries in the directory table managed by the OS file system kernel. You cannot modify them to point somewhere else without first doing some damage to the OS.
Well "you" as in root may be able to change the meaning of . with a tool like debugfs
That's an interesting idea! You're probably right, but I suspect it would put the system into a tailspin. Lots of progams probably assume that "." is the current directory. The filesystem check program fsck would almost certainly flag and correct this.