Closed
Bug 832363
Opened 11 years ago
Closed 11 years ago
GC: Rooting updates to jsdate.cpp
Categories
(Core :: JavaScript Engine, defect)
Tracking
()
RESOLVED
FIXED
mozilla21
People
(Reporter: jonco, Assigned: jonco)
Details
Attachments
(1 file)
9.51 KB,
patch
|
sfink
:
review+
|
Details | Diff | Splinter Review |
Update the rooting in jsdate.cpp according to the static rooting analysis.
Assignee | ||
Comment 1•11 years ago
|
||
Assignee | ||
Comment 2•11 years ago
|
||
Comment on attachment 703945 [details] [diff] [review] Proposed fix Steve can you check that this is ok? Do we want to be fixing up the unnecessary rooting reported, or shall we leave that for now?
Attachment #703945 -
Flags: review?(sphink)
Comment 3•11 years ago
|
||
Comment on attachment 703945 [details] [diff] [review] Proposed fix Review of attachment 703945 [details] [diff] [review]: ----------------------------------------------------------------- r=me with those 2 Unrooteds changed to Raws. ::: js/src/jsdate.cpp @@ +767,5 @@ > * TZD = time zone designator (Z or +hh:mm or -hh:mm or missing for local) > */ > > static JSBool > +date_parseISOString(UnrootedLinearString str, double *result, DateTimeInfo *dtInfo) When there's no cx being passed in and no implicit cx being used, I'd definitely rather use Raw for these instead of Unrooted. Unrooted implies to me that there *is* some GCing possible, it just isn't in the region covered by the Unrooted. More generally, it sounds like we're now saying that maybe it's not worth using Unrooted (vs Raw) anywhere. But I haven't gotten that far yet; I'll probably continue to use Unrooted in places where it's simple and doesn't cause any trouble. @@ +906,5 @@ > #undef NEED_NDIGITS > } > > static JSBool > +date_parseString(UnrootedLinearString str, double *result, DateTimeInfo *dtInfo) same here @@ +3060,5 @@ > UnrootedString str = args[0].toString(); > if (!str) > return false; > > + UnrootedLinearString linearStr = DropUnrooted(str)->ensureLinear(cx); I would r+ either way, but |str| is an example of something that I'd probably switch to RawString now. The DropUnrooted is going to confuse people who aren't familiar with it, and it's not really doing any good here. (In fact, it's somewhat implying that ensureLinear could GC, which is not the case.)
Attachment #703945 -
Flags: review?(sphink) → review+
Comment 4•11 years ago
|
||
(In reply to Jon Coppeard (:jonco) from comment #2) > Comment on attachment 703945 [details] [diff] [review] > Proposed fix > > Steve can you check that this is ok? Do we want to be fixing up the > unnecessary rooting reported, or shall we leave that for now? I agree with you. I'm not planning on fixing over-rooting yet. I'll worry about that when we have proper rooting out of the way, so it unblocks other things.
Assignee | ||
Comment 5•11 years ago
|
||
https://hg.mozilla.org/integration/mozilla-inbound/rev/c2439886cc1b
Comment 6•11 years ago
|
||
https://hg.mozilla.org/mozilla-central/rev/c2439886cc1b
Status: ASSIGNED → RESOLVED
Closed: 11 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla21
You need to log in
before you can comment on or make changes to this bug.
Description
•