Merge pull request #2188 from dreampiggy/refactor_context_option

Move the context option to a separate header to allow to be included without dependency
This commit is contained in:
DreamPiggy 2018-01-23 14:47:20 +08:00 committed by GitHub
commit 6d64f740bb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 76 additions and 23 deletions

View File

@ -312,6 +312,18 @@
323F8C1D1F38EF770092B609 /* muxread.c in Sources */ = {isa = PBXBuildFile; fileRef = 323F8B3D1F38EF770092B609 /* muxread.c */; }; 323F8C1D1F38EF770092B609 /* muxread.c in Sources */ = {isa = PBXBuildFile; fileRef = 323F8B3D1F38EF770092B609 /* muxread.c */; };
323F8C1E1F38EF770092B609 /* muxread.c in Sources */ = {isa = PBXBuildFile; fileRef = 323F8B3D1F38EF770092B609 /* muxread.c */; }; 323F8C1E1F38EF770092B609 /* muxread.c in Sources */ = {isa = PBXBuildFile; fileRef = 323F8B3D1F38EF770092B609 /* muxread.c */; };
323F8C1F1F38EF770092B609 /* muxread.c in Sources */ = {isa = PBXBuildFile; fileRef = 323F8B3D1F38EF770092B609 /* muxread.c */; }; 323F8C1F1F38EF770092B609 /* muxread.c in Sources */ = {isa = PBXBuildFile; fileRef = 323F8B3D1F38EF770092B609 /* muxread.c */; };
324DF4B4200A14DC008A84CC /* SDWebImageDefine.h in Headers */ = {isa = PBXBuildFile; fileRef = 324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */; settings = {ATTRIBUTES = (Public, ); }; };
324DF4B5200A14DC008A84CC /* SDWebImageDefine.h in Headers */ = {isa = PBXBuildFile; fileRef = 324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */; settings = {ATTRIBUTES = (Public, ); }; };
324DF4B6200A14DC008A84CC /* SDWebImageDefine.h in Headers */ = {isa = PBXBuildFile; fileRef = 324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */; settings = {ATTRIBUTES = (Public, ); }; };
324DF4B7200A14DC008A84CC /* SDWebImageDefine.h in Headers */ = {isa = PBXBuildFile; fileRef = 324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */; settings = {ATTRIBUTES = (Public, ); }; };
324DF4B8200A14DC008A84CC /* SDWebImageDefine.h in Headers */ = {isa = PBXBuildFile; fileRef = 324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */; settings = {ATTRIBUTES = (Public, ); }; };
324DF4B9200A14DC008A84CC /* SDWebImageDefine.h in Headers */ = {isa = PBXBuildFile; fileRef = 324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */; settings = {ATTRIBUTES = (Public, ); }; };
324DF4BA200A14DC008A84CC /* SDWebImageDefine.m in Sources */ = {isa = PBXBuildFile; fileRef = 324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */; };
324DF4BB200A14DC008A84CC /* SDWebImageDefine.m in Sources */ = {isa = PBXBuildFile; fileRef = 324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */; };
324DF4BC200A14DC008A84CC /* SDWebImageDefine.m in Sources */ = {isa = PBXBuildFile; fileRef = 324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */; };
324DF4BD200A14DC008A84CC /* SDWebImageDefine.m in Sources */ = {isa = PBXBuildFile; fileRef = 324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */; };
324DF4BE200A14DC008A84CC /* SDWebImageDefine.m in Sources */ = {isa = PBXBuildFile; fileRef = 324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */; };
324DF4BF200A14DC008A84CC /* SDWebImageDefine.m in Sources */ = {isa = PBXBuildFile; fileRef = 324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */; };
3290FA041FA478AF0047D20C /* SDWebImageFrame.h in Headers */ = {isa = PBXBuildFile; fileRef = 3290FA021FA478AF0047D20C /* SDWebImageFrame.h */; settings = {ATTRIBUTES = (Public, ); }; }; 3290FA041FA478AF0047D20C /* SDWebImageFrame.h in Headers */ = {isa = PBXBuildFile; fileRef = 3290FA021FA478AF0047D20C /* SDWebImageFrame.h */; settings = {ATTRIBUTES = (Public, ); }; };
3290FA051FA478AF0047D20C /* SDWebImageFrame.h in Headers */ = {isa = PBXBuildFile; fileRef = 3290FA021FA478AF0047D20C /* SDWebImageFrame.h */; settings = {ATTRIBUTES = (Public, ); }; }; 3290FA051FA478AF0047D20C /* SDWebImageFrame.h in Headers */ = {isa = PBXBuildFile; fileRef = 3290FA021FA478AF0047D20C /* SDWebImageFrame.h */; settings = {ATTRIBUTES = (Public, ); }; };
3290FA061FA478AF0047D20C /* SDWebImageFrame.h in Headers */ = {isa = PBXBuildFile; fileRef = 3290FA021FA478AF0047D20C /* SDWebImageFrame.h */; settings = {ATTRIBUTES = (Public, ); }; }; 3290FA061FA478AF0047D20C /* SDWebImageFrame.h in Headers */ = {isa = PBXBuildFile; fileRef = 3290FA021FA478AF0047D20C /* SDWebImageFrame.h */; settings = {ATTRIBUTES = (Public, ); }; };
@ -1335,6 +1347,8 @@
323F8B3B1F38EF770092B609 /* muxi.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = muxi.h; sourceTree = "<group>"; }; 323F8B3B1F38EF770092B609 /* muxi.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = muxi.h; sourceTree = "<group>"; };
323F8B3C1F38EF770092B609 /* muxinternal.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = muxinternal.c; sourceTree = "<group>"; }; 323F8B3C1F38EF770092B609 /* muxinternal.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = muxinternal.c; sourceTree = "<group>"; };
323F8B3D1F38EF770092B609 /* muxread.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = muxread.c; sourceTree = "<group>"; }; 323F8B3D1F38EF770092B609 /* muxread.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = muxread.c; sourceTree = "<group>"; };
324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SDWebImageDefine.h; sourceTree = "<group>"; };
324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = SDWebImageDefine.m; sourceTree = "<group>"; };
3290FA021FA478AF0047D20C /* SDWebImageFrame.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SDWebImageFrame.h; sourceTree = "<group>"; }; 3290FA021FA478AF0047D20C /* SDWebImageFrame.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SDWebImageFrame.h; sourceTree = "<group>"; };
3290FA031FA478AF0047D20C /* SDWebImageFrame.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = SDWebImageFrame.m; sourceTree = "<group>"; }; 3290FA031FA478AF0047D20C /* SDWebImageFrame.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = SDWebImageFrame.m; sourceTree = "<group>"; };
329A18571FFF5DFD008C9A2F /* UIImage+WebCache.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = "UIImage+WebCache.h"; path = "SDWebImage/UIImage+WebCache.h"; sourceTree = "<group>"; }; 329A18571FFF5DFD008C9A2F /* UIImage+WebCache.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = "UIImage+WebCache.h"; path = "SDWebImage/UIImage+WebCache.h"; sourceTree = "<group>"; };
@ -1818,6 +1832,8 @@
53922D8F148C56230056699D /* SDWebImageManager.m */, 53922D8F148C56230056699D /* SDWebImageManager.m */,
53922D91148C56230056699D /* SDWebImagePrefetcher.h */, 53922D91148C56230056699D /* SDWebImagePrefetcher.h */,
53922D92148C56230056699D /* SDWebImagePrefetcher.m */, 53922D92148C56230056699D /* SDWebImagePrefetcher.m */,
324DF4B2200A14DC008A84CC /* SDWebImageDefine.h */,
324DF4B3200A14DC008A84CC /* SDWebImageDefine.m */,
); );
name = Utils; name = Utils;
sourceTree = "<group>"; sourceTree = "<group>";
@ -2018,6 +2034,7 @@
323F8B711F38EF770092B609 /* delta_palettization_enc.h in Headers */, 323F8B711F38EF770092B609 /* delta_palettization_enc.h in Headers */,
321E60B31F38E90100405457 /* SDWebImageWebPCoder.h in Headers */, 321E60B31F38E90100405457 /* SDWebImageWebPCoder.h in Headers */,
3290FA071FA478AF0047D20C /* SDWebImageFrame.h in Headers */, 3290FA071FA478AF0047D20C /* SDWebImageFrame.h in Headers */,
324DF4B7200A14DC008A84CC /* SDWebImageDefine.h in Headers */,
807A122B1F89636300EC2A9B /* SDWebImageCodersManager.h in Headers */, 807A122B1F89636300EC2A9B /* SDWebImageCodersManager.h in Headers */,
80377EC61F2F66D500F89830 /* webpi_dec.h in Headers */, 80377EC61F2F66D500F89830 /* webpi_dec.h in Headers */,
80377C591F2F666300F89830 /* random_utils.h in Headers */, 80377C591F2F666300F89830 /* random_utils.h in Headers */,
@ -2125,6 +2142,7 @@
80377E981F2F66D400F89830 /* alphai_dec.h in Headers */, 80377E981F2F66D400F89830 /* alphai_dec.h in Headers */,
4314D1791D0E0E3B004B36C9 /* SDWebImageManager.h in Headers */, 4314D1791D0E0E3B004B36C9 /* SDWebImageManager.h in Headers */,
323F8BE51F38EF770092B609 /* vp8li_enc.h in Headers */, 323F8BE51F38EF770092B609 /* vp8li_enc.h in Headers */,
324DF4B5200A14DC008A84CC /* SDWebImageDefine.h in Headers */,
80377C191F2F666300F89830 /* endian_inl_utils.h in Headers */, 80377C191F2F666300F89830 /* endian_inl_utils.h in Headers */,
321E60A31F38E8F600405457 /* SDWebImageGIFCoder.h in Headers */, 321E60A31F38E8F600405457 /* SDWebImageGIFCoder.h in Headers */,
4314D17C1D0E0E3B004B36C9 /* UIImage+WebP.h in Headers */, 4314D17C1D0E0E3B004B36C9 /* UIImage+WebP.h in Headers */,
@ -2207,6 +2225,7 @@
321E60981F38E8ED00405457 /* SDWebImageImageIOCoder.h in Headers */, 321E60981F38E8ED00405457 /* SDWebImageImageIOCoder.h in Headers */,
4369C27B1D9807EC007E863A /* UIView+WebCache.h in Headers */, 4369C27B1D9807EC007E863A /* UIView+WebCache.h in Headers */,
80377ED11F2F66D500F89830 /* vp8_dec.h in Headers */, 80377ED11F2F66D500F89830 /* vp8_dec.h in Headers */,
324DF4B8200A14DC008A84CC /* SDWebImageDefine.h in Headers */,
80377C751F2F666400F89830 /* rescaler_utils.h in Headers */, 80377C751F2F666400F89830 /* rescaler_utils.h in Headers */,
80377C6F1F2F666400F89830 /* quant_levels_dec_utils.h in Headers */, 80377C6F1F2F666400F89830 /* quant_levels_dec_utils.h in Headers */,
431BB6F01D06D2C1006A3455 /* SDWebImageOperation.h in Headers */, 431BB6F01D06D2C1006A3455 /* SDWebImageOperation.h in Headers */,
@ -2235,6 +2254,7 @@
80377C7E1F2F666400F89830 /* bit_writer_utils.h in Headers */, 80377C7E1F2F666400F89830 /* bit_writer_utils.h in Headers */,
80377ED81F2F66D500F89830 /* alphai_dec.h in Headers */, 80377ED81F2F66D500F89830 /* alphai_dec.h in Headers */,
321E60A71F38E8F600405457 /* SDWebImageGIFCoder.h in Headers */, 321E60A71F38E8F600405457 /* SDWebImageGIFCoder.h in Headers */,
324DF4B9200A14DC008A84CC /* SDWebImageDefine.h in Headers */,
80377EDA1F2F66D500F89830 /* common_dec.h in Headers */, 80377EDA1F2F66D500F89830 /* common_dec.h in Headers */,
80377EE61F2F66D500F89830 /* webpi_dec.h in Headers */, 80377EE61F2F66D500F89830 /* webpi_dec.h in Headers */,
4397D2BA1D0DDD8C00BB2784 /* demux.h in Headers */, 4397D2BA1D0DDD8C00BB2784 /* demux.h in Headers */,
@ -2331,6 +2351,7 @@
323F8B701F38EF770092B609 /* delta_palettization_enc.h in Headers */, 323F8B701F38EF770092B609 /* delta_palettization_enc.h in Headers */,
321E60B21F38E90100405457 /* SDWebImageWebPCoder.h in Headers */, 321E60B21F38E90100405457 /* SDWebImageWebPCoder.h in Headers */,
3290FA061FA478AF0047D20C /* SDWebImageFrame.h in Headers */, 3290FA061FA478AF0047D20C /* SDWebImageFrame.h in Headers */,
324DF4B6200A14DC008A84CC /* SDWebImageDefine.h in Headers */,
807A122A1F89636300EC2A9B /* SDWebImageCodersManager.h in Headers */, 807A122A1F89636300EC2A9B /* SDWebImageCodersManager.h in Headers */,
80377EB61F2F66D400F89830 /* webpi_dec.h in Headers */, 80377EB61F2F66D400F89830 /* webpi_dec.h in Headers */,
4A2CAE211AB4BB7000B6BC39 /* SDWebImageManager.h in Headers */, 4A2CAE211AB4BB7000B6BC39 /* SDWebImageManager.h in Headers */,
@ -2428,6 +2449,7 @@
80377C0F1F2F665300F89830 /* thread_utils.h in Headers */, 80377C0F1F2F665300F89830 /* thread_utils.h in Headers */,
321E60BE1F38E91700405457 /* UIImage+ForceDecode.h in Headers */, 321E60BE1F38E91700405457 /* UIImage+ForceDecode.h in Headers */,
5376131E155AD0D5005750A4 /* SDWebImagePrefetcher.h in Headers */, 5376131E155AD0D5005750A4 /* SDWebImagePrefetcher.h in Headers */,
324DF4B4200A14DC008A84CC /* SDWebImageDefine.h in Headers */,
80377CE11F2F66A100F89830 /* common_sse2.h in Headers */, 80377CE11F2F66A100F89830 /* common_sse2.h in Headers */,
80377C0B1F2F665300F89830 /* random_utils.h in Headers */, 80377C0B1F2F665300F89830 /* random_utils.h in Headers */,
80377E921F2F66D000F89830 /* vp8i_dec.h in Headers */, 80377E921F2F66D000F89830 /* vp8i_dec.h in Headers */,
@ -2804,6 +2826,7 @@
80377C521F2F666300F89830 /* huffman_utils.c in Sources */, 80377C521F2F666300F89830 /* huffman_utils.c in Sources */,
80377DD81F2F66A700F89830 /* lossless.c in Sources */, 80377DD81F2F66A700F89830 /* lossless.c in Sources */,
80377DE11F2F66A700F89830 /* rescaler_sse2.c in Sources */, 80377DE11F2F66A700F89830 /* rescaler_sse2.c in Sources */,
324DF4BD200A14DC008A84CC /* SDWebImageDefine.m in Sources */,
80377DAC1F2F66A700F89830 /* alpha_processing.c in Sources */, 80377DAC1F2F66A700F89830 /* alpha_processing.c in Sources */,
80377DE01F2F66A700F89830 /* rescaler_neon.c in Sources */, 80377DE01F2F66A700F89830 /* rescaler_neon.c in Sources */,
80377C541F2F666300F89830 /* quant_levels_dec_utils.c in Sources */, 80377C541F2F666300F89830 /* quant_levels_dec_utils.c in Sources */,
@ -2942,6 +2965,7 @@
80377D5C1F2F66A700F89830 /* upsampling_sse2.c in Sources */, 80377D5C1F2F66A700F89830 /* upsampling_sse2.c in Sources */,
323F8BC71F38EF770092B609 /* syntax_enc.c in Sources */, 323F8BC71F38EF770092B609 /* syntax_enc.c in Sources */,
80377D321F2F66A700F89830 /* dec_sse41.c in Sources */, 80377D321F2F66A700F89830 /* dec_sse41.c in Sources */,
324DF4BB200A14DC008A84CC /* SDWebImageDefine.m in Sources */,
80377D451F2F66A700F89830 /* lossless_enc_msa.c in Sources */, 80377D451F2F66A700F89830 /* lossless_enc_msa.c in Sources */,
80377C1A1F2F666300F89830 /* filters_utils.c in Sources */, 80377C1A1F2F666300F89830 /* filters_utils.c in Sources */,
323F8B9D1F38EF770092B609 /* picture_csp_enc.c in Sources */, 323F8B9D1F38EF770092B609 /* picture_csp_enc.c in Sources */,
@ -3087,6 +3111,7 @@
80377DFD1F2F66A800F89830 /* dec_mips32.c in Sources */, 80377DFD1F2F66A800F89830 /* dec_mips32.c in Sources */,
323F8BCA1F38EF770092B609 /* syntax_enc.c in Sources */, 323F8BCA1F38EF770092B609 /* syntax_enc.c in Sources */,
80377E2B1F2F66A800F89830 /* upsampling_sse2.c in Sources */, 80377E2B1F2F66A800F89830 /* upsampling_sse2.c in Sources */,
324DF4BE200A14DC008A84CC /* SDWebImageDefine.m in Sources */,
80377E011F2F66A800F89830 /* dec_sse41.c in Sources */, 80377E011F2F66A800F89830 /* dec_sse41.c in Sources */,
80377E141F2F66A800F89830 /* lossless_enc_msa.c in Sources */, 80377E141F2F66A800F89830 /* lossless_enc_msa.c in Sources */,
323F8BA01F38EF770092B609 /* picture_csp_enc.c in Sources */, 323F8BA01F38EF770092B609 /* picture_csp_enc.c in Sources */,
@ -3159,6 +3184,7 @@
80377E521F2F66A800F89830 /* filters_msa.c in Sources */, 80377E521F2F66A800F89830 /* filters_msa.c in Sources */,
329A18641FFF5DFD008C9A2F /* UIImage+WebCache.m in Sources */, 329A18641FFF5DFD008C9A2F /* UIImage+WebCache.m in Sources */,
80377C821F2F666400F89830 /* filters_utils.c in Sources */, 80377C821F2F666400F89830 /* filters_utils.c in Sources */,
324DF4BF200A14DC008A84CC /* SDWebImageDefine.m in Sources */,
4397D28C1D0DDD8C00BB2784 /* UIImageView+WebCache.m in Sources */, 4397D28C1D0DDD8C00BB2784 /* UIImageView+WebCache.m in Sources */,
80377E581F2F66A800F89830 /* lossless_enc_mips32.c in Sources */, 80377E581F2F66A800F89830 /* lossless_enc_mips32.c in Sources */,
4397D28F1D0DDD8C00BB2784 /* SDWebImageDownloaderOperation.m in Sources */, 4397D28F1D0DDD8C00BB2784 /* SDWebImageDownloaderOperation.m in Sources */,
@ -3389,6 +3415,7 @@
80377EB01F2F66D400F89830 /* vp8_dec.c in Sources */, 80377EB01F2F66D400F89830 /* vp8_dec.c in Sources */,
80377C381F2F666300F89830 /* huffman_utils.c in Sources */, 80377C381F2F666300F89830 /* huffman_utils.c in Sources */,
80377C3A1F2F666300F89830 /* quant_levels_dec_utils.c in Sources */, 80377C3A1F2F666300F89830 /* quant_levels_dec_utils.c in Sources */,
324DF4BC200A14DC008A84CC /* SDWebImageDefine.m in Sources */,
80377D931F2F66A700F89830 /* lossless.c in Sources */, 80377D931F2F66A700F89830 /* lossless.c in Sources */,
80377D9C1F2F66A700F89830 /* rescaler_sse2.c in Sources */, 80377D9C1F2F66A700F89830 /* rescaler_sse2.c in Sources */,
80377D671F2F66A700F89830 /* alpha_processing.c in Sources */, 80377D671F2F66A700F89830 /* alpha_processing.c in Sources */,
@ -3538,6 +3565,7 @@
80377C041F2F665300F89830 /* huffman_utils.c in Sources */, 80377C041F2F665300F89830 /* huffman_utils.c in Sources */,
80377C061F2F665300F89830 /* quant_levels_dec_utils.c in Sources */, 80377C061F2F665300F89830 /* quant_levels_dec_utils.c in Sources */,
80377D091F2F66A100F89830 /* lossless.c in Sources */, 80377D091F2F66A100F89830 /* lossless.c in Sources */,
324DF4BA200A14DC008A84CC /* SDWebImageDefine.m in Sources */,
80377D121F2F66A100F89830 /* rescaler_sse2.c in Sources */, 80377D121F2F66A100F89830 /* rescaler_sse2.c in Sources */,
80377CDD1F2F66A100F89830 /* alpha_processing.c in Sources */, 80377CDD1F2F66A100F89830 /* alpha_processing.c in Sources */,
80377D111F2F66A100F89830 /* rescaler_neon.c in Sources */, 80377D111F2F66A100F89830 /* rescaler_neon.c in Sources */,

