2000-09-18 15:18:56 +00:00
|
|
|
|
/*************************************************************************
|
|
|
|
|
*
|
|
|
|
|
* $RCSfile: msgedit.cxx,v $
|
|
|
|
|
*
|
2004-12-10 16:16:04 +00:00
|
|
|
|
* $Revision: 1.18 $
|
2000-09-18 15:18:56 +00:00
|
|
|
|
*
|
2004-12-10 16:16:04 +00:00
|
|
|
|
* last change: $Author: rt $ $Date: 2004-12-10 17:16:04 $
|
2000-09-18 15:18:56 +00:00
|
|
|
|
*
|
|
|
|
|
* The Contents of this file are made available subject to the terms of
|
|
|
|
|
* either of the following licenses
|
|
|
|
|
*
|
|
|
|
|
* - GNU Lesser General Public License Version 2.1
|
|
|
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
|
|
|
*
|
|
|
|
|
* Sun Microsystems Inc., October, 2000
|
|
|
|
|
*
|
|
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
|
* =============================================
|
|
|
|
|
* Copyright 2000 by Sun Microsystems, Inc.
|
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
|
|
|
|
*
|
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
|
* License version 2.1, as published by the Free Software Foundation.
|
|
|
|
|
*
|
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
|
* MA 02111-1307 USA
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* Sun Industry Standards Source License Version 1.1
|
|
|
|
|
* =================================================
|
|
|
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
|
|
|
* Source License Version 1.1 (the "License"); You may not use this file
|
|
|
|
|
* except in compliance with the License. You may obtain a copy of the
|
|
|
|
|
* License at http://www.openoffice.org/license.html.
|
|
|
|
|
*
|
|
|
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
|
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
|
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
|
|
|
* See the License for the specific provisions governing your rights and
|
|
|
|
|
* obligations concerning the Software.
|
|
|
|
|
*
|
|
|
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
|
|
|
*
|
|
|
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
|
|
|
*
|
|
|
|
|
* All Rights Reserved.
|
|
|
|
|
*
|
|
|
|
|
* Contributor(s): _______________________________________
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
************************************************************************/
|
|
|
|
|
/*************************************************************************
|
|
|
|
|
File Versions so far:
|
|
|
|
|
No Version Initial Implementation without Version Information
|
|
|
|
|
Version 2 changed order of entries(New Entries at the end)
|
|
|
|
|
Version 3 Changed Charset from CHARSET_IBMPC to RTL_TEXTENCODING_UTF8
|
|
|
|
|
|
|
|
|
|
*************************************************************************/
|
|
|
|
|
#ifndef _INTN_HXX //autogen
|
|
|
|
|
#include <tools/intn.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _TIME_HXX //autogen
|
|
|
|
|
#include <tools/time.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _STREAM_HXX //autogen
|
|
|
|
|
#include <tools/stream.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _MSGBOX_HXX //autogen
|
|
|
|
|
#include <vcl/msgbox.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _SOUND_HXX //autogen
|
|
|
|
|
#include <vcl/sound.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _FSYS_HXX //autogen
|
|
|
|
|
#include <tools/fsys.hxx>
|
|
|
|
|
#endif
|
2001-04-04 12:18:57 +00:00
|
|
|
|
#ifndef _SVTOOLS_STRINGTRANSFER_HXX_
|
|
|
|
|
#include <svtools/stringtransfer.hxx>
|
2000-09-18 15:18:56 +00:00
|
|
|
|
#endif
|
2001-07-11 08:44:47 +00:00
|
|
|
|
#ifndef INCLUDED_SVTOOLS_SYSLOCALE_HXX
|
|
|
|
|
#include <svtools/syslocale.hxx>
|
|
|
|
|
#endif
|
2000-09-18 15:18:56 +00:00
|
|
|
|
#ifndef _BASIC_TTRESHLP_HXX
|
|
|
|
|
#include "ttstrhlp.hxx"
|
|
|
|
|
#endif
|
|
|
|
|
#include "basic.hrc"
|
|
|
|
|
#include "msgedit.hxx"
|
|
|
|
|
#include "app.hxx"
|
2002-03-28 13:43:03 +00:00
|
|
|
|
#include "apperror.hxx"
|
2000-09-18 15:18:56 +00:00
|
|
|
|
#include "appbased.hxx"
|
|
|
|
|
#include "basmsg.hrc"
|
|
|
|
|
|
2004-06-17 10:47:06 +00:00
|
|
|
|
USHORT MsgEdit::nMaxLogLen = 0;
|
|
|
|
|
BOOL MsgEdit::bLimitLogLen = FALSE;
|
|
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
|
#define WARNING_PREFIX String( ResId( S_WARNING_PREFIX ) )
|
|
|
|
|
#define VERSION_STRING CUniString("File Format Version: ")
|
|
|
|
|
#define THIS_VERSION 2
|
|
|
|
|
|
|
|
|
|
#define LOGTYPE( pEntry ) ((pEntry && pEntry->GetUserData())?((TTDebugData*)pEntry->GetUserData())->aLogType:LOG_ERROR)
|
|
|
|
|
|
2002-03-28 13:43:03 +00:00
|
|
|
|
MsgEdit::MsgEdit( AppError* pParent, BasicFrame *pBF, const WinBits& aBits )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
: aEditTree( pParent, pBF, aBits | WB_HASBUTTONS | WB_HASLINES | WB_HASBUTTONSATROOT )
|
|
|
|
|
, pBasicFrame(pBF)
|
|
|
|
|
, pCurrentRun(NULL)
|
|
|
|
|
, pCurrentTestCase(NULL)
|
2003-04-17 16:17:22 +00:00
|
|
|
|
, pCurrentAssertion( NULL )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
, pCurrentError(NULL)
|
|
|
|
|
, nVersion(0)
|
|
|
|
|
, bFileLoading(FALSE)
|
|
|
|
|
, bModified(FALSE)
|
2002-03-28 13:43:03 +00:00
|
|
|
|
, pAppError( pParent )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
{
|
2002-04-11 07:38:47 +00:00
|
|
|
|
// SetFont( aEditTree.GetDefaultFont( DEFAULTFONT_FIXED, aEditTree.GetSettings().GetLanguage(), 0, &aEditTree ) );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.SetNodeBitmaps( Bitmap( ResId (MBP_PLUS) ), Bitmap( ResId (MBP_MINUS) ) );
|
|
|
|
|
aEditTree.SetSelectionMode( MULTIPLE_SELECTION );
|
|
|
|
|
if ( aEditTree.GetModel()->GetSortMode() != SortNone )
|
|
|
|
|
aEditTree.GetModel()->SetSortMode( SortNone );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MsgEdit::~MsgEdit()
|
|
|
|
|
{}
|
|
|
|
|
|
2004-06-17 10:47:06 +00:00
|
|
|
|
// set the LogType since calling the add method can be from other add methods
|
|
|
|
|
#define COPY_TTDEBUGDATA( LOGTYPE ) \
|
|
|
|
|
TTDebugData *pTTDebugData = new TTDebugData; \
|
|
|
|
|
*pTTDebugData = aDebugData; \
|
|
|
|
|
pTTDebugData->aLogType = LOGTYPE; \
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddAnyMsg( TTLogMsg *LogMsg )
|
|
|
|
|
{
|
|
|
|
|
if ( LogMsg->aDebugData.aFilename.Copy(0,2).CompareToAscii( "--" ) == COMPARE_EQUAL )
|
|
|
|
|
LogMsg->aDebugData.aFilename.Erase(0,2);
|
2002-03-28 13:43:03 +00:00
|
|
|
|
|
2002-07-04 09:29:15 +00:00
|
|
|
|
if ( LogMsg->aDebugData.aFilename.Len() && LogMsg->aDebugData.aFilename.GetChar(0) != '~' ) // do we want to convert
|
2002-03-28 13:43:03 +00:00
|
|
|
|
{
|
|
|
|
|
DirEntry aConvert( LogMsg->aDebugData.aFilename );
|
|
|
|
|
if ( pAppError->aBaseDir.Contains( aConvert ) )
|
|
|
|
|
{
|
|
|
|
|
aConvert.ToRel( pAppError->aBaseDir );
|
|
|
|
|
LogMsg->aDebugData.aFilename = CUniString("~"); // mark as converted
|
|
|
|
|
LogMsg->aDebugData.aFilename += aConvert.GetFull( FSYS_STYLE_VFAT );
|
|
|
|
|
}
|
|
|
|
|
else if ( !bFileLoading )
|
|
|
|
|
{
|
|
|
|
|
LogMsg->aDebugData.aFilename.Insert( CUniString("~-"), 0); // mark as unconvertable
|
|
|
|
|
}
|
|
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
|
xub_StrLen nPos;
|
|
|
|
|
LogMsg->aDebugData.aMsg.ConvertLineEnd();
|
2004-01-19 16:54:34 +00:00
|
|
|
|
// does the message have several lines -> repeat the call for each line
|
2000-09-18 15:18:56 +00:00
|
|
|
|
if ( (nPos = LogMsg->aDebugData.aMsg.Search( CUniString("\n").ConvertLineEnd() )) != STRING_NOTFOUND )
|
|
|
|
|
{
|
2004-01-19 16:54:34 +00:00
|
|
|
|
String aOriginalMsg = LogMsg->aDebugData.aMsg;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
xub_StrLen nSysLineEndLen = CUniString("\n").ConvertLineEnd().Len();
|
|
|
|
|
String aLastPart = LogMsg->aDebugData.aMsg.Copy( nPos+nSysLineEndLen );
|
|
|
|
|
LogMsg->aDebugData.aMsg.Erase( nPos );
|
|
|
|
|
AddAnyMsg( LogMsg );
|
2003-04-17 16:17:22 +00:00
|
|
|
|
if ( aLastPart.Len() )
|
|
|
|
|
{
|
|
|
|
|
LogMsg->aDebugData.aMsg = aLastPart;
|
|
|
|
|
AddAnyMsg( LogMsg );
|
|
|
|
|
}
|
2004-01-19 16:54:34 +00:00
|
|
|
|
LogMsg->aDebugData.aMsg = aOriginalMsg;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
String aUILogMsg( pBasicFrame->GenRealString( LogMsg->aDebugData.aMsg ) );
|
|
|
|
|
switch ( LogMsg->aDebugData.aLogType )
|
|
|
|
|
{
|
|
|
|
|
case LOG_RUN:
|
|
|
|
|
{
|
|
|
|
|
if ( LogMsg->aDebugData.aMsg.Len() == 0 )
|
|
|
|
|
{
|
2001-07-11 08:44:47 +00:00
|
|
|
|
SvtSysLocale aLocale;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
LogMsg->aDebugData.aMsg = GEN_RES_STR2( S_PROG_START,
|
2001-07-11 08:44:47 +00:00
|
|
|
|
aLocale.GetLocaleData().getDate(Date()),
|
|
|
|
|
aLocale.GetLocaleData().getTime(Time()) );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aUILogMsg = pBasicFrame->GenRealString( LogMsg->aDebugData.aMsg );
|
|
|
|
|
}
|
|
|
|
|
AddRun( aUILogMsg, LogMsg->aDebugData ); break;
|
|
|
|
|
}
|
|
|
|
|
case LOG_TEST_CASE: AddTestCase( aUILogMsg, LogMsg->aDebugData ); break;
|
|
|
|
|
case LOG_ERROR: AddError( aUILogMsg, LogMsg->aDebugData ); break;
|
|
|
|
|
case LOG_CALL_STACK:AddCallStack( aUILogMsg, LogMsg->aDebugData ); break;
|
|
|
|
|
case LOG_MESSAGE: AddMessage( aUILogMsg, LogMsg->aDebugData ); break;
|
|
|
|
|
case LOG_WARNING: AddWarning( aUILogMsg, LogMsg->aDebugData ); break;
|
|
|
|
|
case LOG_ASSERTION: AddAssertion( aUILogMsg, LogMsg->aDebugData ); break;
|
2003-04-17 16:17:22 +00:00
|
|
|
|
case LOG_ASSERTION_STACK: AddAssertionStack( aUILogMsg, LogMsg->aDebugData ); break;
|
2003-03-18 15:28:40 +00:00
|
|
|
|
case LOG_QA_ERROR: AddQAError( aUILogMsg, LogMsg->aDebugData ); break;
|
|
|
|
|
default:DBG_ERROR("Unbekannter Typ in ResultFile. Speichern des ResultFile resultiert in Informationsverlust");
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( !bFileLoading )
|
|
|
|
|
{ // Kommt vom Testtool und mu<6D> gleich geschrieben werden.
|
2002-03-28 13:43:03 +00:00
|
|
|
|
BOOL bFileWasChanged = pAppError->DiskFileChanged( SINCE_LAST_LOAD );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
DBG_ASSERT( aLogFileName == LogMsg->aLogFileName, "Logging to different logfile as before" );
|
2001-08-09 12:46:27 +00:00
|
|
|
|
DirEntry aEntry( LogMsg->aLogFileName );
|
|
|
|
|
BOOL bNewFile = !aEntry.Exists();
|
2000-09-18 15:18:56 +00:00
|
|
|
|
SvFileStream aStrm( LogMsg->aLogFileName, STREAM_STD_WRITE );
|
2001-08-09 12:46:27 +00:00
|
|
|
|
if ( bNewFile )
|
|
|
|
|
{
|
|
|
|
|
String aSave = VERSION_STRING.Append( UniString::CreateFromInt32( 3 ) ).AppendAscii("\n"); // Version 3
|
|
|
|
|
aSave.ConvertLineEnd(LINEEND_CRLF);
|
|
|
|
|
aStrm << ByteString( aSave, RTL_TEXTENCODING_IBM_850 ).GetBuffer();
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
|
String aLogMsg = Impl_MakeSaveText( LogMsg->aDebugData ).AppendAscii("\n");
|
|
|
|
|
if( aStrm.IsOpen() )
|
|
|
|
|
{
|
|
|
|
|
aLogMsg.ConvertLineEnd(LINEEND_CRLF);
|
|
|
|
|
aStrm.Seek(STREAM_SEEK_TO_END);
|
|
|
|
|
aStrm << ByteString( aLogMsg, RTL_TEXTENCODING_UTF8 ).GetBuffer();
|
|
|
|
|
aStrm.Close();
|
|
|
|
|
}
|
|
|
|
|
if ( !bFileWasChanged )
|
2002-03-28 13:43:03 +00:00
|
|
|
|
pAppError->UpdateFileInfo( HAS_BEEN_LOADED );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2004-01-19 16:54:34 +00:00
|
|
|
|
LogMsg->aDebugData.aMsg = pBasicFrame->GenRealString( LogMsg->aDebugData.aMsg );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddRun( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
if ( !bFileLoading && bLimitLogLen )
|
|
|
|
|
{
|
|
|
|
|
USHORT nSkip = nMaxLogLen;
|
|
|
|
|
SvLBoxEntry *pRun = aEditTree.First();
|
|
|
|
|
while ( nSkip-- && pRun )
|
|
|
|
|
pRun = aEditTree.NextSibling( pRun );
|
|
|
|
|
// Remove all Entries thereafter
|
|
|
|
|
if ( pRun )
|
|
|
|
|
{
|
|
|
|
|
while ( pRun && aEditTree.NextSibling( pRun ) )
|
|
|
|
|
aEditTree.GetModel()->Remove( aEditTree.NextSibling( pRun ) );
|
|
|
|
|
|
|
|
|
|
aEditTree.GetModel()->Remove( pRun );
|
|
|
|
|
bModified = TRUE;
|
|
|
|
|
lModify.Call( NULL );
|
|
|
|
|
Save( aLogFileName );
|
|
|
|
|
pAppError->UpdateFileInfo( HAS_BEEN_LOADED );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
COPY_TTDEBUGDATA( LOG_RUN );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
if ( !bFileLoading || ( bFileLoading && nVersion >= 2 ) )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pCurrentRun = aEditTree.InsertEntry( aMsg, NULL, FALSE, 0, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
else // Erstes Dateiformat
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pCurrentRun = aEditTree.InsertEntry( aMsg, NULL, FALSE, LIST_APPEND, pTTDebugData ); // und damit an Ende!
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
aEditTree.ShowEntry( pCurrentRun );
|
|
|
|
|
pCurrentTestCase = NULL;
|
2003-04-17 16:17:22 +00:00
|
|
|
|
pCurrentAssertion = NULL;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
pCurrentError = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddTestCase( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
|
|
|
|
if ( pCurrentRun )
|
|
|
|
|
{
|
|
|
|
|
if ( aMsg.Len() == 0 ) // Am Ende des Testcase
|
|
|
|
|
{
|
|
|
|
|
pCurrentTestCase = NULL;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_TEST_CASE );
|
|
|
|
|
pCurrentTestCase = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pCurrentTestCase );
|
|
|
|
|
}
|
|
|
|
|
}
|
2003-04-17 16:17:22 +00:00
|
|
|
|
pCurrentAssertion = NULL;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
pCurrentError = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddError( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
|
|
|
|
if ( !pCurrentTestCase )
|
|
|
|
|
{
|
|
|
|
|
TTLogMsg aLogMsg;
|
|
|
|
|
aLogMsg.aDebugData = aDebugData;
|
|
|
|
|
aLogMsg.aDebugData.aMsg = GEN_RES_STR0( S_ERROR_OUTSIDE_TESTCASE );
|
|
|
|
|
aLogMsg.aDebugData.aLogType = LOG_TEST_CASE;
|
|
|
|
|
aLogMsg.aLogFileName = aLogFileName;
|
|
|
|
|
AddAnyMsg( &aLogMsg );
|
|
|
|
|
}
|
|
|
|
|
if ( pCurrentTestCase )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_ERROR );
|
|
|
|
|
pCurrentError = aEditTree.InsertEntry( aMsg, pCurrentTestCase, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pCurrentError );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddCallStack( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
|
|
|
|
DBG_ASSERT( pCurrentError, "Callstack ohne CurrentError im Journal" );
|
|
|
|
|
if ( pCurrentError )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_CALL_STACK );
|
|
|
|
|
SvLBoxEntry *pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentError, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddMessage( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry *pThisEntry = NULL;
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_MESSAGE );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
if ( pCurrentTestCase )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentTestCase, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
else if ( pCurrentRun )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AddRun( aMsg, aDebugData );
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddWarning( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry *pThisEntry = NULL;
|
|
|
|
|
String aCompleteMsg;
|
|
|
|
|
aCompleteMsg = WARNING_PREFIX.Append( aMsg );
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_WARNING );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
if ( pCurrentTestCase )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aCompleteMsg, pCurrentTestCase, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
else if ( pCurrentRun )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aCompleteMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AddRun( aMsg, aDebugData );
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aCompleteMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
while ( !aEditTree.IsEntryVisible( pThisEntry ) && ( pThisEntry = aEditTree.GetParent( pThisEntry ) ) )
|
|
|
|
|
aEditTree.InvalidateEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddAssertion( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
2003-04-17 16:17:22 +00:00
|
|
|
|
const String aAssertionStackPrefix( CUniString(ASSERTION_STACK_PREFIX) );
|
|
|
|
|
if ( aMsg.Match( aAssertionStackPrefix ) == aAssertionStackPrefix.Len() )
|
|
|
|
|
{
|
|
|
|
|
AddAssertionStack( aMsg, aDebugData );
|
|
|
|
|
return;
|
|
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
|
SvLBoxEntry *pThisEntry = NULL;
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_ASSERTION );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
if ( pCurrentTestCase )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentTestCase, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
else if ( pCurrentRun )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AddRun( aMsg, aDebugData );
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
2003-04-17 16:17:22 +00:00
|
|
|
|
pCurrentAssertion = pThisEntry;
|
|
|
|
|
|
|
|
|
|
while ( !aEditTree.IsEntryVisible( pThisEntry ) && ( pThisEntry = aEditTree.GetParent( pThisEntry ) ) )
|
|
|
|
|
aEditTree.InvalidateEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::AddAssertionStack( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry *pThisEntry = NULL;
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_ASSERTION_STACK );
|
2003-04-17 16:17:22 +00:00
|
|
|
|
if ( pCurrentAssertion )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentAssertion, FALSE, LIST_APPEND, pTTDebugData );
|
2003-04-17 16:17:22 +00:00
|
|
|
|
else if ( pCurrentTestCase )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentTestCase, FALSE, LIST_APPEND, pTTDebugData );
|
2003-04-17 16:17:22 +00:00
|
|
|
|
else if ( pCurrentRun )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2003-04-17 16:17:22 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AddRun( aMsg, aDebugData );
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2003-04-17 16:17:22 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
|
while ( !aEditTree.IsEntryVisible( pThisEntry ) && ( pThisEntry = aEditTree.GetParent( pThisEntry ) ) )
|
|
|
|
|
aEditTree.InvalidateEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
2003-03-18 15:28:40 +00:00
|
|
|
|
void MsgEdit::AddQAError( String aMsg, TTDebugData aDebugData )
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry *pThisEntry = NULL;
|
2004-06-17 10:47:06 +00:00
|
|
|
|
COPY_TTDEBUGDATA( LOG_QA_ERROR );
|
2003-03-18 15:28:40 +00:00
|
|
|
|
if ( pCurrentTestCase )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentTestCase, FALSE, LIST_APPEND, pTTDebugData );
|
2003-03-18 15:28:40 +00:00
|
|
|
|
else if ( pCurrentRun )
|
|
|
|
|
{
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2003-03-18 15:28:40 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
AddRun( aMsg, aDebugData );
|
2004-06-17 10:47:06 +00:00
|
|
|
|
pThisEntry = aEditTree.InsertEntry( aMsg, pCurrentRun, FALSE, LIST_APPEND, pTTDebugData );
|
2003-03-18 15:28:40 +00:00
|
|
|
|
aEditTree.ShowEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
while ( !aEditTree.IsEntryVisible( pThisEntry ) && ( pThisEntry = aEditTree.GetParent( pThisEntry ) ) )
|
|
|
|
|
aEditTree.InvalidateEntry( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 15:18:56 +00:00
|
|
|
|
/*
|
|
|
|
|
SvLBoxEntry* GetEntry( SvLBoxEntry* pParent, ULONG nPos ) const { return SvLBox::GetEntry(pParent,nPos); }
|
|
|
|
|
SvLBoxEntry* GetEntry( ULONG nRootPos ) const { return SvLBox::GetEntry(nRootPos);}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
SvLBoxEntry* FirstChild(SvLBoxEntry* pParent ) const { return (SvLBoxEntry*)(pModel->FirstChild(pParent)); }
|
|
|
|
|
SvLBoxEntry* NextSibling(SvLBoxEntry* pEntry ) const { return (SvLBoxEntry*)(pModel->NextSibling( pEntry )); }
|
|
|
|
|
SvLBoxEntry* PrevSibling(SvLBoxEntry* pEntry ) const { return (SvLBoxEntry*)(pModel->PrevSibling( pEntry )); }
|
|
|
|
|
|
|
|
|
|
SvLBoxEntry* FirstSelected() const { return (SvLBoxEntry*)SvListView::FirstSelected(); }
|
|
|
|
|
SvLBoxEntry* NextSelected( SvLBoxEntry* pEntry ) const { return (SvLBoxEntry*)(SvListView::NextSelected(pEntry)); }
|
|
|
|
|
SvLBoxEntry* PrevSelected( SvLBoxEntry* pEntry ) const { return (SvLBoxEntry*)(SvListView::PrevSelected(pEntry)); }
|
|
|
|
|
SvLBoxEntry* LastSelected() const { return (SvLBoxEntry*)(SvListView::LastSelected()); }
|
|
|
|
|
|
|
|
|
|
SvLBoxEntry* GetEntry( SvLBoxEntry* pParent, ULONG nPos ) const { return (SvLBoxEntry*)(pModel->GetEntry(pParent,nPos)); }
|
|
|
|
|
SvLBoxEntry* GetEntry( ULONG nRootPos ) const { return (SvLBoxEntry*)(pModel->GetEntry(nRootPos)); }
|
|
|
|
|
|
|
|
|
|
SvLBoxEntry* GetParent( SvLBoxEntry* pEntry ) const { return (SvLBoxEntry*)(pModel->GetParent(pEntry)); }
|
|
|
|
|
SvLBoxEntry* GetRootLevelParent(SvLBoxEntry* pEntry ) const { return (SvLBoxEntry*)(pModel->GetRootLevelParent( pEntry ));}
|
|
|
|
|
|
|
|
|
|
BOOL IsInChildList( SvListEntry* pParent, SvListEntry* pChild) const;
|
|
|
|
|
SvListEntry* GetEntry( SvListEntry* pParent, ULONG nPos ) const;
|
|
|
|
|
SvListEntry* GetEntry( ULONG nRootPos ) const;
|
|
|
|
|
SvListEntry* GetEntryAtAbsPos( ULONG nAbsPos ) const;
|
|
|
|
|
SvListEntry* GetParent( SvListEntry* pEntry ) const;
|
|
|
|
|
SvListEntry* GetRootLevelParent( SvListEntry* pEntry ) const;
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
//#define CHECK( pMemo ) if ( pMemo && !aEditTree.GetViewData( pMemo ) ) pMemo = NULL
|
|
|
|
|
#define CHECK( pMemo ) if ( pMemo && !aEditTree.GetModel()->IsInChildList( NULL, pMemo ) ) pMemo = NULL
|
|
|
|
|
void MsgEdit::Delete()
|
|
|
|
|
{
|
|
|
|
|
aEditTree.RemoveSelection();
|
|
|
|
|
CHECK( pCurrentRun );
|
|
|
|
|
CHECK( pCurrentTestCase );
|
2003-04-17 16:17:22 +00:00
|
|
|
|
CHECK( pCurrentAssertion );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
CHECK( pCurrentError );
|
|
|
|
|
bModified = TRUE;
|
|
|
|
|
lModify.Call( NULL );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::Cut(){ Copy(); Delete(); bModified = TRUE; lModify.Call( NULL ); }
|
2001-06-08 12:44:14 +00:00
|
|
|
|
void MsgEdit::Copy(){ ::svt::OStringTransfer::CopyString( GetSelected(), &aEditTree ); }
|
2000-09-18 15:18:56 +00:00
|
|
|
|
/**/void MsgEdit::Paste(){ Sound::Beep(); }
|
|
|
|
|
void MsgEdit::Undo(){ Sound::Beep(); }
|
|
|
|
|
void MsgEdit::Redo(){ Sound::Beep(); }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
String MsgEdit::Impl_MakeText( SvLBoxEntry *pEntry ) const
|
|
|
|
|
{
|
|
|
|
|
String aRet;
|
|
|
|
|
TTDebugData *aData = (TTDebugData*)pEntry->GetUserData();
|
|
|
|
|
switch ( aData->aLogType )
|
|
|
|
|
{
|
|
|
|
|
case LOG_RUN: aRet.AppendAscii("\n"); break;
|
|
|
|
|
case LOG_TEST_CASE: break;
|
|
|
|
|
case LOG_ERROR: break;
|
|
|
|
|
case LOG_CALL_STACK:aRet.AppendAscii("--> "); break;
|
|
|
|
|
case LOG_MESSAGE: break;
|
|
|
|
|
case LOG_WARNING: break;
|
|
|
|
|
case LOG_ASSERTION: break;
|
2003-04-17 16:17:22 +00:00
|
|
|
|
case LOG_ASSERTION_STACK:aRet.AppendAscii("--> "); break;
|
2003-03-18 15:28:40 +00:00
|
|
|
|
case LOG_QA_ERROR: break;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
default:DBG_ERROR("Unbekannter Typ im ResultFenster");
|
|
|
|
|
}
|
|
|
|
|
aRet += aEditTree.GetEntryText( pEntry );
|
|
|
|
|
return aRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String MsgEdit::Impl_MakeSaveText( TTDebugData aData ) const
|
|
|
|
|
{
|
|
|
|
|
// LogType;Filename;Line;Col1;Col2;Message
|
|
|
|
|
String aRet;
|
|
|
|
|
aRet += String::CreateFromInt32( (int)aData.aLogType );
|
|
|
|
|
aRet += ';';
|
|
|
|
|
aRet += aData.aFilename;
|
|
|
|
|
aRet += ';';
|
|
|
|
|
aRet += String::CreateFromInt32( aData.nLine );
|
|
|
|
|
aRet += ';';
|
|
|
|
|
aRet += String::CreateFromInt32( aData.nCol1 );
|
|
|
|
|
aRet += ';';
|
|
|
|
|
aRet += String::CreateFromInt32( aData.nCol2 );
|
|
|
|
|
aRet += ';';
|
|
|
|
|
aRet += '"';
|
|
|
|
|
aRet += aData.aMsg;
|
|
|
|
|
aRet += '"';
|
|
|
|
|
return aRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String MsgEdit::Impl_MakeSaveText( SvLBoxEntry *pEntry ) const
|
|
|
|
|
{
|
|
|
|
|
// LogType;Filename;Line;Col1;Col2;Message
|
|
|
|
|
String aRet;
|
|
|
|
|
TTDebugData *aData = (TTDebugData*)pEntry->GetUserData();
|
|
|
|
|
|
|
|
|
|
if ( aEditTree.PrevSibling( pEntry ) && LOGTYPE( aEditTree.PrevSibling( pEntry ) ) == LOG_TEST_CASE )
|
|
|
|
|
{ // Um Cases richtig abzuschliessen, so da<64> Warnings und Msgs in Hirarchie richtig.
|
|
|
|
|
aRet += String::CreateFromInt32( (int)LOG_TEST_CASE );
|
|
|
|
|
aRet.AppendAscii(";;0;0;0;\"\"\n");
|
|
|
|
|
}
|
|
|
|
|
aRet += Impl_MakeSaveText( *aData );
|
|
|
|
|
return aRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String MsgEdit::GetSelected()
|
|
|
|
|
{
|
|
|
|
|
String aRet;
|
|
|
|
|
SvLBoxEntry *pEntry = aEditTree.FirstSelected();
|
|
|
|
|
while ( pEntry )
|
|
|
|
|
{
|
|
|
|
|
aRet += Impl_MakeText( pEntry );
|
|
|
|
|
aRet += '\n';
|
|
|
|
|
pEntry = aEditTree.NextSelected( pEntry );
|
|
|
|
|
}
|
|
|
|
|
aRet.ConvertLineEnd();
|
|
|
|
|
return aRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TextSelection MsgEdit::GetSelection() const
|
|
|
|
|
{
|
|
|
|
|
ULONG nStart=0,nEnd=0;
|
|
|
|
|
|
|
|
|
|
if ( aEditTree.FirstSelected() )
|
|
|
|
|
{
|
|
|
|
|
nStart = aEditTree.GetModel()->GetAbsPos(aEditTree.FirstSelected() );
|
|
|
|
|
if ( aEditTree.LastSelected() )
|
|
|
|
|
nEnd = aEditTree.GetModel()->GetAbsPos(aEditTree.LastSelected() );
|
|
|
|
|
return TextSelection( TextPaM( nStart, 0 ), TextPaM( nEnd, STRING_MAXLEN ) );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
return TextSelection();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::SetSelection( const TextSelection& rSelection )
|
|
|
|
|
{
|
2004-01-19 16:54:34 +00:00
|
|
|
|
ULONG nStart,nEnd;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
while ( aEditTree.GetSelectionCount() )
|
|
|
|
|
aEditTree.Select( aEditTree.FirstSelected(), FALSE );
|
|
|
|
|
|
|
|
|
|
if ( rSelection.HasRange() )
|
|
|
|
|
{
|
|
|
|
|
nStart = rSelection.GetStart().GetPara();
|
|
|
|
|
nEnd = rSelection.GetEnd().GetPara();
|
|
|
|
|
|
2004-06-17 10:47:06 +00:00
|
|
|
|
for ( ULONG i = nStart ; i <= nEnd ; i++ )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aEditTree.Select( aEditTree.GetModel()->GetEntryAtAbsPos( i ), TRUE );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
USHORT MsgEdit::GetLineNr() const
|
|
|
|
|
{
|
|
|
|
|
if ( aEditTree.GetCurEntry() )
|
2004-01-19 16:54:34 +00:00
|
|
|
|
return (USHORT)aEditTree.GetModel()->GetAbsPos(aEditTree.GetCurEntry() ) + 1;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
else
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void MsgEdit::ReplaceSelected( const String& rStr ){ Sound::Beep();DBG_ERROR("Not Implemented"); }
|
|
|
|
|
BOOL MsgEdit::IsModified(){ return bModified; }
|
|
|
|
|
void MsgEdit::SetModifyHdl( Link l ){ lModify = l; }
|
|
|
|
|
|
|
|
|
|
String MsgEdit::GetText() const
|
|
|
|
|
{
|
|
|
|
|
String aRet;
|
|
|
|
|
SvLBoxEntry *pEntry = aEditTree.First();
|
|
|
|
|
while ( pEntry )
|
|
|
|
|
{
|
|
|
|
|
aRet += Impl_MakeText( pEntry );
|
|
|
|
|
aRet += '\n';
|
|
|
|
|
pEntry = aEditTree.Next( pEntry );
|
|
|
|
|
}
|
|
|
|
|
aRet.ConvertLineEnd();
|
|
|
|
|
return aRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**/void MsgEdit::SetText( const String& rStr ){ DBG_ERROR("Not Implemented"); }
|
|
|
|
|
|
|
|
|
|
BOOL MsgEdit::HasText() const { return aEditTree.First() != NULL; }
|
|
|
|
|
|
|
|
|
|
// Es wird entweder ab Beginn oder ab Markierungsbegin + 1 gesucht.
|
|
|
|
|
BOOL MsgEdit::Find( const String& s )
|
|
|
|
|
{
|
|
|
|
|
TextSelection r = GetSelection();
|
|
|
|
|
USHORT bgn = (USHORT) r.GetStart().GetPara() + 1;
|
|
|
|
|
if ( r.GetStart().GetPara() == 0 ) bgn = 0; // Suchen ganz von Anfang
|
|
|
|
|
|
|
|
|
|
SvLBoxEntry *pEntry = aEditTree.GetModel()->GetEntryAtAbsPos( bgn );
|
|
|
|
|
while ( pEntry )
|
|
|
|
|
{
|
|
|
|
|
if( aEditTree.GetEntryText( pEntry ).Search( s, 0 ) != STRING_NOTFOUND )
|
|
|
|
|
{
|
|
|
|
|
aEditTree.SetCurEntry( pEntry );
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
pEntry = aEditTree.Next( pEntry );
|
|
|
|
|
}
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
/******************************************************************
|
|
|
|
|
|
|
|
|
|
Zum Fileformat der *.res Dateien:
|
|
|
|
|
Die Informationenn werden als Semikolon getrennte Strings
|
|
|
|
|
zusammengebastelt. Reihenfolge:
|
|
|
|
|
|
|
|
|
|
LogType;Filename;Line;Col1;Col2;Message
|
|
|
|
|
|
|
|
|
|
******************************************************************/
|
|
|
|
|
|
|
|
|
|
BOOL MsgEdit::Load( const String& aName )
|
|
|
|
|
{
|
|
|
|
|
aLogFileName = aName;
|
|
|
|
|
BOOL bOk = TRUE, bFirstLine = TRUE;
|
|
|
|
|
BOOL bLoadError = FALSE;
|
|
|
|
|
SvFileStream aStrm( aName, STREAM_STD_READ );
|
|
|
|
|
if( aStrm.IsOpen() )
|
|
|
|
|
{
|
|
|
|
|
aEditTree.Clear();
|
|
|
|
|
String aLine;
|
|
|
|
|
bFileLoading = TRUE; // So da<64> nicht gleich wieder auf Platte mitgelogt wird.
|
|
|
|
|
TTLogMsg *pLogMsg = new TTLogMsg;
|
|
|
|
|
while( !aStrm.IsEof() && bOk )
|
|
|
|
|
{
|
|
|
|
|
if ( nVersion >= 3 ) // Wir habe utf8
|
|
|
|
|
aStrm.ReadByteStringLine( aLine, RTL_TEXTENCODING_UTF8 );
|
|
|
|
|
else
|
|
|
|
|
aStrm.ReadByteStringLine( aLine, RTL_TEXTENCODING_IBM_850 );
|
|
|
|
|
|
|
|
|
|
if( aStrm.GetError() != SVSTREAM_OK )
|
|
|
|
|
bOk = FALSE;
|
|
|
|
|
|
|
|
|
|
#define TOKEN( n ) aLine.GetToken( n )
|
|
|
|
|
|
|
|
|
|
if ( aLine.GetTokenCount() >= 6 )
|
|
|
|
|
{
|
|
|
|
|
// LogType;Filename;Line;Col1;Col2;Message
|
|
|
|
|
TTDebugData aDebugData;
|
|
|
|
|
aDebugData.aLogType = TTLogType( TOKEN(0).ToInt32() );
|
|
|
|
|
aDebugData.aFilename = TOKEN(1);
|
2004-06-17 10:47:06 +00:00
|
|
|
|
aDebugData.nLine = USHORT( TOKEN(2).ToInt32() );
|
|
|
|
|
aDebugData.nCol1 = USHORT( TOKEN(3).ToInt32() );
|
|
|
|
|
aDebugData.nCol2 = USHORT( TOKEN(4).ToInt32() );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aDebugData.aMsg = aLine.GetQuotedToken( 5, CUniString("\"\"") );
|
|
|
|
|
aDebugData.aMsg.Erase(0,1); // Anf<6E>hrungszeichen entfernen
|
|
|
|
|
aDebugData.aMsg.Erase(aDebugData.aMsg.Len()-1,1);
|
|
|
|
|
|
|
|
|
|
pLogMsg->aLogFileName.Erase();
|
|
|
|
|
pLogMsg->aDebugData = aDebugData;
|
|
|
|
|
|
|
|
|
|
AddAnyMsg( pLogMsg );
|
|
|
|
|
}
|
|
|
|
|
else if ( bFirstLine && (aLine.Search( VERSION_STRING ) == 0) )
|
2004-06-17 10:47:06 +00:00
|
|
|
|
nVersion = USHORT( aLine.Copy( VERSION_STRING.Len() ).ToInt32() );
|
2001-08-09 12:46:27 +00:00
|
|
|
|
else if ( aLine.Len() )
|
|
|
|
|
bLoadError = TRUE;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
bFirstLine = FALSE;
|
|
|
|
|
}
|
|
|
|
|
bFileLoading = FALSE;
|
|
|
|
|
delete pLogMsg;
|
|
|
|
|
aStrm.Close();
|
|
|
|
|
if ( nVersion < 2 && !bLoadError )
|
|
|
|
|
Save( aName ); // Mu<4D> sein, sonst passiert beim mitloggen Bl<42>dsinn.
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
bOk = FALSE;
|
|
|
|
|
return bOk;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL MsgEdit::Save( const String& aName )
|
|
|
|
|
{
|
|
|
|
|
BOOL bOk = TRUE;
|
|
|
|
|
BOOL bIsText = DirEntry( aName ).GetExtension().CompareIgnoreCaseToAscii("TXT") == COMPARE_EQUAL;
|
|
|
|
|
if ( bIsText && !QueryBox( NULL, ResId( IDS_LOSS_OF_INFORMATION ) ).Execute() )
|
|
|
|
|
return FALSE;
|
|
|
|
|
SvFileStream aStrm( aName, STREAM_STD_WRITE | STREAM_TRUNC );
|
|
|
|
|
if( aStrm.IsOpen() )
|
|
|
|
|
{
|
|
|
|
|
if ( bIsText )
|
|
|
|
|
{
|
|
|
|
|
String aSave = GetText();
|
|
|
|
|
aSave.ConvertLineEnd(LINEEND_CRLF);
|
|
|
|
|
aStrm << ByteString( aSave, RTL_TEXTENCODING_UTF8 ).GetBuffer();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// LogType;Filename;Line;Col1;Col2;Message
|
2001-08-09 12:46:27 +00:00
|
|
|
|
String aSave = VERSION_STRING.Append( UniString::CreateFromInt32( 3 ) ).AppendAscii("\n"); // Version 3
|
2000-09-18 15:18:56 +00:00
|
|
|
|
SvLBoxEntry *pRun = aEditTree.First();
|
|
|
|
|
while ( pRun && aEditTree.NextSibling( pRun ) )
|
|
|
|
|
pRun = aEditTree.NextSibling( pRun );
|
|
|
|
|
|
|
|
|
|
aSave.ConvertLineEnd(LINEEND_CRLF);
|
2001-07-26 11:59:07 +00:00
|
|
|
|
aStrm << ByteString( aSave, RTL_TEXTENCODING_IBM_850 ).GetBuffer();
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
SvLBoxEntry *pEntry;
|
|
|
|
|
while ( pRun )
|
|
|
|
|
{
|
|
|
|
|
pEntry = pRun;
|
|
|
|
|
while ( pEntry && ( pEntry == pRun || LOGTYPE( pEntry ) != LOG_RUN ) )
|
|
|
|
|
{
|
|
|
|
|
aSave = Impl_MakeSaveText( pEntry );
|
|
|
|
|
aSave += '\n';
|
|
|
|
|
aSave.ConvertLineEnd(LINEEND_CRLF);
|
|
|
|
|
aStrm << ByteString( aSave, RTL_TEXTENCODING_UTF8 ).GetBuffer();
|
|
|
|
|
pEntry = aEditTree.Next( pEntry );
|
|
|
|
|
}
|
|
|
|
|
pRun = aEditTree.PrevSibling( pRun );
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if( aStrm.GetError() != SVSTREAM_OK )
|
|
|
|
|
bOk = FALSE;
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
bModified = FALSE;
|
|
|
|
|
lModify.Call( NULL );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
bOk = FALSE;
|
|
|
|
|
return bOk;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2002-03-28 13:43:03 +00:00
|
|
|
|
TTTreeListBox::TTTreeListBox( AppError* pParent, BasicFrame* pBF, WinBits nWinStyle )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
: SvTreeListBox( pParent, nWinStyle )
|
|
|
|
|
, pBasicFrame(pBF)
|
2002-03-28 13:43:03 +00:00
|
|
|
|
, pAppError( pParent )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
//, nDeselectParent(0)
|
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
BOOL TTTreeListBox::DoubleClickHdl()
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry *pThisEntry = GetHdlEntry();
|
|
|
|
|
if ( pThisEntry && pThisEntry->GetUserData() && ((TTDebugData*)pThisEntry->GetUserData())->aFilename.Len() > 0 )
|
|
|
|
|
{
|
|
|
|
|
TTDebugData *aData = (TTDebugData*)pThisEntry->GetUserData();
|
2002-03-28 13:43:03 +00:00
|
|
|
|
String aFilename = aData->aFilename;
|
|
|
|
|
if ( aData->aFilename.GetChar(0) == '~' )
|
|
|
|
|
{
|
|
|
|
|
if ( aData->aFilename.GetChar(1) == '-' )
|
|
|
|
|
{
|
|
|
|
|
aFilename.Erase( 0,2 );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
aFilename.Erase( 0,1 );
|
|
|
|
|
DirEntry aConvert( pAppError->aBaseDir );
|
|
|
|
|
aConvert += DirEntry( aFilename, FSYS_STYLE_VFAT );
|
|
|
|
|
aFilename = aConvert.GetFull();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( pBasicFrame->FindModuleWin( aFilename ) )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
{
|
2002-03-28 13:43:03 +00:00
|
|
|
|
AppWin *pWin = pBasicFrame->FindModuleWin( aFilename );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
pWin->ToTop();
|
|
|
|
|
}
|
2002-04-24 08:19:47 +00:00
|
|
|
|
else if ( pBasicFrame->Basic().FindModule( CUniString( "--" ).Append( aFilename ) ) )
|
|
|
|
|
{
|
|
|
|
|
SbModule* pMod = pBasicFrame->Basic().FindModule( CUniString( "--" ).Append( aFilename ) );
|
|
|
|
|
pBasicFrame->CreateModuleWin( pMod );
|
|
|
|
|
}
|
2000-09-18 15:18:56 +00:00
|
|
|
|
else
|
2002-03-28 13:43:03 +00:00
|
|
|
|
pBasicFrame->LoadFile( aFilename );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
if ( pBasicFrame->pWork && pBasicFrame->pWork->ISA(AppEdit) )
|
|
|
|
|
((AppEdit*)pBasicFrame->pWork)->Highlight( aData->nLine, aData->nCol1, aData->nCol2 );
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*ULONG TTTreeListBox::SelectChildren( SvLBoxEntry* pParent, BOOL bSelect )
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry *pEntry = FirstChild( pParent );
|
|
|
|
|
ULONG nRet = 0;
|
|
|
|
|
while ( pEntry )
|
|
|
|
|
{
|
|
|
|
|
nRet++;
|
|
|
|
|
Select( pEntry, bSelect );
|
|
|
|
|
pEntry = NextSibling( pEntry );
|
|
|
|
|
}
|
|
|
|
|
return nRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void TTTreeListBox::SelectHdl()
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry* pHdlEntry = GetHdlEntry();
|
|
|
|
|
|
|
|
|
|
SelectChildren( pHdlEntry, TRUE );
|
|
|
|
|
Select( pHdlEntry, TRUE );
|
|
|
|
|
// InitMenu(pApp->GetAppMenu()->GetPopupMenu( RID_APPEDIT )); // So da<64> Delete richtig ist
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void TTTreeListBox::DeselectHdl()
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry* pHdlEntry = GetHdlEntry();
|
|
|
|
|
if ( GetParent( pHdlEntry ) )
|
|
|
|
|
{
|
|
|
|
|
nDeselectParent++;
|
|
|
|
|
Select( GetParent( pHdlEntry ), FALSE );
|
|
|
|
|
nDeselectParent--;
|
|
|
|
|
}
|
|
|
|
|
if ( !nDeselectParent )
|
|
|
|
|
{
|
|
|
|
|
SelectChildren( pHdlEntry, FALSE );
|
|
|
|
|
Select( pHdlEntry, FALSE );
|
|
|
|
|
}
|
|
|
|
|
Invalidate();
|
|
|
|
|
} */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void TTTreeListBox::KeyInput( const KeyEvent& rKEvt )
|
|
|
|
|
{
|
|
|
|
|
switch ( rKEvt.GetKeyCode().GetFunction() )
|
|
|
|
|
{
|
|
|
|
|
case KEYFUNC_CUT:
|
|
|
|
|
Control::GetParent()->Command( CommandEvent( Point(), RID_EDITCUT ) );
|
|
|
|
|
break;
|
|
|
|
|
case KEYFUNC_COPY:
|
|
|
|
|
Control::GetParent()->Command( CommandEvent( Point(), RID_EDITCOPY ) );
|
|
|
|
|
break;
|
|
|
|
|
case KEYFUNC_PASTE:
|
|
|
|
|
Control::GetParent()->Command( CommandEvent( Point(), RID_EDITPASTE ) );
|
|
|
|
|
break;
|
|
|
|
|
case KEYFUNC_DELETE:
|
|
|
|
|
Control::GetParent()->Command( CommandEvent( Point(), RID_EDITDEL ) );
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
SvTreeListBox::KeyInput( rKEvt );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TTFeatures TTTreeListBox::GetFeatures( SvLBoxEntry* pEntry )
|
|
|
|
|
{
|
|
|
|
|
switch ( LOGTYPE( pEntry ) )
|
|
|
|
|
{
|
|
|
|
|
case LOG_MESSAGE:
|
|
|
|
|
return HasNothing;
|
|
|
|
|
case LOG_WARNING :
|
|
|
|
|
return HasWarning;
|
|
|
|
|
case LOG_ERROR:
|
|
|
|
|
case LOG_CALL_STACK:
|
|
|
|
|
return HasError;
|
|
|
|
|
case LOG_RUN:
|
|
|
|
|
case LOG_TEST_CASE:
|
|
|
|
|
{
|
|
|
|
|
SvLBoxEntry* pThisEntry = FirstChild( pEntry );
|
|
|
|
|
TTFeatures aResult = HasNothing;
|
|
|
|
|
while ( pThisEntry && !( (aResult & HasError) == HasError ) )
|
|
|
|
|
{
|
|
|
|
|
if ( !IsEntryVisible( pThisEntry ) )
|
|
|
|
|
aResult |= GetFeatures( pThisEntry );
|
|
|
|
|
pThisEntry = NextSibling( pThisEntry );
|
|
|
|
|
}
|
|
|
|
|
return aResult;
|
|
|
|
|
}
|
|
|
|
|
case LOG_ASSERTION:
|
2003-04-17 16:17:22 +00:00
|
|
|
|
case LOG_ASSERTION_STACK:
|
2000-09-18 15:18:56 +00:00
|
|
|
|
return HasAssertion;
|
2003-03-18 15:28:40 +00:00
|
|
|
|
case LOG_QA_ERROR:
|
|
|
|
|
return HasQAError;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
default:
|
|
|
|
|
DBG_ERROR("Unbekannter Typ im ResultFenster");
|
|
|
|
|
}
|
2003-03-18 15:28:40 +00:00
|
|
|
|
return HasNothing;
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class TTLBoxString : public SvLBoxString
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
TTLBoxString( SvLBoxEntry* pEntry, USHORT nFlags,
|
|
|
|
|
const String& rStr ) : SvLBoxString(pEntry,nFlags,rStr) {}
|
|
|
|
|
|
|
|
|
|
virtual void Paint( const Point& rPos, SvLBox& rDev, USHORT nFlags,
|
|
|
|
|
SvLBoxEntry* pEntry);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void TTLBoxString::Paint( const Point& rPos, SvLBox& rDev, USHORT nFlags,
|
|
|
|
|
SvLBoxEntry* pEntry )
|
|
|
|
|
{
|
|
|
|
|
TTFeatures aFeatures = ((TTTreeListBox*)&rDev)->GetFeatures( pEntry );
|
|
|
|
|
|
2004-12-10 16:16:04 +00:00
|
|
|
|
Font aOldFont( rDev.GetFont());
|
|
|
|
|
Font aFont( aOldFont );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
if ( aFeatures != HasNothing )
|
|
|
|
|
{
|
2004-08-02 14:50:42 +00:00
|
|
|
|
if ( ( aFeatures & HasError ) != 0 || ( aFeatures & HasWarning ) != 0 )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
{
|
|
|
|
|
Color aCol;
|
|
|
|
|
if ( ( aFeatures & HasError ) == HasError )
|
|
|
|
|
aCol = Color( 255, 120, 120 ); // Rot
|
2004-06-17 10:47:06 +00:00
|
|
|
|
else if ( ( aFeatures & HasWarning ) == HasWarning )
|
2000-09-18 15:18:56 +00:00
|
|
|
|
aCol = Color( 255, 200, 120 ); // Ocker oder so
|
2004-06-17 10:47:06 +00:00
|
|
|
|
else
|
|
|
|
|
aCol = Color( 255, 102, 51 ); // Orange oder so
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
|
|
|
|
if( rDev.IsSelected(pEntry) )
|
|
|
|
|
aFont.SetColor( aCol );
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
aFont.SetFillColor( aCol );
|
|
|
|
|
aFont.SetTransparent( FALSE );
|
2004-12-10 16:16:04 +00:00
|
|
|
|
Color aCol( COL_BLACK );
|
|
|
|
|
aFont.SetColor( aCol );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2004-08-02 14:50:42 +00:00
|
|
|
|
else // so its HasAssertion or HasQAError
|
2000-09-18 15:18:56 +00:00
|
|
|
|
{
|
|
|
|
|
if( rDev.IsSelected(pEntry) )
|
|
|
|
|
{
|
|
|
|
|
Color aCol( 255, 255, 153 );
|
|
|
|
|
aFont.SetColor( aCol );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Size aSize( rDev.GetTextWidth( GetText() ), rDev.GetTextHeight() );
|
|
|
|
|
Rectangle aRect( rPos, aSize );
|
|
|
|
|
|
2004-08-02 14:50:42 +00:00
|
|
|
|
static Bitmap aAssertionBmp( ResId( MBP_ASSERT ) );
|
|
|
|
|
static BitmapEx aAssertionBmpEx( aAssertionBmp );
|
|
|
|
|
static Wallpaper aAssertionWP( aAssertionBmpEx );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
|
2004-08-02 14:50:42 +00:00
|
|
|
|
static Bitmap aQAErrorBmp( ResId( MBP_QAERROR ) );
|
|
|
|
|
static BitmapEx aQAErrorBmpEx( aQAErrorBmp );
|
|
|
|
|
static Wallpaper aQAErrorWP( aQAErrorBmpEx );
|
|
|
|
|
|
|
|
|
|
if ( ( aFeatures & HasAssertion ) == HasAssertion )
|
|
|
|
|
rDev.DrawWallpaper( aRect, aAssertionWP );
|
|
|
|
|
else // HasQAError
|
|
|
|
|
rDev.DrawWallpaper( aRect, aQAErrorWP );
|
2004-12-10 16:16:04 +00:00
|
|
|
|
|
|
|
|
|
Color aCol( COL_BLACK );
|
|
|
|
|
aFont.SetColor( aCol );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// virtual void NotifyScrolling( long nLines );
|
|
|
|
|
}
|
|
|
|
|
rDev.SetFont( aFont );
|
|
|
|
|
rDev.DrawText( rPos, GetText() );
|
|
|
|
|
}
|
|
|
|
|
else
|
2004-12-10 16:16:04 +00:00
|
|
|
|
{
|
|
|
|
|
if( !rDev.IsSelected(pEntry) )
|
|
|
|
|
{
|
|
|
|
|
Color aCol( COL_BLACK );
|
|
|
|
|
aFont.SetColor( aCol );
|
|
|
|
|
}
|
|
|
|
|
rDev.SetFont( aFont );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
SvLBoxString::Paint( rPos, rDev, nFlags, pEntry );
|
2004-12-10 16:16:04 +00:00
|
|
|
|
}
|
|
|
|
|
rDev.SetFont( aOldFont );
|
2000-09-18 15:18:56 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void TTTreeListBox::InitEntry(SvLBoxEntry* pEntry,
|
|
|
|
|
const String& rStr ,const Image& rImg1, const Image& rImg2 )
|
|
|
|
|
{
|
|
|
|
|
USHORT nColToHilite = 1; //0==Bitmap;1=="Spalte1";2=="Spalte2"
|
|
|
|
|
SvTreeListBox::InitEntry( pEntry, rStr, rImg1, rImg2 );
|
|
|
|
|
SvLBoxString* pCol = (SvLBoxString*)pEntry->GetItem( nColToHilite );
|
|
|
|
|
TTLBoxString* pStr = new TTLBoxString( pEntry, 0, pCol->GetText() );
|
|
|
|
|
pEntry->ReplaceItem( pStr, nColToHilite );
|
|
|
|
|
}
|
|
|
|
|
|