Personal tools
You are here: Home Projects C++ Cfront releases Release 3.0.3 source libSC Path find.c
Document Actions

find.c

by Michael L Powell last modified 2007-01-26 03:24

Click here to get the file

Size 1.5 kB - File type text/plain

File contents

/*ident	"@(#)Path:find.c	3.1" */
/******************************************************************************
*
* C++ Standard Components, Release 3.0.
*
* Copyright (c) 1991, 1992 AT&T and Unix System Laboratories, Inc.
* Copyright (c) 1988, 1989, 1990 AT&T.  All Rights Reserved.
*
* THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T and Unix System
* Laboratories, Inc.  The copyright notice above does not evidence
* any actual or intended publication of such source code.
*
******************************************************************************/

#include "Pathlib.h"
#include <Search_path.h>

int Search_path::find(const Path & p, Path & ret, Ksh_test::unary m, Ksh_test::id _t) const {
	if (p.is_absolute()) {
		if (ksh_test(m, p, _t)) {
			ret = p;
			return 1;
		}
		else {
			return 0;
		}
	}
	else {
		Listiter<Path> i(*(Search_path*)this);
		while (!i.at_end()) {
			Path tmp = *(i.next());
			tmp /= p;
//cout << "checking access of " << tmp << endl;
			if (ksh_test(m, tmp, _t)) {
				ret = tmp;
				return 1;
			}
		}
		return 0;
	}
}

int Search_path::find_all(const Path & p, List<Path> & l, Ksh_test::unary m, Ksh_test::id _t) const {
	l.make_empty();
	if (p.is_absolute()) {
		if (ksh_test(m, p, _t))
			l.put(p);
	}
	else {
		Listiter<Path> i(*(Search_path*)this);
		while (!i.at_end()) {
			Path tmp = *(i.next());
			tmp /= p;
			if (ksh_test(m, tmp, _t))
				l.put(tmp);
		}
	}
	// not really necessary, since put doesn't change current position
	// l.reset();
	return (l.length() > 0);
}

« March 2024 »
Su Mo Tu We Th Fr Sa
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31
 

Powered by Plone CMS, the Open Source Content Management System

This site conforms to the following standards: