Remove initialization on MIMETypeUtil

pull/1/head
Frederic Jacobs 10 years ago
parent 1f61291e0c
commit 7a5f9f1413

@ -20,9 +20,6 @@
#import "VersionMigrations.h" #import "VersionMigrations.h"
#import "UIColor+OWS.h" #import "UIColor+OWS.h"
#import "CodeVerificationViewController.h" #import "CodeVerificationViewController.h"
#import "MIMETypeUtil.h"
#import "TSDatabaseView.h"
#import <PastelogKit/Pastelog.h>
#ifdef __APPLE__ #ifdef __APPLE__
#include "TargetConditionals.h" #include "TargetConditionals.h"
@ -138,7 +135,7 @@ static NSString* const kCallSegue = @"2.0_6.0_Call_Segue";
[self refreshContacts]; [self refreshContacts];
[TSPreKeyManager refreshPreKeys]; [TSPreKeyManager refreshPreKeys];
} }
[MIMETypeUtil initialize];
return YES; return YES;
} }
@ -284,7 +281,11 @@ static NSString* const kCallSegue = @"2.0_6.0_Call_Segue";
window.windowLevel = CGFLOAT_MAX; window.windowLevel = CGFLOAT_MAX;
// There appears to be no more reliable way to get the launchscreen image from an asset bundle // There appears to be no more reliable way to get the launchscreen image from an asset bundle
NSDictionary *dict = @{@"320x480" : @"LaunchImage-700", @"320x568" : @"LaunchImage-700-568h", @"375x667" : @"LaunchImage-800-667h", @"414x736" : @"LaunchImage-800-Portrait-736h"}; NSDictionary *dict = @{@"320x480" : @"LaunchImage-700",
@"320x568" : @"LaunchImage-700-568h",
@"375x667" : @"LaunchImage-800-667h",
@"414x736" : @"LaunchImage-800-Portrait-736h"};
NSString *key = [NSString stringWithFormat:@"%dx%d", (int)[UIScreen mainScreen].bounds.size.width, (int)[UIScreen mainScreen].bounds.size.height]; NSString *key = [NSString stringWithFormat:@"%dx%d", (int)[UIScreen mainScreen].bounds.size.width, (int)[UIScreen mainScreen].bounds.size.height];
UIImage *launchImage = [UIImage imageNamed:dict[key]]; UIImage *launchImage = [UIImage imageNamed:dict[key]];
UIImageView *imgView = [[UIImageView alloc] initWithImage:launchImage]; UIImageView *imgView = [[UIImageView alloc] initWithImage:launchImage];

@ -2,8 +2,6 @@
@interface MIMETypeUtil : NSObject @interface MIMETypeUtil : NSObject
+(void) initialize;
+(BOOL)isSupportedMIMEType:(NSString*)contentType; +(BOOL)isSupportedMIMEType:(NSString*)contentType;
+(BOOL)isSupportedVideoMIMEType:(NSString*)contentType; +(BOOL)isSupportedVideoMIMEType:(NSString*)contentType;
+(BOOL)isSupportedAudioMIMEType:(NSString*)contentType; +(BOOL)isSupportedAudioMIMEType:(NSString*)contentType;

