WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
139870
[SVG -> OTF Converter] Make Placeholder a move-only type
https://bugs.webkit.org/show_bug.cgi?id=139870
Summary
[SVG -> OTF Converter] Make Placeholder a move-only type
Myles C. Maxfield
Reported
2014-12-22 11:38:02 PST
[SVG -> OTF Converter] Make Placeholder a move-only type
Attachments
Patch
(2.70 KB, patch)
2014-12-22 11:39 PST
,
Myles C. Maxfield
no flags
Details
Formatted Diff
Diff
Patch
(2.74 KB, patch)
2014-12-22 12:51 PST
,
Myles C. Maxfield
no flags
Details
Formatted Diff
Diff
Patch
(2.62 KB, patch)
2014-12-23 10:36 PST
,
Myles C. Maxfield
andersca
: review+
Details
Formatted Diff
Diff
Show Obsolete
(2)
View All
Add attachment
proposed patch, testcase, etc.
Myles C. Maxfield
Comment 1
2014-12-22 11:39:59 PST
Created
attachment 243631
[details]
Patch
Myles C. Maxfield
Comment 2
2014-12-22 11:40:41 PST
I'm not sure if there's a better way to do this other than a movedOutOf boolean.
Myles C. Maxfield
Comment 3
2014-12-22 12:51:36 PST
Created
attachment 243636
[details]
Patch
Darin Adler
Comment 4
2014-12-22 22:42:52 PST
Comment on
attachment 243636
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=243636&action=review
> Source/WebCore/svg/SVGToOTFFontConversion.cpp:86 > + , m_movedOutOf(false)
This initialization should be !ASSERT_DISABLED only. But it should be omitted entirely (see below).
> Source/WebCore/svg/SVGToOTFFontConversion.cpp:103 > +#if !ASSERT_DISABLED > + , m_written(other.m_written) > +#endif
Doesn’t seem right to me. We should ASSERT(other.m_written) and just initialize m_written to true.
> Source/WebCore/svg/SVGToOTFFontConversion.cpp:106 > + other.m_movedOutOf = true;
Should only compile this when !ASSERT_DISABLED.
> Source/WebCore/svg/SVGToOTFFontConversion.cpp:123 > - ASSERT(m_written); > + ASSERT(m_movedOutOf || m_written);
Change doesn’t make sense to me. No reason to check m_movedOutOf here that I can see.
> Source/WebCore/svg/SVGToOTFFontConversion.cpp:130 > + unsigned m_movedOutOf : 1;
This should be !ASSERT_DISABLED only. This should be bool, not a bit field, because it’s !ASSERT_DISABLED only and size not all that important. This should be initialized here to cut down on initialization in constructors: bool m_movedOutOf { false };
> Source/WebCore/svg/SVGToOTFFontConversion.cpp:132 > + unsigned m_written : 1;
This should be bool, not a bit field, because it’s !ASSERT_DISABLED only and size not all that important. This should be initialized here to cut down on initialization in constructors: bool m_written { false };
Myles C. Maxfield
Comment 5
2014-12-23 10:36:39 PST
Created
attachment 243678
[details]
Patch
Myles C. Maxfield
Comment 6
2014-12-23 10:37:27 PST
Comment on
attachment 243636
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=243636&action=review
>> Source/WebCore/svg/SVGToOTFFontConversion.cpp:86 >> + , m_movedOutOf(false) > > This initialization should be !ASSERT_DISABLED only. But it should be omitted entirely (see below).
I've removed this variable, and renamed m_written to m_active, because a Placeholder which has been moved from but hasn't written anything yet should be marked as inactive. Populate() will then set m_active to false, and the destructor will ASSERT(!m_active);
Anders Carlsson
Comment 7
2014-12-23 10:40:22 PST
Comment on
attachment 243678
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=243678&action=review
> Source/WebCore/svg/SVGToOTFFontConversion.cpp:90 > + Placeholder(const Placeholder&) = delete;
Implementing a move constructor is enough to not make it have a copy constructor, so this isn't needed.
Myles C. Maxfield
Comment 8
2014-12-23 10:45:07 PST
Committed
r177688
: <
http://trac.webkit.org/changeset/177688
>
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug