*****************************************************************************/
void MessagesView::Pulse()
{
-#if 0
bool isScrolling = false;
if( fScrollBar->LockLooper() )
{
if( LockLooper() )
{
oldLength = TextLength();
- BString string;
- string << p_sub->p_msg[i_start].psz_module
- << " " << psz_module_type << " : "
- << p_sub->p_msg[i_start].psz_msg << "\n";
- Insert( TextLength(), string.String(), strlen( string.String() ) );
- SetFontAndColor( oldLength, TextLength(), NULL, 0, &color );
- Draw( Bounds() );
- UnlockLooper();
+ BString string;
+ string << p_sub->p_msg[i_start].psz_module
+ << " " << psz_module_type << " : "
+ << p_sub->p_msg[i_start].psz_msg << "\n";
+ Insert( TextLength(), string.String(), strlen( string.String() ) );
+ SetFontAndColor( oldLength, TextLength(), NULL, 0, &color );
+ Draw( Bounds() );
+ UnlockLooper();
}
}
}
BTextView::Pulse();
-#endif
}
/*****************************************************************************
* MessagesWindow::MessagesWindow
*****************************************************************************/
-MessagesWindow::MessagesWindow( intf_thread_t * p_intf,
+MessagesWindow::MessagesWindow( intf_thread_t * _p_intf,
BRect frame, const char * name )
- : BWindow( frame, name, B_FLOATING_WINDOW_LOOK, B_NORMAL_WINDOW_FEEL,
- B_NOT_ZOOMABLE )
+ : BWindow( frame, name, B_FLOATING_WINDOW_LOOK, B_NORMAL_WINDOW_FEEL,
+ B_NOT_ZOOMABLE ),
+ p_intf(_p_intf)
{
- this->p_intf = p_intf;
-
SetSizeLimits( 400, 2000, 200, 2000 );
-
- BRect rect, textRect;
-
- rect = Bounds();
- rect.right -= B_V_SCROLL_BAR_WIDTH;
- textRect = rect;
- textRect.InsetBy( 5, 5 );
- fMessagesView = new MessagesView( p_intf,
- rect, "messages", textRect,
- B_FOLLOW_ALL, B_WILL_DRAW );
- fMessagesView->MakeEditable( false );
- fMessagesView->SetStylable( true );
- fScrollView = new BScrollView( "scrollview", fMessagesView, B_WILL_DRAW,
- B_FOLLOW_ALL, false, true );
- fMessagesView->fScrollBar = fScrollView->ScrollBar( B_VERTICAL );
- AddChild( fScrollView );
-
+
+ p_sub = msg_Subscribe( p_intf );
+
+ BRect rect, textRect;
+
+ rect = Bounds();
+ rect.right -= B_V_SCROLL_BAR_WIDTH;
+ textRect = rect;
+ textRect.InsetBy( 5, 5 );
+ fMessagesView = new MessagesView( p_sub,
+ rect, "messages", textRect,
+ B_FOLLOW_ALL, B_WILL_DRAW );
+ fMessagesView->MakeEditable( false );
+ fMessagesView->SetStylable( true );
+ fScrollView = new BScrollView( "scrollview", fMessagesView, B_WILL_DRAW,
+ B_FOLLOW_ALL, false, true );
+ fMessagesView->fScrollBar = fScrollView->ScrollBar( B_VERTICAL );
+ AddChild( fScrollView );
+
/* start window thread in hidden state */
Hide();
Show();
*****************************************************************************/
MessagesWindow::~MessagesWindow()
{
+ msg_Unsubscribe( p_intf, p_sub );
}
/*****************************************************************************
class MessagesView : public BTextView
{
public:
- MessagesView( intf_thread_t * _p_intf,
+ MessagesView( msg_subscription_t * _p_sub,
BRect rect, char * name, BRect textRect,
uint32 resizingMode, uint32 flags )
: BTextView( rect, name, textRect,
- resizingMode, flags )
+ resizingMode, flags ),
+ p_sub(_p_sub)
{
- p_intf = _p_intf;
}
virtual void Pulse();
- intf_thread_t * p_intf;
msg_subscription_t * p_sub;
- BScrollBar * fScrollBar;
+ BScrollBar * fScrollBar;
};
class MessagesWindow : public BWindow
void ReallyQuit();
- intf_thread_t * p_intf;
+ intf_thread_t * p_intf;
+ msg_subscription_t * p_sub;
BView * fBackgroundView;
MessagesView * fMessagesView;
BScrollView * fScrollView;
};
-#endif // BEOS_PREFERENCES_WINDOW_H
+#endif // BEOS_PREFERENCES_WINDOW_H