view toys/seq.c @ 551:2548e6e590b2

Add string to mode_t parser added new function string_to_mode(char *m_string, mode_t base) which parses a given string and converts it to a mode_t. If either + or - are part of m_string the permissions are either added or removed from base. Currently support for permision copy is missing (e.g. g=u), but all other flags should work. Format for m_string: either symbolic modes or octal representation. symbolic modes: [auog][[+-=][rwxst]*] examples: string_to_mode("u=rwx,g=rw,o=r", 0); string_to_mode("a-x", 0777); string_to_mode("0744", 0);
author Daniel Walter <d.walter@0x90.at>
date Mon, 19 Mar 2012 19:57:56 -0500
parents 15bad33d5ded
children
line wrap: on
line source

/* vi: set sw=4 ts=4:
 *
 * seq.c - Count from first to last, by increment.
 *
 * Copyright 2006 Rob Landley <rob@landley.net>
 *
 * Not in SUSv3.  (Don't ask me why not.)

USE_SEQ(NEWTOY(seq, "<1>3?", TOYFLAG_USR|TOYFLAG_BIN))

config SEQ
	bool "seq"
	depends on TOYBOX_FLOAT
	default y
	help
	  usage: seq [first] [increment] last

	  Count from first to last, by increment.  Omitted arguments default
	  to 1.  Two arguments are used as first and last.  Arguments can be
	  negative or floating point.
*/

#include "toys.h"

void seq_main(void)
{
	double first, increment, last, dd;

	// Parse command line arguments, with appropriate defaults.
	// Note that any non-numeric arguments are treated as zero.
	first = increment = 1;
	switch (toys.optc) {
		case 3:
			increment = atof(toys.optargs[1]);
		case 2:
			first = atof(*toys.optargs);
		default:
			last = atof(toys.optargs[toys.optc-1]);
	}

	// Yes, we're looping on a double.  Yes rounding errors can accumulate if
	// you use a non-integer increment.  Deal with it.
	for (dd=first; (increment>0 && dd<=last) || (increment <0 && dd>=last);
		dd+=increment)
	{
		printf("%g\n", dd);
	}
}