单军华
2018-07-31 21d3023a9b7b6aff68c1170e345951396b1c6cfd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
//
//  ASINetworkQueue.h
//  Part of ASIHTTPRequest -> http://allseeing-i.com/ASIHTTPRequest
//
//  Created by Ben Copsey on 07/11/2008.
//  Copyright 2008-2009 All-Seeing Interactive. All rights reserved.
//
 
#import <Foundation/Foundation.h>
#import "ASIHTTPRequestDelegate.h"
#import "ASIProgressDelegate.h"
 
@interface ASINetworkQueue : NSOperationQueue <ASIProgressDelegate, ASIHTTPRequestDelegate, NSCopying> {
    
    // Delegate will get didFail + didFinish messages (if set)
    id delegate;
 
    // Will be called when a request starts with the request as the argument
    SEL requestDidStartSelector;
    
    // Will be called when a request receives response headers
    // Should take the form request:didRecieveResponseHeaders:, where the first argument is the request, and the second the headers dictionary
    SEL requestDidReceiveResponseHeadersSelector;
    
    // Will be called when a request is about to redirect
    // Should take the form request:willRedirectToURL:, where the first argument is the request, and the second the new url
    SEL requestWillRedirectSelector;
 
    // Will be called when a request completes with the request as the argument
    SEL requestDidFinishSelector;
    
    // Will be called when a request fails with the request as the argument
    SEL requestDidFailSelector;
    
    // Will be called when the queue finishes with the queue as the argument
    SEL queueDidFinishSelector;
    
    // Upload progress indicator, probably an NSProgressIndicator or UIProgressView
    id uploadProgressDelegate;
    
    // Total amount uploaded so far for all requests in this queue
    unsigned long long bytesUploadedSoFar;
    
    // Total amount to be uploaded for all requests in this queue - requests add to this figure as they work out how much data they have to transmit
    unsigned long long totalBytesToUpload;
 
    // Download progress indicator, probably an NSProgressIndicator or UIProgressView
    id downloadProgressDelegate;
    
    // Total amount downloaded so far for all requests in this queue
    unsigned long long bytesDownloadedSoFar;
    
    // Total amount to be downloaded for all requests in this queue - requests add to this figure as they receive Content-Length headers
    unsigned long long totalBytesToDownload;
    
    // When YES, the queue will cancel all requests when a request fails. Default is YES
    BOOL shouldCancelAllRequestsOnFailure;
    
    //Number of real requests (excludes HEAD requests created to manage showAccurateProgress)
    int requestsCount;
    
    // When NO, this request will only update the progress indicator when it completes
    // When YES, this request will update the progress indicator according to how much data it has received so far
    // When YES, the queue will first perform HEAD requests for all GET requests in the queue, so it can calculate the total download size before it starts
    // NO means better performance, because it skips this step for GET requests, and it won't waste time updating the progress indicator until a request completes 
    // Set to YES if the size of a requests in the queue varies greatly for much more accurate results
    // Default for requests in the queue is NO
    BOOL showAccurateProgress;
 
    // Storage container for additional queue information.
    NSDictionary *userInfo;
    
}
 
// Convenience constructor
+ (id)queue;
 
// Call this to reset a queue - it will cancel all operations, clear delegates, and suspend operation
- (void)reset;
 
// Used internally to manage HEAD requests when showAccurateProgress is YES, do not use!
- (void)addHEADOperation:(NSOperation *)operation;
 
// All ASINetworkQueues are paused when created so that total size can be calculated before the queue starts
// This method will start the queue
- (void)go;
 
@property (assign, nonatomic, setter=setUploadProgressDelegate:) id uploadProgressDelegate;
@property (assign, nonatomic, setter=setDownloadProgressDelegate:) id downloadProgressDelegate;
 
@property (assign) SEL requestDidStartSelector;
@property (assign) SEL requestDidReceiveResponseHeadersSelector;
@property (assign) SEL requestWillRedirectSelector;
@property (assign) SEL requestDidFinishSelector;
@property (assign) SEL requestDidFailSelector;
@property (assign) SEL queueDidFinishSelector;
@property (assign) BOOL shouldCancelAllRequestsOnFailure;
@property (assign) id delegate;
@property (assign) BOOL showAccurateProgress;
@property (assign, readonly) int requestsCount;
@property (retain) NSDictionary *userInfo;
 
@property (assign) unsigned long long bytesUploadedSoFar;
@property (assign) unsigned long long totalBytesToUpload;
@property (assign) unsigned long long bytesDownloadedSoFar;
@property (assign) unsigned long long totalBytesToDownload;
 
@end