diff options
author | bungeman <bungeman@google.com> | 2016-09-15 10:03:27 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-09-15 10:03:27 -0700 |
commit | d8c2476a8b1e1e1a1771b17e8dd4db8645914f8c (patch) | |
tree | 8b274ded4310cbc30791e448d2af7e3a448e4309 /src/core/SkStream.cpp | |
parent | 35b26a457100804b7a782cdff1132d2b65176c35 (diff) |
SkFontData to use smart pointers.
The SkFontData type is not exposed externally, so any method which uses
it can be updated to use smart pointers without affecting external
users. Updating this first will make updating the public API much
easier.
This also updates SkStreamAsset* SkStream::NewFromFile(const char*) to
std::unique_ptr<SkStreamAsset> SkStream::MakeFromFile(const char*). It
appears that no one outside Skia is currently using SkStream::NewfromFile
so this is a good time to update it as well.
GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2339273002
Review-Url: https://codereview.chromium.org/2339273002
Diffstat (limited to 'src/core/SkStream.cpp')
-rw-r--r-- | src/core/SkStream.cpp | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/src/core/SkStream.cpp b/src/core/SkStream.cpp index 48eb92cae5..e7b3a7a7e5 100644 --- a/src/core/SkStream.cpp +++ b/src/core/SkStream.cpp @@ -10,6 +10,7 @@ #include "SkStreamPriv.h" #include "SkData.h" #include "SkFixed.h" +#include "SkMakeUnique.h" #include "SkString.h" #include "SkOSFile.h" #include "SkTypes.h" @@ -854,20 +855,18 @@ static sk_sp<SkData> mmap_filename(const char path[]) { return data; } -SkStreamAsset* SkStream::NewFromFile(const char path[]) { +std::unique_ptr<SkStreamAsset> SkStream::MakeFromFile(const char path[]) { auto data(mmap_filename(path)); if (data) { - return new SkMemoryStream(std::move(data)); + return skstd::make_unique<SkMemoryStream>(std::move(data)); } - // If we get here, then our attempt at using mmap failed, so try normal - // file access. - SkFILEStream* stream = new SkFILEStream(path); + // If we get here, then our attempt at using mmap failed, so try normal file access. + auto stream = skstd::make_unique<SkFILEStream>(path); if (!stream->isValid()) { - delete stream; - stream = nullptr; + return nullptr; } - return stream; + return std::move(stream); } // Declared in SkStreamPriv.h: |