view target-utils/libtiffs/basicfind.c @ 965:2969032bdfac

fcup-smsend[mult]: fix buglet in K&R C NULL pointer passing The only 100% safe way to pass a NULL pointer as a function argument in K&R C is to cast 0 to a pointer type; failing to do so may cause mysterious bugs (invalid stack frames or garbage in argument registers) on 64-bit machines. This issue has already been fixed in most of FC host tools, but I just found some missed spots: passing of NULL UDH to PDU encoding functions in fcup-smsend[mult] in the case of single (not concatenated) SMS.
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 01 Sep 2023 07:33:51 +0000
parents 87cb03b35f77
children
line wrap: on
line source

#include <sys/types.h>
#include "types.h"
#include "struct.h"
#include "globals.h"
#include "macros.h"

extern char *index();

static
find_named_child(start, seekname)
	char *seekname;
{
	int ino;
	struct inode *irec;

	for (ino = start; ino != 0xFFFF; ino = irec->sibling) {
		irec = tiffs_active_index + ino;
		if (!irec->type)
			continue;
		if (!strcmp(inode_to_dataptr(irec), seekname))
			return(ino);
	}
	return(0);
}

tiffs_pathname_to_inode(pathname)
	char *pathname;
{
	int ino, stat;
	struct inode *irec;
	char *cur, *next;

	stat = tiffs_init();
	if (stat < 0)
		return(stat);
	cur = pathname;
	if (*cur == '/')
		cur++;
	for (ino = tiffs_root_ino; cur; cur = next) {
		if (!*cur)
			break;
		next = index(cur, '/');
		if (next == cur) {
		    printf("malformed pathname: multiple adjacent slashes\n");
			return(-1);
		}
		if (next)
			*next++ = '\0';
		irec = tiffs_active_index + ino;
		if (irec->type != OBJTYPE_DIR) {
			printf("Error: non-terminal non-directory\n");
			if (next)
				next[-1] = '/';
			return(-1);
		}
		ino = find_named_child(irec->descend, cur);
		if (next)
			next[-1] = '/';
		if (!ino) {
			printf("Error: pathname component not found\n");
			return(-1);
		}
	}
	return(ino);
}