|
What this is
Other links
The source code// $Id: CustomSeparator.java,v 1.5 2004/08/27 15:29:17 mvw Exp $ // Copyright (c) 1996-2002 The Regents of the University of California. All // Rights Reserved. Permission to use, copy, modify, and distribute this // software and its documentation without fee, and without a written // agreement is hereby granted, provided that the above copyright notice // and this paragraph appear in all copies. This software program and // documentation are copyrighted by The Regents of the University of // California. The software program and documentation are supplied "AS // IS", without any accompanying services from The Regents. The Regents // does not warrant that the operation of the program will be // uninterrupted or error-free. The end-user understands that the program // was developed for research purposes and is advised not to rely // exclusively on the program for any reason. IN NO EVENT SHALL THE // UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, // SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, // ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF // THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF // SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE // PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF // CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, // UPDATES, ENHANCEMENTS, OR MODIFICATIONS. package org.argouml.util; /** * Base class for custom separators. * *
The default behaviour is to return false until the character * or String given as parameter to the constructor has been matched. * * @param c The next character in the sequence being tokenized. * @return true to gain control of the matching, false to continue * matching. */ public boolean addChar(char c) { int i; for (i = 0; i < match.length - 1; i++) match[i] = match[i + 1]; match[match.length - 1] = c; for (i = 0; i < match.length; i++) if (match[i] != pattern[i]) return false; return true; } /** * Called to check if more characters are expected to follow after * addChar has returned true. If true, then any following characters * will be fed to endChar until endChar returns true. * * The default behaviour is to return false. * * @return true to continue feeding characters to endChar or false. */ public boolean hasFreePart() { return false; } /** * Called to check if more characters are expected in the free part of * the token. * * @param c The next character in the sequence being tokenized. * @return true to indicate that the token is complete, or false to * continue feeding characters through endChar. */ public boolean endChar(char c) { return true; } /** * Called to how many characters the CustomSeparator read after * the end of the separator. This allows them to see beyond the * end, but these characters will be fed to the separators again * when looking for the next token so be careful. * * @return the number of characters that were read after the end * of the token had been read. */ public int getPeekCount() { return 0; } } |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2021 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.