Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   */
  package org.jruby.ext.zlib;
  
  import org.jruby.Ruby;
 import static org.jruby.runtime.Visibility.PRIVATE;
 
 @JRubyClass(name = "Zlib::ZStream")
 public abstract class ZStream extends RubyObject {
 
     protected boolean closed = false;
 
     protected abstract int internalTotalIn();
 
     protected abstract int internalTotalOut();
 
     protected abstract boolean internalStreamEndP();
 
     protected abstract void internalReset();
 
     protected abstract boolean internalFinished();
 
     protected abstract long internalAdler();
 
     // TODO: eliminate?
     protected abstract IRubyObject internalFinish();
 
     protected abstract void internalClose();
 
     public ZStream(Ruby runtimeRubyClass type) {
         super(runtimetype);
     }
 
     @JRubyMethod(visibility = )
     public IRubyObject initialize(Block unusedBlock) {
         return this;
     }
 
     @JRubyMethod
     public IRubyObject flush_next_out(ThreadContext context) {
         return RubyString.newEmptyString(context.getRuntime());
     }
 
     @JRubyMethod
     public IRubyObject total_out() {
         checkClosed();
         return getRuntime().newFixnum(internalTotalOut());
     }
 
     @JRubyMethod(name = "stream_end?")
     public IRubyObject stream_end_p() {
         return internalStreamEndP() ? getRuntime().getTrue() : getRuntime().getFalse();
     }
 
     @JRubyMethod(name = "data_type")
     public IRubyObject data_type() {
         checkClosed();
         return getRuntime().getModule("Zlib").getConstant("UNKNOWN");
     }
 
     @JRubyMethod(name = {"closed?""ended?"})
     public IRubyObject closed_p() {
         return  ? getRuntime().getTrue() : getRuntime().getFalse();
     }
 
     @JRubyMethod(name = "reset")
     public IRubyObject reset() {
         checkClosed();
         internalReset();
         
         return getRuntime().getNil();
     }
 
     @JRubyMethod(name = "avail_out")
     public IRubyObject avail_out() {
         return RubyFixnum.zero(getRuntime());
     }
 
     @JRubyMethod(name = "avail_out=", required = 1)
     public IRubyObject set_avail_out(IRubyObject p1) {
         checkClosed();
         
         return p1;
     }
 
     @JRubyMethod(name = "adler")
    public IRubyObject adler() {
        checkClosed();
        
        return getRuntime().newFixnum(internalAdler());
    }
    @JRubyMethod(name = "finish")
    public IRubyObject finish(ThreadContext context) {
        checkClosed();
        
        IRubyObject result = internalFinish();
        
        return result;
    }
    @JRubyMethod(name = "avail_in")
    public IRubyObject avail_in() {
        return RubyFixnum.zero(getRuntime());
    }
    @JRubyMethod(name = "flush_next_in")
    public IRubyObject flush_next_in(ThreadContext context) {
        return RubyString.newEmptyString(context.getRuntime());
    }
    @JRubyMethod(name = "total_in")
    public IRubyObject total_in() {
        checkClosed();
        
        return getRuntime().newFixnum(internalTotalIn());
    }
    @JRubyMethod(name = "finished?")
    public IRubyObject finished_p(ThreadContext context) {
        checkClosed();
        Ruby runtime = context.getRuntime();
        return internalFinished() ? runtime.getTrue() : runtime.getFalse();
    }
    @JRubyMethod(name = {"close""end"})
    public IRubyObject close() {
        checkClosed();
        internalClose();
         = true;
        return getRuntime().getNil();
    }
    void checkClosed() {
        if (throw RubyZlib.newZlibError(getRuntime(), "stream is not ready");
    }
    // TODO: remove when JZlib checks the given level
    static void checkLevel(Ruby runtimeint level) {
        if ((level < 0 || level > 9) && level != .) {
            throw RubyZlib.newStreamError(runtime"stream error: invalid level");
        }
    }

    
We only do windowBits=15(32K buffer, LZ77 algorithm) since java.util.zip only allows it. NOTE: deflateInit2 of zlib.c also accepts MAX_WBITS + 16(gzip compression). inflateInit2 also accepts MAX_WBITS + 16(gzip decompression) and MAX_WBITS + 32(automatic detection of gzip and LZ77).
    // TODO: remove when JZlib checks the given windowBits
    static void checkWindowBits(Ruby runtimeint wbitsboolean forInflate) {
        wbits = Math.abs(wbits);
        if ((wbits & 0xf) < 8) {
            throw RubyZlib.newStreamError(runtime"stream error: invalid window bits");
        }
        if ((wbits & 0xf) != 0xf) {
            // windowBits < 15 for reducing memory is meaningless on Java platform. 
            runtime.getWarnings().warn("windowBits < 15 is ignored on this platform");
            // continue
        }
        if (forInflate && wbits > . + 32) {
            throw RubyZlib.newStreamError(runtime"stream error: invalid window bits");
        } else if (!forInflate && wbits > . + 16) {
            throw RubyZlib.newStreamError(runtime"stream error: invalid window bits");
        }
    }
    // TODO: remove when JZlib checks the given strategy
    static void checkStrategy(Ruby runtimeint strategy) {
        switch (strategy) {
            case .:
            case .:
            case .:
                break;
            default:
                throw RubyZlib.newStreamError(runtime"stream error: invalid strategy");
        }
    }
New to GrepCode? Check out our FAQ X