Closed
Bug 333387
Opened 18 years ago
Closed 18 years ago
[@ ns4xPluginInstance::Print]
Categories
(Core Graveyard :: Plug-ins, defect)
Tracking
(Not tracked)
RESOLVED
FIXED
People
(Reporter: timeless, Assigned: sciguyryan)
References
(Blocks 1 open bug, )
Details
(Keywords: coverity, crash)
Crash Data
Attachments
(1 file, 3 obsolete files)
1.35 KB,
patch
|
Details | Diff | Splinter Review |
found by coverity i wonder if we were really supposed to be checking something other than fCallbacks
Updated•18 years ago
|
Status: UNCONFIRMED → NEW
Ever confirmed: true
Assignee | ||
Comment 1•18 years ago
|
||
Assignee: nobody → sciguyryan+bugzilla
Status: NEW → ASSIGNED
Attachment #242421 -
Flags: superreview?(jst)
Attachment #242421 -
Flags: review?(jst)
Comment 2•18 years ago
|
||
Comment on attachment 242421 [details] [diff] [review] Patch v1 >- if(fCallbacks) { >+ if(fCallbacks->print) { I don't think we want to change this. Not that I can imagine how this could break any existing plugins, but you never really know, and there's really not much benefit in changing this here... [...] + NS_TRY_SAFE_CALL_VOID(CallNPP_PrintProc(fCallbacks->print, + &fNPP, + thePrint), fLibrary, this); } - NS_TRY_SAFE_CALL_VOID(CallNPP_PrintProc(fCallbacks->print, - &fNPP, - thePrint), fLibrary, this); - But this should be inside a if (fCallbacks->print) check. r+sr=jst with that changed.
Attachment #242421 -
Flags: superreview?(jst)
Attachment #242421 -
Flags: superreview-
Attachment #242421 -
Flags: review?(jst)
Attachment #242421 -
Flags: review-
Assignee | ||
Comment 3•18 years ago
|
||
Patch v2 too Johnny Stenback's comments. Do not alter the if check.
Attachment #242421 -
Attachment is obsolete: true
Attachment #243532 -
Flags: superreview?(jst)
Attachment #243532 -
Flags: review?(jst)
Comment 4•18 years ago
|
||
Comment on attachment 243532 [details] [diff] [review] Patch v2 + NS_TRY_SAFE_CALL_VOID(CallNPP_PrintProc(fCallbacks->print, + &fNPP, + thePrint), fLibrary, this); } - NS_TRY_SAFE_CALL_VOID(CallNPP_PrintProc(fCallbacks->print, - &fNPP, - thePrint), fLibrary, this); Unless I missed something the problem coverity was complaining about was that we were accessing fCallbacks->print w/o null checking it first. If so, then this change won't fix that problem. As I see this we want the above NS_TRY_SAFE_CALL_VOID() to remain outside the above if but we want it inside a if (fCallbacks->print) check. And if that's what we want we really could remove the above check that checks fCallbacks since it's a pointless check if we access fCallbacks here w/o the check. No other users of fCallbacks members check if fCallbacks is null or not before use, so loosing that check here too should be safe. > NPP_PLUGIN_LOG(PLUGIN_LOG_NORMAL, > ("NPP PrintProc called: this=%p, pDC=%p, [x=%d,y=%d,w=%d,h=%d], clip[t=%d,b=%d,l=%d,r=%d]\n", > this, > platformPrint->print.embedPrint.platformPrint, > platformPrint->print.embedPrint.window.x, > platformPrint->print.embedPrint.window.y, > platformPrint->print.embedPrint.window.width, > platformPrint->print.embedPrint.window.height,
Attachment #243532 -
Flags: superreview?(jst)
Attachment #243532 -
Flags: superreview-
Attachment #243532 -
Flags: review?(jst)
Attachment #243532 -
Flags: review-
Assignee | ||
Comment 5•18 years ago
|
||
Patch v3 (corrected of #2). Sorry I misunderstood what you said, corrected too comments and moved |NS_TRY_SAFE_CALL_VOID| call inside a |fCallbacks->print| if check.
Attachment #243532 -
Attachment is obsolete: true
Attachment #243539 -
Flags: superreview?(jst)
Attachment #243539 -
Flags: review?(jst)
Comment 6•18 years ago
|
||
Comment on attachment 243539 [details] [diff] [review] Patch v3 + if(fCallbacks->print) + NS_TRY_SAFE_CALL_VOID(CallNPP_PrintProc(fCallbacks->print, + &fNPP, + thePrint), fLibrary, this); r+sr=jst, though I'd put braces around that even if it's a one-liner. Thanks for fixing!
Attachment #243539 -
Flags: superreview?(jst)
Attachment #243539 -
Flags: superreview+
Attachment #243539 -
Flags: review?(jst)
Attachment #243539 -
Flags: review+
Assignee | ||
Comment 7•18 years ago
|
||
Final patch, added braces as suggested in comment #6.
Attachment #243539 -
Attachment is obsolete: true
Assignee | ||
Updated•18 years ago
|
Whiteboard: [checkin needed]
Comment 8•18 years ago
|
||
mozilla/modules/plugin/base/src/ns4xPluginInstance.cpp 1.134
Status: ASSIGNED → RESOLVED
Closed: 18 years ago
Resolution: --- → FIXED
Whiteboard: [checkin needed]
Updated•13 years ago
|
Crash Signature: [@ ns4xPluginInstance::Print]
Updated•6 years ago
|
Blocks: coverity-analysis
Updated•2 years ago
|
Product: Core → Core Graveyard
You need to log in
before you can comment on or make changes to this bug.
Description
•