mirror of
https://github.com/ManchildProductions/UXP-Fixed.git
synced 2026-05-26 20:03:46 +00:00
Make resuming of decoding work for anonymous decoders.
This commit is contained in:
+14
-1
@@ -142,8 +142,10 @@ MetadataDecodingTask::Run()
|
||||
// AnonymousDecodingTask implementation.
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
AnonymousDecodingTask::AnonymousDecodingTask(NotNull<Decoder*> aDecoder)
|
||||
AnonymousDecodingTask::AnonymousDecodingTask(NotNull<Decoder*> aDecoder,
|
||||
bool aResumable)
|
||||
: mDecoder(aDecoder)
|
||||
, mResumable(aResumable)
|
||||
{ }
|
||||
|
||||
void
|
||||
@@ -168,5 +170,16 @@ AnonymousDecodingTask::Run()
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
AnonymousDecodingTask::Resume()
|
||||
{
|
||||
// Anonymous decoders normally get all their data at once. We have some situations
|
||||
// where they don't. If explicitly requested, resuming should be supported.
|
||||
if (mResumable) {
|
||||
RefPtr<AnonymousDecodingTask> self(this);
|
||||
NS_DispatchToMainThread(NS_NewRunnableFunction([self]() -> void { self->Run(); }));
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace image
|
||||
} // namespace mozilla
|
||||
|
||||
@@ -102,22 +102,20 @@ class AnonymousDecodingTask final : public IDecodingTask
|
||||
public:
|
||||
NS_INLINE_DECL_THREADSAFE_REFCOUNTING(AnonymousDecodingTask, override)
|
||||
|
||||
explicit AnonymousDecodingTask(NotNull<Decoder*> aDecoder);
|
||||
explicit AnonymousDecodingTask(NotNull<Decoder*> aDecoder, bool aResumable);
|
||||
|
||||
void Run() override;
|
||||
|
||||
bool ShouldPreferSyncRun() const override { return true; }
|
||||
TaskPriority Priority() const override { return TaskPriority::eLow; }
|
||||
|
||||
// Anonymous decoders normally get all their data at once. We have tests where
|
||||
// they don't; in these situations, the test re-runs them manually. So no
|
||||
// matter what, we don't want to resume by posting a task to the DecodePool.
|
||||
void Resume() override { }
|
||||
void Resume() override;
|
||||
|
||||
private:
|
||||
virtual ~AnonymousDecodingTask() { }
|
||||
|
||||
NotNull<RefPtr<Decoder>> mDecoder;
|
||||
bool mResumable;
|
||||
};
|
||||
|
||||
} // namespace image
|
||||
|
||||
+1
-1
@@ -126,7 +126,7 @@ ImageOps::DecodeToSurface(nsIInputStream* aInputStream,
|
||||
}
|
||||
|
||||
// Run the decoder synchronously.
|
||||
RefPtr<IDecodingTask> task = new AnonymousDecodingTask(WrapNotNull(decoder));
|
||||
RefPtr<IDecodingTask> task = new AnonymousDecodingTask(WrapNotNull(decoder), /* aResumable */ false);
|
||||
task->Run();
|
||||
if (!decoder->GetDecodeDone() || decoder->HasError()) {
|
||||
return nullptr;
|
||||
|
||||
Reference in New Issue
Block a user