More advanced dump log to file

From NSIS Wiki

Author: Afrow UK (talk, contrib)


[edit] Description

This is based on the original Dump log to file function by KiCHiK, but instead, only log's lines containing the inputted string.

[edit] Usage

This will write any lines containing "error" that were dumped to the log window during installation to "mappackage_errors1.txt".

Push error
Push "$EXEDIR\logs\mappackage_errors1.txt"
 Call AdvDumpLog

[edit] The Script

!define LVM_GETITEMCOUNT 0x1004
!define LVM_GETITEMTEXT 0x102D
 
Function AdvDumpLog
  Exch $5 ;input file
  Exch
  Exch $9 ;string to search for
  Push $0
  Push $1
  Push $2
  Push $3
  Push $4
  Push $6
  Push $7
  Push $8
  Push $R0
 
  FindWindow $0 "#32770" "" $HWNDPARENT
  GetDlgItem $0 $0 1016
  StrCmp $0 0 error
  FileOpen $5 $5 "w" ;change to "a" if you do not want to overwrite
  StrCmp $5 "" error
    SendMessage $0 ${LVM_GETITEMCOUNT} 0 0 $6
    System::Alloc ${NSIS_MAX_STRLEN}
    Pop $3
    StrCpy $2 0
    System::Call "*(i, i, i, i, i, i, i, i, i) i \
      (0, 0, 0, 0, 0, r3, ${NSIS_MAX_STRLEN}) .r1"
 
    loop:
        StrCmp $2 $6 done
      System::Call "User32::SendMessageA(i, i, i, i) i \
        ($0, ${LVM_GETITEMTEXT}, $2, r1)"
      System::Call "*$3(&t${NSIS_MAX_STRLEN} .r4)"
 
        StrLen $8 $9
        StrCpy $7 0
      searchloop:
        IntOp $7 $7 - 1
        StrCpy $R0 $4 $8 $7
	StrCmp $R0 "" +3
	StrCmp $R0 $9 0 searchloop
 
      FileWrite $5 "$4$\r$\n"
      IntOp $2 $2 + 1
      Goto loop
 
    done:
      FileClose $5
      System::Free $1
      System::Free $3
      Goto exit
 
  error:
    MessageBox MB_OK error
 
exit:
  Pop $8
  Pop $7
  Pop $6
  Pop $4
  Pop $3
  Pop $2
  Pop $1
  Pop $0
  Exch $9
  Exch
  Exch $5
FunctionEnd

-Stu (Afrow UK)

donate
ads