/* * * * Copyright 1990-2009 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 only, as published by the Free Software Foundation. * * This program 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 version 2 for more details (a copy is * included at /legal/license.txt). * * You should have received a copy of the GNU General Public License * version 2 along with this work; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 or visit www.sun.com if you need additional * information or have any questions. */ package gov.nist.siplite.parser; import gov.nist.core.*; import gov.nist.siplite.header.*; /** * Parser for content type header. * */ public class ExtensionParser extends ParametersParser { /** Default constructor. */ protected ExtensionParser() {} /** * Constructor with header value. * @param value full header value respresented as a string */ public ExtensionParser(String value) { super(value); } /** * Constructor with initial lexer engine. * @param lexer initial lexer engine */ protected ExtensionParser(Lexer lexer) { super(lexer); } /** * Invokes parser for extension header field. * IMPL_NOTE: optimize it (maybe use ParserCore.nameValue()?). * @return the parsed extension header * @throws ParseException if a parsing error occurs */ public Header parse() throws ParseException { String name = lexer.getNextToken(':'); HeaderList hdrList = new HeaderList(name); lexer.consume(1); lexer.SPorHT(); while (true) { String body = ""; String rest = lexer.getRest(); if (rest != null) { body = StringTokenizer.convertNewLines(rest.trim()); } ExtensionHeader header; int index = getDelimiterIndex(body, ';'); int separator = getDelimiterIndex(body, ','); if ((index != -1) || (separator != -1)) { if (((index != -1) && (index < separator)) || (separator == -1)) { separator = index; } int currPos = lexer.getPtr(); body = StringTokenizer.convertNewLines( lexer.getBuffer().substring(currPos, currPos + separator).trim()); lexer.consume(separator); } header = new ExtensionHeader(name, body); super.parse(header); hdrList.add(header); if (separator != -1) { this.lexer.SPorHT(); if (lexer.lookAhead(0) == ',') { this.lexer.match(','); this.lexer.SPorHT(); } else if (lexer.lookAhead(0) == '\n') { break; } else { throw createParseException("unexpected char"); } } else { break; } } return hdrList; } }