/* * Copyright 2013 Simon Taddiken * * This file is part of Polly HTTP API. * * Polly HTTP API is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or (at * your option) any later version. * * Polly HTTP API 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 for * more details. * * You should have received a copy of the GNU General Public License along * with Polly HTTP API. If not, see http://www.gnu.org/licenses/. */ package de.skuzzle.polly.http.internal; import java.io.FilterOutputStream; import java.io.IOException; import java.io.OutputStream; /** * {@link OutputStream} wrapper which counts all written bytes and updates a * {@link TrafficInformation} instance. * * @author Simon Taddiken */ class CountingOutputStream extends FilterOutputStream { /** The updated TrafficInformation */ protected final TrafficInformationImpl trafficInfo; /** * Creates a new CountingOutputStream. * * @param out The wrapped OutputStream. * @param trafficInfo TrafficInformation that are updated when data is written. */ public CountingOutputStream(OutputStream out, TrafficInformationImpl trafficInfo) { super(out); this.trafficInfo = trafficInfo; } @Override public void write(byte[] b) throws IOException { this.write(b, 0, b.length); } @Override public synchronized void write(byte[] b, int off, int len) throws IOException { this.trafficInfo.updateUpload(Math.max(0, len)); super.write(b, off, len); } @Override public synchronized void write(int b) throws IOException { this.trafficInfo.updateUpload(1); super.write(b); } }