1069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project/* 2069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $HeadURL: http://svn.apache.org/repos/asf/httpcomponents/httpcore/trunk/module-main/src/main/java/org/apache/http/NameValuePair.java $ 3069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $Revision: 496070 $ 4069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $Date: 2007-01-14 04:18:34 -0800 (Sun, 14 Jan 2007) $ 5069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * 6069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * ==================================================================== 7069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Licensed to the Apache Software Foundation (ASF) under one 8069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * or more contributor license agreements. See the NOTICE file 9069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * distributed with this work for additional information 10069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * regarding copyright ownership. The ASF licenses this file 11069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * to you under the Apache License, Version 2.0 (the 12069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * "License"); you may not use this file except in compliance 13069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * with the License. You may obtain a copy of the License at 14069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * 15069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 16069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * 17069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Unless required by applicable law or agreed to in writing, 18069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * software distributed under the License is distributed on an 19069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 20069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * KIND, either express or implied. See the License for the 21069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * specific language governing permissions and limitations 22069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * under the License. 23069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * ==================================================================== 24069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * 25069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * This software consists of voluntary contributions made by many 26069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * individuals on behalf of the Apache Software Foundation. For more 27069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * information on the Apache Software Foundation, please see 28069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <http://www.apache.org/>. 29069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * 30069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project */ 31069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project 32069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectpackage org.apache.http; 33069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project 34069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project/** 35069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * A simple class encapsulating an attribute/value pair. 36069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p> 37069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * This class comforms to the generic grammar and formatting rules outlined in the 38069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <a href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec2.html#sec2.2">Section 2.2</a> 39069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * and 40069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <a href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec3.html#sec3.6">Section 3.6</a> 41069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * of <a href="http://www.w3.org/Protocols/rfc2616/rfc2616.txt">RFC 2616</a> 42069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </p> 43069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <h>2.2 Basic Rules</h> 44069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p> 45069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * The following rules are used throughout this specification to describe basic parsing constructs. 46069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * The US-ASCII coded character set is defined by ANSI X3.4-1986. 47069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </p> 48069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <pre> 49069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * OCTET = <any 8-bit sequence of data> 50069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * CHAR = <any US-ASCII character (octets 0 - 127)> 51069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * UPALPHA = <any US-ASCII uppercase letter "A".."Z"> 52069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * LOALPHA = <any US-ASCII lowercase letter "a".."z"> 53069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * ALPHA = UPALPHA | LOALPHA 54069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * DIGIT = <any US-ASCII digit "0".."9"> 55069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * CTL = <any US-ASCII control character 56069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * (octets 0 - 31) and DEL (127)> 57069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * CR = <US-ASCII CR, carriage return (13)> 58069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * LF = <US-ASCII LF, linefeed (10)> 59069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * SP = <US-ASCII SP, space (32)> 60069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * HT = <US-ASCII HT, horizontal-tab (9)> 61069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <"> = <US-ASCII double-quote mark (34)> 62069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </pre> 63069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p> 64069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Many HTTP/1.1 header field values consist of words separated by LWS or special 65069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * characters. These special characters MUST be in a quoted string to be used within 66069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * a parameter value (as defined in section 3.6). 67069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p> 68069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <pre> 69069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * token = 1*<any CHAR except CTLs or separators> 70069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * separators = "(" | ")" | "<" | ">" | "@" 71069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * | "," | ";" | ":" | "\" | <"> 72069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * | "/" | "[" | "]" | "?" | "=" 73069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * | "{" | "}" | SP | HT 74069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </pre> 75069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p> 76069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * A string of text is parsed as a single word if it is quoted using double-quote marks. 77069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </p> 78069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <pre> 79069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * quoted-string = ( <"> *(qdtext | quoted-pair ) <"> ) 80069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * qdtext = <any TEXT except <">> 81069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </pre> 82069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p> 83069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * The backslash character ("\") MAY be used as a single-character quoting mechanism only 84069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * within quoted-string and comment constructs. 85069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </p> 86069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <pre> 87069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * quoted-pair = "\" CHAR 88069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </pre> 89069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <h>3.6 Transfer Codings</h> 90069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p> 91069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Parameters are in the form of attribute/value pairs. 92069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </p> 93069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <pre> 94069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * parameter = attribute "=" value 95069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * attribute = token 96069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * value = token | quoted-string 97069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * </pre> 98069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * 99069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * @author <a href="mailto:oleg at ural.com">Oleg Kalnichevski</a> 100069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * 101d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath * 102d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath * @deprecated Please use {@link java.net.URL#openConnection} instead. 103d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath * Please visit <a href="http://android-developers.blogspot.com/2011/09/androids-http-clients.html">this webpage</a> 104d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath * for further details. 105069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project */ 106d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath@Deprecated 107069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectpublic interface NameValuePair { 108069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project 109069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project String getName(); 110069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project 111069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project String getValue(); 112069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project 113069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project} 114