I have a gripe about the fread() business - I have to hit ^D twice
before eof is reported - the first ^D causes fread() to return non-zero,
with text I entered previously, the second ^D causes fread() to return 0.
Probably not a major problem but here's a patch if anyone's interested.

Also rm.c
I don't think it has any problems with symlinks, but I accept no
responsibility for your lost home directory, anime collection or
childhood memories.  I've never ever found a use for -f, it's just a
pain having rm prompt me, so I've assumed an always present -f. Stick it
in if you're going for posix or whatever though.

One more thing, we're not bothering with the -- flag, are we?

> but I'm quite busy with exams atm.
UK, right? Up late coding even with exams, I'm impressed.

Finally, I have an editor in the works, unfinished, but I plan to show
you lot at some point though</vapourware>.

Cheers,
Rob.

Attachment: fread.diff
Description: plain/text

/* See LICENSE file for copyright and license details. */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>
#include <sys/types.h>
#include <dirent.h>
#include "util.h"

int rflag = 0;

void rm(const char *);

int
main(int argc, char *argv[])
{
	int i;

	if(argc == 1)
		eprintf("usage: %s [-r] files...\n", argv[0]);

	for(i = 1; i < argc; i++) {
		if(!strcmp(argv[i], "-r"))
			rflag = 1;
		else
			rm(argv[i]);
	}
	return EXIT_SUCCESS;
}

void rm(const char *path)
{
	if(remove(path) == -1){
		if(errno == ENOTEMPTY && rflag){
			DIR *d = opendir(path);
			struct dirent *ent;
			char prev[BUFSIZ];

			if(!getcwd(prev, sizeof prev))
				eprintf("getcwd:");
			if(chdir(path))
				eprintf("chdir %s:", path);

			while((ent = readdir(d)))
				if(strcmp(ent->d_name, "..") && strcmp(ent->d_name, "."))
					rm(ent->d_name);

			closedir(d);
			if(chdir(prev) == -1)
				eprintf("chdir %s:", prev);

			if(remove(path) == -1)
				eprintf("remove %s:", path);
		}else
			eprintf("remove %s:", path);
	}
}

Attachment: rm.1
Description: Binary data

Reply via email to