Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 package org.chromium.net.impl; | |
| 6 | |
| 7 import org.chromium.net.BidirectionalStream; | |
| 8 import org.chromium.net.CronetEngine; | |
| 9 import org.chromium.net.CronetException; | |
| 10 import org.chromium.net.NetworkQualityRttListener; | |
| 11 import org.chromium.net.NetworkQualityThroughputListener; | |
| 12 import org.chromium.net.RequestFinishedInfo; | |
| 13 import org.chromium.net.UploadDataProvider; | |
| 14 import org.chromium.net.UploadDataSink; | |
| 15 import org.chromium.net.UrlRequest; | |
| 16 import org.chromium.net.UrlRequestException; | |
| 17 import org.chromium.net.UrlResponseInfo; | |
| 18 | |
| 19 import java.io.IOException; | |
| 20 import java.nio.ByteBuffer; | |
| 21 import java.util.concurrent.Executor; | |
| 22 | |
| 23 /** | |
| 24 * This class contains wrapper classes for all Cronet API callback/listener clas ses. These classes | |
| 25 * only permit callbacks that the version of the client API is known to support. For example, if | |
| 26 * version 2 of the API adds a callback onFoo() but the client API this class is implementing is | |
| 27 * version 1, these wrapper classes should not call {@code mWrappedCallback.onFo o()} and should | |
| 28 * instead silently drop the callback. | |
| 29 * | |
| 30 * When adding any callback wrapping here, be sure you add the proper version ch eck. Only callbacks | |
| 31 * supported in all versions of the API should forgo a version check. | |
| 32 */ | |
| 33 public class VersionSafeCallbacks { | |
|
kapishnikov
2016/11/18 16:32:57
Instead of list of static classes, we can change t
pauljensen
2016/11/18 19:18:07
You just want me to add a bunch of these type of f
kapishnikov
2016/11/18 19:39:16
I was thinking of returning anonymous classes but
| |
| 34 /** | |
| 35 * Wrap a {@link UrlRequest.Callback} in a version safe manner. | |
| 36 */ | |
| 37 public static final class UrlRequestCallback extends UrlRequest.Callback { | |
|
kapishnikov
2016/11/18 20:11:18
Would it be safer if we don't extend the underlyin
pauljensen
2016/11/19 01:12:19
I also considered this. I've been working on a pr
kapishnikov
2016/11/21 17:35:22
Agree, with the presubmit check it should be safe.
| |
| 38 private final UrlRequest.Callback mWrappedCallback; | |
| 39 | |
| 40 public UrlRequestCallback(UrlRequest.Callback callback) { | |
| 41 mWrappedCallback = callback; | |
| 42 } | |
| 43 | |
| 44 @Override | |
| 45 public void onRedirectReceived( | |
| 46 UrlRequest request, UrlResponseInfo info, String newLocationUrl) throws Exception { | |
| 47 mWrappedCallback.onRedirectReceived(request, info, newLocationUrl); | |
| 48 } | |
| 49 | |
| 50 @Override | |
| 51 public void onResponseStarted(UrlRequest request, UrlResponseInfo info) throws Exception { | |
| 52 mWrappedCallback.onResponseStarted(request, info); | |
| 53 } | |
| 54 | |
| 55 @Override | |
| 56 public void onReadCompleted(UrlRequest request, UrlResponseInfo info, By teBuffer byteBuffer) | |
| 57 throws Exception { | |
| 58 mWrappedCallback.onReadCompleted(request, info, byteBuffer); | |
| 59 } | |
| 60 | |
| 61 @Override | |
| 62 public void onSucceeded(UrlRequest request, UrlResponseInfo info) { | |
| 63 mWrappedCallback.onSucceeded(request, info); | |
| 64 } | |
| 65 | |
| 66 @Override | |
| 67 public void onFailed(UrlRequest request, UrlResponseInfo info, UrlReques tException error) { | |
| 68 mWrappedCallback.onFailed(request, info, error); | |
| 69 } | |
| 70 | |
| 71 @Override | |
| 72 public void onCanceled(UrlRequest request, UrlResponseInfo info) { | |
| 73 mWrappedCallback.onCanceled(request, info); | |
| 74 } | |
| 75 } | |
| 76 | |
| 77 /** | |
| 78 * Wrap a {@link UrlRequest.StatusListener} in a version safe manner. | |
| 79 */ | |
| 80 public static final class UrlRequestStatusListener extends UrlRequest.Status Listener { | |
| 81 private final UrlRequest.StatusListener mWrappedListener; | |
| 82 | |
| 83 public UrlRequestStatusListener(UrlRequest.StatusListener listener) { | |
| 84 mWrappedListener = listener; | |
| 85 } | |
| 86 | |
| 87 @Override | |
| 88 public void onStatus(int status) { | |
| 89 mWrappedListener.onStatus(status); | |
| 90 } | |
| 91 } | |
| 92 | |
| 93 /** | |
| 94 * Wrap a {@link BidirectionalStream.Callback} in a version safe manner. | |
| 95 */ | |
| 96 public static final class BidirectionalStreamCallback extends BidirectionalS tream.Callback { | |
| 97 private final BidirectionalStream.Callback mWrappedCallback; | |
| 98 | |
| 99 public BidirectionalStreamCallback(BidirectionalStream.Callback callback ) { | |
| 100 mWrappedCallback = callback; | |
| 101 } | |
| 102 | |
| 103 @Override | |
| 104 public void onStreamReady(BidirectionalStream stream) { | |
| 105 mWrappedCallback.onStreamReady(stream); | |
| 106 } | |
| 107 | |
| 108 @Override | |
| 109 public void onResponseHeadersReceived(BidirectionalStream stream, UrlRes ponseInfo info) { | |
| 110 mWrappedCallback.onResponseHeadersReceived(stream, info); | |
| 111 } | |
| 112 | |
| 113 @Override | |
| 114 public void onReadCompleted(BidirectionalStream stream, UrlResponseInfo info, | |
| 115 ByteBuffer buffer, boolean endOfStream) { | |
| 116 mWrappedCallback.onReadCompleted(stream, info, buffer, endOfStream); | |
| 117 } | |
| 118 | |
| 119 @Override | |
| 120 public void onWriteCompleted(BidirectionalStream stream, UrlResponseInfo info, | |
| 121 ByteBuffer buffer, boolean endOfStream) { | |
| 122 mWrappedCallback.onWriteCompleted(stream, info, buffer, endOfStream) ; | |
| 123 } | |
| 124 | |
| 125 @Override | |
| 126 public void onResponseTrailersReceived(BidirectionalStream stream, UrlRe sponseInfo info, | |
| 127 UrlResponseInfo.HeaderBlock trailers) { | |
| 128 mWrappedCallback.onResponseTrailersReceived(stream, info, trailers); | |
| 129 } | |
| 130 | |
| 131 @Override | |
| 132 public void onSucceeded(BidirectionalStream stream, UrlResponseInfo info ) { | |
| 133 mWrappedCallback.onSucceeded(stream, info); | |
| 134 } | |
| 135 | |
| 136 @Override | |
| 137 public void onFailed( | |
| 138 BidirectionalStream stream, UrlResponseInfo info, CronetExceptio n error) { | |
| 139 mWrappedCallback.onFailed(stream, info, error); | |
| 140 } | |
| 141 | |
| 142 @Override | |
| 143 public void onCanceled(BidirectionalStream stream, UrlResponseInfo info) { | |
| 144 mWrappedCallback.onCanceled(stream, info); | |
| 145 } | |
| 146 } | |
| 147 | |
| 148 /** | |
| 149 * Wrap a {@link UploadDataProvider} in a version safe manner. | |
| 150 */ | |
| 151 public static final class UploadDataProviderWrapper extends UploadDataProvid er { | |
| 152 private final UploadDataProvider mWrappedProvider; | |
| 153 | |
| 154 public UploadDataProviderWrapper(UploadDataProvider provider) { | |
| 155 mWrappedProvider = provider; | |
| 156 } | |
| 157 | |
| 158 @Override | |
| 159 public long getLength() throws IOException { | |
| 160 return mWrappedProvider.getLength(); | |
| 161 } | |
| 162 | |
| 163 @Override | |
| 164 public void read(UploadDataSink uploadDataSink, ByteBuffer byteBuffer) t hrows IOException { | |
| 165 mWrappedProvider.read(uploadDataSink, byteBuffer); | |
| 166 } | |
| 167 | |
| 168 @Override | |
| 169 public void rewind(UploadDataSink uploadDataSink) throws IOException { | |
| 170 mWrappedProvider.rewind(uploadDataSink); | |
| 171 } | |
| 172 | |
| 173 @Override | |
| 174 public void close() throws IOException { | |
| 175 mWrappedProvider.close(); | |
| 176 } | |
| 177 } | |
| 178 | |
| 179 /** | |
| 180 * Wrap a {@link RequestFinishedInfo.Listener} in a version safe manner. | |
| 181 */ | |
| 182 public static final class RequestFinishedInfoListener extends RequestFinishe dInfo.Listener { | |
| 183 private final RequestFinishedInfo.Listener mWrappedListener; | |
| 184 | |
| 185 public RequestFinishedInfoListener(RequestFinishedInfo.Listener listener ) { | |
| 186 super(listener.getExecutor()); | |
| 187 mWrappedListener = listener; | |
| 188 } | |
| 189 | |
| 190 @Override | |
| 191 public void onRequestFinished(RequestFinishedInfo requestInfo) { | |
| 192 mWrappedListener.onRequestFinished(requestInfo); | |
| 193 } | |
| 194 | |
| 195 @Override | |
| 196 public Executor getExecutor() { | |
| 197 return mWrappedListener.getExecutor(); | |
| 198 } | |
| 199 } | |
| 200 | |
| 201 /** | |
| 202 * Wrap a {@link NetworkQualityRttListener} in a version safe manner. | |
| 203 */ | |
| 204 public static final class NetworkQualityRttListenerWrapper extends NetworkQu alityRttListener { | |
| 205 private final NetworkQualityRttListener mWrappedListener; | |
| 206 | |
| 207 public NetworkQualityRttListenerWrapper(NetworkQualityRttListener listen er) { | |
| 208 super(listener.getExecutor()); | |
| 209 mWrappedListener = listener; | |
| 210 } | |
| 211 | |
| 212 @Override | |
| 213 public void onRttObservation(int rttMs, long whenMs, int source) { | |
| 214 mWrappedListener.onRttObservation(rttMs, whenMs, source); | |
| 215 } | |
| 216 | |
| 217 @Override | |
| 218 public Executor getExecutor() { | |
| 219 return mWrappedListener.getExecutor(); | |
| 220 } | |
| 221 } | |
| 222 | |
| 223 /** | |
| 224 * Wrap a {@link NetworkQualityThroughputListener} in a version safe manner. | |
| 225 */ | |
| 226 public static final class NetworkQualityThroughputListenerWrapper | |
| 227 extends NetworkQualityThroughputListener { | |
| 228 private final NetworkQualityThroughputListener mWrappedListener; | |
| 229 | |
| 230 public NetworkQualityThroughputListenerWrapper(NetworkQualityThroughputL istener listener) { | |
| 231 super(listener.getExecutor()); | |
| 232 mWrappedListener = listener; | |
| 233 } | |
| 234 | |
| 235 @Override | |
| 236 public void onThroughputObservation(int throughputKbps, long whenMs, int source) { | |
| 237 mWrappedListener.onThroughputObservation(throughputKbps, whenMs, sou rce); | |
| 238 } | |
| 239 | |
| 240 @Override | |
| 241 public Executor getExecutor() { | |
| 242 return mWrappedListener.getExecutor(); | |
| 243 } | |
| 244 } | |
| 245 | |
| 246 /** | |
| 247 * Wrap a {@link CronetEngine.Builder.LibraryLoader} in a version safe manne r. | |
| 248 */ | |
| 249 public static final class LibraryLoader extends CronetEngine.Builder.Library Loader { | |
| 250 private final CronetEngine.Builder.LibraryLoader mWrappedLoader; | |
| 251 | |
| 252 public LibraryLoader(CronetEngine.Builder.LibraryLoader libraryLoader) { | |
| 253 mWrappedLoader = libraryLoader; | |
| 254 } | |
| 255 | |
| 256 @Override | |
| 257 public void loadLibrary(String libName) { | |
| 258 mWrappedLoader.loadLibrary(libName); | |
| 259 } | |
| 260 } | |
| 261 } | |
| OLD | NEW |