All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.hk2.component.KeyValuePairParser Maven / Gradle / Ivy

There is a newer version: 1.6.9
Show newest version
/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright (c) 2007-2011 Oracle and/or its affiliates. All rights reserved.
 *
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License.  You can
 * obtain a copy of the License at
 * https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
 * or packager/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at packager/legal/LICENSE.txt.
 *
 * GPL Classpath Exception:
 * Oracle designates this particular file as subject to the "Classpath"
 * exception as provided by Oracle in the GPL Version 2 section of the License
 * file that accompanied this code.
 *
 * Modifications:
 * If applicable, add the following below the License Header, with the fields
 * enclosed by brackets [] replaced by your own identifying information:
 * "Portions Copyright [year] [name of copyright owner]"
 *
 * Contributor(s):
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 */
package com.sun.hk2.component;

import java.util.Iterator;
import java.util.StringTokenizer;

/**
 * Parses a string like key=value,key=value,key=value.
 *
 * 

* More specifically the format of the line satisfies the following BNF constructions: * *

 * LINE = TOKEN ( ',' LINE )?               // LINE is ','-separated TOKENs
 * TOKEN = KEY ( '=' VALUE )?               // TOKEN is a key/value pair. value is optional.
 * KEY = [^,=]+                             // KEY is a non-empty string that doesn't contain ',' nor '='
 * VALUE = '"' ([^"]| '\' ANYCHAR )* '"'    // VALUE is any string surrounded by quotes/doublequotes (where \ is used as escape), or ...
 * VALUE = ''' ([^']| '\' ANYCHAR )* '''
 * VALUE = [^,]*                //       possibly empty string that doesn't contain ','
 * 
* *

* This class works like {@link StringTokenizer}; each time {@link #parseNext()} * is invoked, the parser "moves" to the next key/value pair, which * you can then obtain with {@link #getKey()} and {@link #getValue()}. * The {@link #hasNext()} method shall be used to check if there's a next key/value * pair after the current position. * * TODO: improved error check * @author Kohsuke Kawaguchi */ public final class KeyValuePairParser { private String str; private int idx; private String key; private String value; private final StringBuilder buf = new StringBuilder(); public KeyValuePairParser() { } public KeyValuePairParser(String s) { set(s); } /** * Resets the parser to parse the given string that looks like "key=value,key=value,..." */ public void set(String str) { this.str = str; idx = 0; } public boolean hasNext() { return idx * This method is not terribly efficient, but it is convenient. */ public String find(String key) { while(hasNext()) { parseNext(); if(getKey().equals(key)) return getValue(); } return null; } /** * Finds all the values of the given key. * Calling the iterator will rewind the parser. */ public Iterable findAll(final String key) { return new Iterable() { public Iterator iterator() { rewind(); return new Iterator() { private String next; private void fetch() { if(next==null) next = find(key); } public boolean hasNext() { fetch(); return next!=null; } public String next() { fetch(); String r = next; next = null; return r; } public void remove() { throw new UnsupportedOperationException(); } }; } }; } /** * Gets the whole line. */ public String getLine() { return str; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy