|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T i
Length: 2440 (0x988) Types: TextFile Names: »iterator.cc«
└─⟦a05ed705a⟧ Bits:30007078 DKUUG GNU 2/12/89 └─⟦cc8755de2⟧ »./libg++-1.36.1.tar.Z« └─⟦23757c458⟧ └─⟦this⟧ »libg++/gperf/src/iterator.cc«
/* Provides an Iterator for keyword characters. Copyright (C) 1989 Free Software Foundation, Inc. written by Douglas C. Schmidt (schmidt@ics.uci.edu) This file is part of GNU GPERF. GNU GPERF is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 1, or (at your option) any later version. GNU GPERF is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GNU GPERF; see the file COPYING. If not, write to the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ #include <stream.h> #include <std.h> #include <ctype.h> #include "iterator.h" /* Constructor for Iterator. */ Iterator::Iterator (char *s, int lo, int hi, int word_end, int bad_val, int key_end) { end = key_end; error_value = bad_val; end_word = word_end; str = s; hi_bound = hi; lo_bound = lo; } /* Provide an Iterator, returning the ``next'' value from the list of valid values given in the constructor. */ int Iterator::operator () (void) { /* Variables to record the Iterator's status when handling ranges, e.g., 3-12. */ static int size; static int curr_value; static int upper_bound; if (size) { if (++curr_value >= upper_bound) size = 0; return curr_value; } else { while (*str) switch (*str) { default: return error_value; case ',': str++; break; case '$': str++; return end_word; case '1'..'9': for (curr_value = 0; isdigit (*str); str++) curr_value = curr_value * 10 + *str - '0'; if (*str == '-') { for (size = 1, upper_bound = 0; isdigit (*++str); upper_bound = upper_bound * 10 + *str - '0'); if (upper_bound <= curr_value || upper_bound > hi_bound) return error_value; } return curr_value >= lo_bound && curr_value <= hi_bound ? curr_value : error_value; } return end; } }