The MASM Forum

General => The Campus => Topic started by: xoreaxeax on July 04, 2012, 05:58:32 AM

Title: WM_PAINT memory leak problem
Post by: xoreaxeax on July 04, 2012, 05:58:32 AM
Hello all, I think I have a memory leak problem which I isolated in my code:


.if uMsg==WM_PAINT
    invoke BeginPaint,hWnd,ADDR ps
    mov hdc,eax

    invoke CreateFont,FONT1H,FONT1W,0,0,400,0,0,0,OEM_CHARSET,OUT_DEFAULT_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH,ADDR TYPEFACE   
    invoke SelectObject,hdc,eax
    mov hfont,eax
   
    RGB 0,0,0
    invoke SetBkColor,hdc,eax
    RGB 0,255,0
    invoke SetTextColor,hdc,eax
    RGB Rr,Gg,Bb
    invoke SetTextColor,hdc,eax

    mov edi,pWorldTable
    mov esi,[edi+4]         ;get ID# of current active area
    lea edi,[edi+8]         ;point to first WorldX,WorldY
    dec esi
    shl esi,4
    lea edi,[edi+esi+8]   
    mov esi,[edi]           ;set ptr to active mem block/area
       
    .if (PAINT_CHAR>0)       ;==idx# to mob's X,Y in LocalTable
        push PAINT_CHAR
        pop edi
        UnCoords [esi+(edi*8)]
        mov ebx,[esi+(edi*8)+4]             ;->Char/Mob Sheet
        invoke SetTextColor,hdc,[ebx+OFFSET_CHARCOLOR]
        invoke TextOut,hdc,MobX,MobY,ADDR [ebx+OFFSET_CHARSYMB],1
        mov PAINT_CHAR,0
    .endif

    invoke EndPaint,hWnd,ADDR ps


It seems to happen specifically when the TextOut function is called.  Any ideas?  Thanks for any help!

Title: Re: WM_PAINT memory leak problem
Post by: qWord on July 04, 2012, 06:27:00 AM
Quote from: xoreaxeax on July 04, 2012, 05:58:32 AM
Hello all, I think I have a memory leak problem which I isolated in my code:
you have a (GDI) handle leak  ;)
Title: Re: WM_PAINT memory leak problem
Post by: jj2007 on July 04, 2012, 06:28:00 AM
"When you no longer need the font, call the DeleteObject function to delete it"
Title: Re: WM_PAINT memory leak problem
Post by: Ryan on July 04, 2012, 06:30:35 AM
http://msdn.microsoft.com/en-us/library/windows/desktop/dd183499%28v=vs.85%29.aspx

What jj said.
Title: Re: WM_PAINT memory leak problem
Post by: MichaelW on July 04, 2012, 06:56:48 AM
xor,

SelectObject is destroying the font handle in EAX before you copy it to hFont.

You should be saving the previous object returned by SelectObject and selecting it back into the paint DC before you reach EndPaint.

You should be deleting the font when you finish with it. And assuming that there are no variables in the font creation, I think it should be created once in your WM_CREATE or WM_INITDIALOG handler and deleted when you close the window or dialog.
Title: Re: WM_PAINT memory leak problem
Post by: jj2007 on July 04, 2012, 07:01:47 AM
Quote from: MichaelW on July 04, 2012, 06:56:48 AM
xor,

SelectObject is destroying the font handle in EAX before you copy it to hFont.

Yep, I had overlooked that one - thanks Michael :t

Wrong:
    invoke SelectObject,hdc,eax
    mov hfont,eax

Right:
    mov hfont,eax
    invoke SelectObject,hdc,eax
Title: Re: WM_PAINT memory leak problem
Post by: dedndave on July 04, 2012, 07:02:27 AM
what Michael said...
create the font once in WM_CREATE - save the font handle as hFont or something similar
delete the font object once in WM_DESTROY (use DeleteObject,hFont)
then - in WM_PAINT
invoke BeginPaint,hWnd,ADDR ps
    mov hdc,eax

    invoke SelectObject,hdc,hFont
    mov hFontOriginal,eax                  ;save the original hFont

;draw stuff here

    invoke SelectObject,hdc,hFontOriginal  ;restore the original hFont into the DC
    invoke EndPaint,hWnd,ADDR ps
Title: Re: WM_PAINT memory leak problem
Post by: xoreaxeax on July 04, 2012, 08:08:11 AM
Wow, you guys are awesome, thanks for all the help!  :t