/*
* Copyright 2005 Joe Walker
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.directwebremoting.dwrp;
import java.util.HashMap;
import java.util.Map;
/**
* A set of constants that represent how browsers need data flushed to them
* @author Joe Walker [joe at getahead dot ltd dot uk]
*/
public enum PartialResponse
{
/**
* The client can not handle partial responses
*/
NO("0"),
/**
* The client can handle partial responses
*/
YES("1"),
/**
* The client can only handle partial responses with a 4k data post
* (can be whitespace) - we're talking IE here.
*/
FLUSH("2");
/**
* @param id The string that the browser passes for this value
*/
private PartialResponse(String id)
{
this.id = id;
}
/**
* The browser version of this value
*/
private final String id;
/**
* A lookup table of browser strings to enum constants
*/
private static final Map<String, PartialResponse> ids = new HashMap<String, PartialResponse>();
/**
* Setup the lookup table
*/
static
{
for (PartialResponse partialResponse : PartialResponse.values())
{
ids.put(partialResponse.id, partialResponse);
}
}
/**
* Convert a string from the web into a PartialResponse. The values are
* PARTIAL_RESPONSE_NO = "0", PARTIAL_RESPONSE_YES = "1" and
* PARTIAL_RESPONSE_FLUSH = "2"
* @param lookupid The PartialResponse to look-up
* @return a matching PartialResponse or null if one was not found
*/
public static PartialResponse fromOrdinal(String lookupid)
{
return ids.get(lookupid);
}
}