diff options
| author | Luke Pulverenti <luke.pulverenti@gmail.com> | 2015-03-27 00:17:04 -0400 |
|---|---|---|
| committer | Luke Pulverenti <luke.pulverenti@gmail.com> | 2015-03-27 00:17:04 -0400 |
| commit | 7773862facd1e58137257726a96b680718b2aa06 (patch) | |
| tree | 2ed5c1096469d09f88d64ecb0675005e8fab382a /MediaBrowser.Server.Implementations/Drawing/ImageProcessor.cs | |
| parent | dfaf935f5ead9ecaf57a7b624d4a8de374b68735 (diff) | |
fix subtitle syncing
Diffstat (limited to 'MediaBrowser.Server.Implementations/Drawing/ImageProcessor.cs')
| -rw-r--r-- | MediaBrowser.Server.Implementations/Drawing/ImageProcessor.cs | 58 |
1 files changed, 23 insertions, 35 deletions
diff --git a/MediaBrowser.Server.Implementations/Drawing/ImageProcessor.cs b/MediaBrowser.Server.Implementations/Drawing/ImageProcessor.cs index 5474892e8..d78d5e8ea 100644 --- a/MediaBrowser.Server.Implementations/Drawing/ImageProcessor.cs +++ b/MediaBrowser.Server.Implementations/Drawing/ImageProcessor.cs @@ -233,57 +233,45 @@ namespace MediaBrowser.Server.Implementations.Drawing await semaphore.WaitAsync().ConfigureAwait(false); - // Check again in case of lock contention - try - { - if (File.Exists(cacheFilePath)) - { - semaphore.Release(); - return cacheFilePath; - } - } - catch - { - semaphore.Release(); - throw; - } - try { CheckDisposed(); - var newWidth = Convert.ToInt32(newSize.Width); - var newHeight = Convert.ToInt32(newSize.Height); + if (!File.Exists(cacheFilePath)) + { + var newWidth = Convert.ToInt32(newSize.Width); + var newHeight = Convert.ToInt32(newSize.Height); - Directory.CreateDirectory(Path.GetDirectoryName(cacheFilePath)); + Directory.CreateDirectory(Path.GetDirectoryName(cacheFilePath)); - if (string.IsNullOrWhiteSpace(options.BackgroundColor)) - { - using (var originalImage = new MagickWand(originalImagePath)) + if (string.IsNullOrWhiteSpace(options.BackgroundColor)) { - originalImage.CurrentImage.ResizeImage(newWidth, newHeight); + using (var originalImage = new MagickWand(originalImagePath)) + { + originalImage.CurrentImage.ResizeImage(newWidth, newHeight); - DrawIndicator(originalImage, newWidth, newHeight, options); + DrawIndicator(originalImage, newWidth, newHeight, options); - originalImage.CurrentImage.CompressionQuality = quality; + originalImage.CurrentImage.CompressionQuality = quality; - originalImage.SaveImage(cacheFilePath); + originalImage.SaveImage(cacheFilePath); + } } - } - else - { - using (var wand = new MagickWand(newWidth, newHeight, options.BackgroundColor)) + else { - using (var originalImage = new MagickWand(originalImagePath)) + using (var wand = new MagickWand(newWidth, newHeight, options.BackgroundColor)) { - originalImage.CurrentImage.ResizeImage(newWidth, newHeight); + using (var originalImage = new MagickWand(originalImagePath)) + { + originalImage.CurrentImage.ResizeImage(newWidth, newHeight); - wand.CurrentImage.CompositeImage(originalImage, CompositeOperator.OverCompositeOp, 0, 0); - DrawIndicator(wand, newWidth, newHeight, options); + wand.CurrentImage.CompositeImage(originalImage, CompositeOperator.OverCompositeOp, 0, 0); + DrawIndicator(wand, newWidth, newHeight, options); - wand.CurrentImage.CompressionQuality = quality; + wand.CurrentImage.CompressionQuality = quality; - wand.SaveImage(cacheFilePath); + wand.SaveImage(cacheFilePath); + } } } } |