@ -3,24 +3,17 @@
@implementation MIMETypeUtil @implementation MIMETypeUtil
static NSDictionary *supportedVideoMIMETypesToExtensionTypes; + (NSDictionary*)supportedVideoMIMETypesToExtensionTypes{
static NSDictionary *supportedAudioMIMETypesToExtensionTypes; return @{@"video/3gpp":@"3gp",
static NSDictionary *supportedImageMIMETypesToExtensionTypes;
static NSDictionary *supportedVideoExtensionTypesToMIMETypes;
static NSDictionary *supportedAudioExtensionTypesToMIMETypes;
static NSDictionary *supportedImageExtensionTypesToMIMETypes;
#pragma mark uses file extensions or MIME types only
+(void) initialize {
// Initialize must be called before this class is used. Could later be in e.g. a .plist
supportedVideoMIMETypesToExtensionTypes =@{@"video/3gpp":@"3gp",
@"video/3gpp2":@"3g2", @"video/3gpp2":@"3g2",
@"video/mp4":@"mp4", @"video/mp4":@"mp4",
@"video/quicktime":@"mov", @"video/quicktime":@"mov",
@"video/x-m4v":@"m4v" @"video/x-m4v":@"m4v"
}; };
}
supportedAudioMIMETypesToExtensionTypes = @{@"audio/x-m4p":@"m4p", + (NSDictionary*)supportedAudioMIMETypesToExtensionTypes{
return @{@"audio/x-m4p":@"m4p",
@"audio/x-m4b":@"m4b", @"audio/x-m4b":@"m4b",
@"audio/x-m4a":@"m4a", @"audio/x-m4a":@"m4a",
@"audio/wav":@"wav", @"audio/wav":@"wav",
@ -38,9 +31,10 @@ static NSDictionary *supportedImageExtensionTypesToMIMETypes;
@"audio/3gpp2":@"3g2", @"audio/3gpp2":@"3g2",
@"audio/3gpp":@"3gp" @"audio/3gpp":@"3gp"
}; };
}
+ (NSDictionary*)supportedImageMIMETypesToExtensionTypes{
supportedImageMIMETypesToExtensionTypes = @{@"image/jpeg":@"jpeg", return @{@"image/jpeg":@"jpeg",
@"image/pjpeg":@"jpeg", @"image/pjpeg":@"jpeg",
@"image/png":@"png", @"image/png":@"png",
@"image/gif":@"gif", @"image/gif":@"gif",
@ -49,9 +43,10 @@ static NSDictionary *supportedImageExtensionTypesToMIMETypes;
@"image/bmp":@"bmp", @"image/bmp":@"bmp",
@"image/x-windows-bmp":@"bmp" @"image/x-windows-bmp":@"bmp"
}; };
}
+ (NSDictionary*)supportedVideoExtensionTypesToMIMETypes{
supportedVideoExtensionTypesToMIMETypes = @{@"3gp":@"video/3gpp", return @{@"3gp":@"video/3gpp",
@"3gpp":@"video/3gpp", @"3gpp":@"video/3gpp",
@"3gp2":@"video/3gpp2", @"3gp2":@"video/3gpp2",
@"3gpp2":@"video/3gpp2", @"3gpp2":@"video/3gpp2",
@ -60,8 +55,9 @@ static NSDictionary *supportedImageExtensionTypesToMIMETypes;
@"mqv":@"video/quicktime", @"mqv":@"video/quicktime",
@"m4v":@"video/x-m4v" @"m4v":@"video/x-m4v"
}; };
}
supportedAudioExtensionTypesToMIMETypes = @{@"3gp":@"audio/3gpp", + (NSDictionary*)supportedAudioExtensionTypesToMIMETypes{
return @{@"3gp":@"audio/3gpp",
@"3gpp":@"@audio/3gpp", @"3gpp":@"@audio/3gpp",
@"3g2":@"audio/3gpp2", @"3g2":@"audio/3gpp2",
@"3gp2":@"audio/3gpp2", @"3gp2":@"audio/3gpp2",
@ -81,8 +77,10 @@ static NSDictionary *supportedImageExtensionTypesToMIMETypes;
@"m4b":@"audio/x-m4b", @"m4b":@"audio/x-m4b",
@"m4p":@"audio/x-m4p" @"m4p":@"audio/x-m4p"
}; };
}
supportedImageExtensionTypesToMIMETypes = @{@"png":@"image/png", + (NSDictionary*)supportedImageExtensionTypesToMIMETypes{
return @{@"png":@"image/png",
@"x-png":@"image/png", @"x-png":@"image/png",
@"jfif":@"image/jpeg", @"jfif":@"image/jpeg",
@"jfif":@"image/pjpeg", @"jfif":@"image/pjpeg",
@ -98,15 +96,15 @@ static NSDictionary *supportedImageExtensionTypesToMIMETypes;
} }
+(BOOL) isSupportedVideoMIMEType:(NSString*)contentType { +(BOOL) isSupportedVideoMIMEType:(NSString*)contentType {
return [supportedVideoMIMETypesToExtensionTypes objectForKey:contentType]!=nil; return [[self supportedVideoMIMETypesToExtensionTypes] objectForKey:contentType]!=nil;
} }
+(BOOL) isSupportedAudioMIMEType:(NSString*)contentType { +(BOOL) isSupportedAudioMIMEType:(NSString*)contentType {
return [supportedAudioMIMETypesToExtensionTypes objectForKey:contentType]!=nil; return [[self supportedAudioMIMETypesToExtensionTypes] objectForKey:contentType]!=nil;
} }
+(BOOL) isSupportedImageMIMEType:(NSString*)contentType { +(BOOL) isSupportedImageMIMEType:(NSString*)contentType {
return [supportedImageMIMETypesToExtensionTypes objectForKey:contentType]!=nil; return [[self supportedImageMIMETypesToExtensionTypes] objectForKey:contentType]!=nil;
} }
+(BOOL) isSupportedMIMEType:(NSString*)contentType { +(BOOL) isSupportedMIMEType:(NSString*)contentType {
@ -114,39 +112,39 @@ static NSDictionary *supportedImageExtensionTypesToMIMETypes;
} }
+(BOOL) isSupportedVideoFile:(NSString*) filePath { +(BOOL) isSupportedVideoFile:(NSString*) filePath {
return [supportedVideoExtensionTypesToMIMETypes objectForKey:[filePath pathExtension]]!=nil; return [[self supportedVideoExtensionTypesToMIMETypes] objectForKey:[filePath pathExtension]]!=nil;
} }
+(BOOL) isSupportedAudioFile:(NSString*) filePath { +(BOOL) isSupportedAudioFile:(NSString*) filePath {
return [supportedAudioExtensionTypesToMIMETypes objectForKey:[filePath pathExtension]]!=nil; return [[self supportedAudioExtensionTypesToMIMETypes] objectForKey:[filePath pathExtension]]!=nil;
} }
+(BOOL) isSupportedImageFile:(NSString*) filePath { +(BOOL) isSupportedImageFile:(NSString*) filePath {
return [supportedImageExtensionTypesToMIMETypes objectForKey:[filePath pathExtension]]!=nil; return [[self supportedImageExtensionTypesToMIMETypes] objectForKey:[filePath pathExtension]]!=nil;
} }
+(NSString*) getSupportedExtensionFromVideoMIMEType:(NSString*)supportedMIMEType { +(NSString*) getSupportedExtensionFromVideoMIMEType:(NSString*)supportedMIMEType {
return [supportedVideoMIMETypesToExtensionTypes objectForKey:supportedMIMEType]; return [[self supportedVideoMIMETypesToExtensionTypes] objectForKey:supportedMIMEType];
} }
+(NSString*) getSupportedExtensionFromAudioMIMEType:(NSString*)supportedMIMEType { +(NSString*) getSupportedExtensionFromAudioMIMEType:(NSString*)supportedMIMEType {
return [supportedAudioMIMETypesToExtensionTypes objectForKey:supportedMIMEType]; return [[self supportedAudioMIMETypesToExtensionTypes] objectForKey:supportedMIMEType];
} }
+(NSString*) getSupportedExtensionFromImageMIMEType:(NSString*)supportedMIMEType { +(NSString*) getSupportedExtensionFromImageMIMEType:(NSString*)supportedMIMEType {
return [supportedImageMIMETypesToExtensionTypes objectForKey:supportedMIMEType]; return [[self supportedImageMIMETypesToExtensionTypes] objectForKey:supportedMIMEType];
} }
+(NSString*) getSupportedMIMETypeFromVideoFile:(NSString*)supportedVideoFile { +(NSString*) getSupportedMIMETypeFromVideoFile:(NSString*)supportedVideoFile {
return [supportedVideoExtensionTypesToMIMETypes objectForKey:[supportedVideoFile pathExtension]]; return [[self supportedVideoExtensionTypesToMIMETypes] objectForKey:[supportedVideoFile pathExtension]];
} }
+(NSString*) getSupportedMIMETypeFromAudioFile:(NSString*)supportedAudioFile { +(NSString*) getSupportedMIMETypeFromAudioFile:(NSString*)supportedAudioFile {
return [supportedAudioExtensionTypesToMIMETypes objectForKey:[supportedAudioFile pathExtension]]; return [[self supportedAudioExtensionTypesToMIMETypes] objectForKey:[supportedAudioFile pathExtension]];
} }
+(NSString*) getSupportedMIMETypeFromImageFile:(NSString*)supportedImageFile { +(NSString*) getSupportedMIMETypeFromImageFile:(NSString*)supportedImageFile {
return [supportedImageExtensionTypesToMIMETypes objectForKey:[supportedImageFile pathExtension]]; return [[self supportedImageExtensionTypesToMIMETypes] objectForKey:[supportedImageFile pathExtension]];
} }
#pragma mark uses bytes #pragma mark uses bytes
@ -189,7 +187,7 @@ static NSDictionary *supportedImageExtensionTypesToMIMETypes;
+(NSURL*) simLinkCorrectExtensionOfFile:(NSURL*)mediaURL ofMIMEType:(NSString*)contentType { +(NSURL*) simLinkCorrectExtensionOfFile:(NSURL*)mediaURL ofMIMEType:(NSString*)contentType {
if([self isAudio:contentType]) { if([self isAudio:contentType]) {
// Audio files in current framework require changing to have extension for player // Audio files in current framework require changing to have extension for player
return [self changeFile:mediaURL toHaveExtension:[supportedAudioMIMETypesToExtensionTypes objectForKey:contentType]]; return [self changeFile:mediaURL toHaveExtension:[[self supportedAudioMIMETypesToExtensionTypes] objectForKey:contentType]];
} }
return mediaURL; return mediaURL;
} }

Loading…
Cancel
Save