View File

@ -107,7 +107,7 @@
} }
progress:progressBlock progress:progressBlock
completed:completedBlock completed:completedBlock
context:group ? @{SDWebImageInternalSetImageGroupKey : group} : nil]; context:group ? @{SDWebImageContextSetImageGroup : group} : nil];
} }
@end @end

View File

@ -8,6 +8,7 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
#import "SDWebImageDefine.h"
#import "SDImageCacheConfig.h" #import "SDImageCacheConfig.h"
typedef NS_ENUM(NSInteger, SDImageCacheType) { typedef NS_ENUM(NSInteger, SDImageCacheType) {

View File

@ -82,8 +82,6 @@
FOUNDATION_EXPORT UIImage * _Nullable SDScaledImageForKey(NSString * _Nullable key, UIImage * _Nullable image); FOUNDATION_EXPORT UIImage * _Nullable SDScaledImageForKey(NSString * _Nullable key, UIImage * _Nullable image);
typedef void(^SDWebImageNoParamsBlock)(void);
FOUNDATION_EXPORT NSString *const _Nonnull SDWebImageErrorDomain; FOUNDATION_EXPORT NSString *const _Nonnull SDWebImageErrorDomain;
#ifndef dispatch_queue_async_safe #ifndef dispatch_queue_async_safe

View File

@ -0,0 +1,22 @@
/*
* This file is part of the SDWebImage package.
* (c) Olivier Poitrey <rs@dailymotion.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
#import <Foundation/Foundation.h>
typedef void(^SDWebImageNoParamsBlock)(void);
typedef NSString * SDWebImageContextOption NS_STRING_ENUM;
typedef NSDictionary<SDWebImageContextOption, id> SDWebImageContext;
/**
A Dispatch group to maintain setImageBlock and completionBlock. This is used for custom setImageBlock advanced usage, such like perform background task but need to guarantee the completion block is called after setImageBlock. (dispatch_group_t)
*/
FOUNDATION_EXPORT SDWebImageContextOption _Nonnull const SDWebImageContextSetImageGroup;
/**
A SDWebImageManager instance to control the image download and cache process using in UIImageView+WebCache category and likes. If not provided, use the shared manager (SDWebImageManager)
*/
FOUNDATION_EXPORT SDWebImageContextOption _Nonnull const SDWebImageContextCustomManager;

View File

@ -0,0 +1,12 @@
/*
* This file is part of the SDWebImage package.
* (c) Olivier Poitrey <rs@dailymotion.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
#import "SDWebImageDefine.h"
SDWebImageContextOption const SDWebImageContextSetImageGroup = @"setImageGroup";
SDWebImageContextOption const SDWebImageContextCustomManager = @"customManager";

View File

@ -8,6 +8,7 @@
#import <Foundation/Foundation.h> #import <Foundation/Foundation.h>
#import "SDWebImageCompat.h" #import "SDWebImageCompat.h"
#import "SDWebImageDefine.h"
#import "SDWebImageOperation.h" #import "SDWebImageOperation.h"
typedef NS_OPTIONS(NSUInteger, SDWebImageDownloaderOptions) { typedef NS_OPTIONS(NSUInteger, SDWebImageDownloaderOptions) {

View File

@ -10,16 +10,9 @@
#if SD_UIKIT || SD_MAC #if SD_UIKIT || SD_MAC
#import "SDWebImageDefine.h"
#import "SDWebImageManager.h" #import "SDWebImageManager.h"
/**
A Dispatch group to maintain setImageBlock and completionBlock. This key should be used only internally and may be changed in the future. (dispatch_group_t)
*/
FOUNDATION_EXPORT NSString * _Nonnull const SDWebImageInternalSetImageGroupKey;
/**
A SDWebImageManager instance to control the image download and cache process using in UIImageView+WebCache category and likes. If not provided, use the shared manager (SDWebImageManager)
*/
FOUNDATION_EXPORT NSString * _Nonnull const SDWebImageExternalCustomManagerKey;
/** /**
The value specify that the image progress unit count cannot be determined because the progressBlock is not been called. The value specify that the image progress unit count cannot be determined because the progressBlock is not been called.
*/ */
@ -88,7 +81,7 @@ typedef void(^SDSetImageBlock)(UIImage * _Nullable image, NSData * _Nullable ima
* is nil and the second parameter may contain an NSError. The third parameter is a Boolean * is nil and the second parameter may contain an NSError. The third parameter is a Boolean
* indicating if the image was retrieved from the local cache or from the network. * indicating if the image was retrieved from the local cache or from the network.
* The fourth parameter is the original image url. * The fourth parameter is the original image url.
* @param context A context with extra information to perform specify changes or processes. * @param context A context contains different options to perform specify changes or processes, see `SDWebImageContextOption`. This hold the extra objects which `options` enum can not hold.
*/ */
- (void)sd_internalSetImageWithURL:(nullable NSURL *)url - (void)sd_internalSetImageWithURL:(nullable NSURL *)url
placeholderImage:(nullable UIImage *)placeholder placeholderImage:(nullable UIImage *)placeholder
@ -97,7 +90,7 @@ typedef void(^SDSetImageBlock)(UIImage * _Nullable image, NSData * _Nullable ima
setImageBlock:(nullable SDSetImageBlock)setImageBlock setImageBlock:(nullable SDSetImageBlock)setImageBlock
progress:(nullable SDWebImageDownloaderProgressBlock)progressBlock progress:(nullable SDWebImageDownloaderProgressBlock)progressBlock
completed:(nullable SDExternalCompletionBlock)completedBlock completed:(nullable SDExternalCompletionBlock)completedBlock
context:(nullable NSDictionary *)context; context:(nullable SDWebImageContext *)context;
/** /**
* Cancel the current image load * Cancel the current image load

View File

@ -13,9 +13,6 @@
#import "objc/runtime.h" #import "objc/runtime.h"
#import "UIView+WebCacheOperation.h" #import "UIView+WebCacheOperation.h"
NSString * const SDWebImageInternalSetImageGroupKey = @"internalSetImageGroup";
NSString * const SDWebImageExternalCustomManagerKey = @"externalCustomManager";
const int64_t SDWebImageProgressUnitCountUnknown = 1LL; const int64_t SDWebImageProgressUnitCountUnknown = 1LL;
static char imageURLKey; static char imageURLKey;
@ -66,14 +63,14 @@ static char TAG_ACTIVITY_SHOW;
setImageBlock:(nullable SDSetImageBlock)setImageBlock setImageBlock:(nullable SDSetImageBlock)setImageBlock
progress:(nullable SDWebImageDownloaderProgressBlock)progressBlock progress:(nullable SDWebImageDownloaderProgressBlock)progressBlock
completed:(nullable SDExternalCompletionBlock)completedBlock completed:(nullable SDExternalCompletionBlock)completedBlock
context:(nullable NSDictionary *)context { context:(nullable SDWebImageContext *)context {
NSString *validOperationKey = operationKey ?: NSStringFromClass([self class]); NSString *validOperationKey = operationKey ?: NSStringFromClass([self class]);
[self sd_cancelImageLoadOperationWithKey:validOperationKey]; [self sd_cancelImageLoadOperationWithKey:validOperationKey];
self.sd_imageURL = url; self.sd_imageURL = url;
if (!(options & SDWebImageDelayPlaceholder)) { if (!(options & SDWebImageDelayPlaceholder)) {
if ([context valueForKey:SDWebImageInternalSetImageGroupKey]) { if ([context valueForKey:SDWebImageContextSetImageGroup]) {
dispatch_group_t group = [context valueForKey:SDWebImageInternalSetImageGroupKey]; dispatch_group_t group = [context valueForKey:SDWebImageContextSetImageGroup];
dispatch_group_enter(group); dispatch_group_enter(group);
} }
dispatch_main_async_safe(^{ dispatch_main_async_safe(^{
@ -92,8 +89,8 @@ static char TAG_ACTIVITY_SHOW;
self.sd_imageProgress.completedUnitCount = 0; self.sd_imageProgress.completedUnitCount = 0;
SDWebImageManager *manager; SDWebImageManager *manager;
if ([context valueForKey:SDWebImageExternalCustomManagerKey]) { if ([context valueForKey:SDWebImageContextCustomManager]) {
manager = (SDWebImageManager *)[context valueForKey:SDWebImageExternalCustomManagerKey]; manager = (SDWebImageManager *)[context valueForKey:SDWebImageContextCustomManager];
} else { } else {
manager = [SDWebImageManager sharedManager]; manager = [SDWebImageManager sharedManager];
} }
@ -148,8 +145,8 @@ static char TAG_ACTIVITY_SHOW;
targetData = nil; targetData = nil;
} }
if ([context valueForKey:SDWebImageInternalSetImageGroupKey]) { if ([context valueForKey:SDWebImageContextSetImageGroup]) {
dispatch_group_t group = [context valueForKey:SDWebImageInternalSetImageGroupKey]; dispatch_group_t group = [context valueForKey:SDWebImageContextSetImageGroup];
dispatch_group_enter(group); dispatch_group_enter(group);
dispatch_main_async_safe(^{ dispatch_main_async_safe(^{
[sself sd_setImage:targetImage imageData:targetData basedOnClassOrViaCustomSetImageBlock:setImageBlock]; [sself sd_setImage:targetImage imageData:targetData basedOnClassOrViaCustomSetImageBlock:setImageBlock];

View File

@ -51,6 +51,7 @@ FOUNDATION_EXPORT const unsigned char WebImageVersionString[];
#import <SDWebImage/UIImage+GIF.h> #import <SDWebImage/UIImage+GIF.h>
#import <SDWebImage/UIImage+ForceDecode.h> #import <SDWebImage/UIImage+ForceDecode.h>
#import <SDWebImage/NSData+ImageContentType.h> #import <SDWebImage/NSData+ImageContentType.h>
#import <SDWebImage/SDWebImageDefine.h>
#if SD_MAC #if SD_MAC
#import <SDWebImage/NSImage+Additions.h> #import <SDWebImage/NSImage+Additions.h>