Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
   * Copyright (c) 2007-2010 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
  * 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.enterprise.web.connector.grizzly.comet;
Non blocking Writer. This class can be used from a CometHandler to execute non blocking write. If the write was incomplete, the CometHandler must register itself using CometContext.registerAsyncWrite()

Jeanfrancois Arcand
 public class CometWriter{
     private boolean isComplete = true;
     private SocketChannel socketChannel;

Buffer used for chunk length conversion.
     protected byte[] chunkLength;   
     private final static ByteBuffer end = ByteBuffer.wrap("0\r\n\r\n".getBytes());
Is this CometWriter ready
     private boolean ready = true;  
     public CometWriter() {
          = new byte[10];
         [8] = (byte'\r';
         [9] = (byte'\n';
     protected void setChannel(SocketChannel socketChannel){      
         this. = socketChannel;
     public int write(byte[] bufthrows IOException {
         return write(buf,0,buf.length);
     public int write(byte[] bufint offint lenthrows IOException {
        if (!){
            throw new IllegalStateException("This CometWriter is no longer usable.");
        int pos = 7;
        int current = len;
        // Force a blocking read.
        if () {
            while (current > 0) {
                int digit = current % 16;
                current = current / 16;
                [pos--] = .[digit];
                    ByteBuffer.wrap(pos + 1, 9 - pos));
        int nWrite = .write(ByteBuffer.wrap(buf,off,len));    
        if (nWrite == len) {
             = true;
                    ByteBuffer.wrap(, 8, 2));
        } else {
             = false;
        return nWrite;
    public boolean isComplete(){
        return ;
    public void recycle(){
         = true;
         = null;
Return true if this instance is ready to read.
    public boolean isReady() {
        return ;

false if this instance is no longer ready to read.
    public void setReady(boolean ready) {
        this. = ready;
New to GrepCode? Check out our FAQ X