2003-02-12 04:11:55 +03:00
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
// Copyright (c) 2001-2002, OpenBeOS
|
|
|
|
//
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
// copy of this software and associated documentation files (the "Software"),
|
|
|
|
// to deal in the Software without restriction, including without limitation
|
|
|
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
// and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
// Software is furnished to do so, subject to the following conditions:
|
|
|
|
//
|
|
|
|
// The above copyright notice and this permission notice shall be included in
|
|
|
|
// all copies or substantial portions of the Software.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
// DEALINGS IN THE SOFTWARE.
|
|
|
|
//
|
|
|
|
// File Name: ServerWindow.cpp
|
|
|
|
// Author: DarkWyrm <bpmagic@columbus.rr.com>
|
|
|
|
// Description: Shadow BWindow class
|
|
|
|
//
|
|
|
|
//------------------------------------------------------------------------------
|
2003-02-07 15:53:57 +03:00
|
|
|
#include <AppDefs.h>
|
|
|
|
#include <Rect.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <View.h> // for B_XXXXX_MOUSE_BUTTON defines
|
|
|
|
#include "AppServer.h"
|
|
|
|
#include "Layer.h"
|
|
|
|
#include "PortLink.h"
|
|
|
|
#include "ServerWindow.h"
|
|
|
|
#include "ServerApp.h"
|
|
|
|
#include "ServerProtocol.h"
|
2003-02-14 04:53:53 +03:00
|
|
|
#include "WinBorder.h"
|
2003-02-07 15:53:57 +03:00
|
|
|
#include "Desktop.h"
|
2003-02-24 18:47:06 +03:00
|
|
|
#include "DesktopClasses.h"
|
2003-02-12 04:11:55 +03:00
|
|
|
#include "TokenHandler.h"
|
|
|
|
|
|
|
|
//! Handler to get BWindow tokens from
|
|
|
|
TokenHandler win_token_handler;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Contructor
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
Does a lot of stuff to set up for the window - new decorator, new winborder, spawn a
|
|
|
|
monitor thread.
|
2003-02-12 04:11:55 +03:00
|
|
|
*/
|
|
|
|
ServerWindow::ServerWindow(BRect rect, const char *string, uint32 wlook,
|
2003-03-19 04:12:53 +03:00
|
|
|
uint32 wfeel, uint32 wflags, ServerApp *winapp, port_id winport, uint32 index, int32 handlerID)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-12 04:11:55 +03:00
|
|
|
_title=new BString;
|
2003-03-12 21:32:27 +03:00
|
|
|
if(string)
|
|
|
|
_title->SetTo(string);
|
2003-02-12 04:11:55 +03:00
|
|
|
_frame=rect;
|
|
|
|
_flags=wflags;
|
|
|
|
_look=wlook;
|
|
|
|
_feel=wfeel;
|
2003-03-19 04:12:53 +03:00
|
|
|
_handlertoken=handlerID;
|
2003-02-07 15:53:57 +03:00
|
|
|
|
2003-03-12 21:32:27 +03:00
|
|
|
_winborder=new WinBorder(_frame,_title->String(),wlook,wfeel,wflags,this);
|
2003-02-07 15:53:57 +03:00
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
// _sender is the monitored window's event port
|
2003-02-12 04:11:55 +03:00
|
|
|
_sender=winport;
|
|
|
|
_winlink=new PortLink(_sender);
|
2003-02-07 15:53:57 +03:00
|
|
|
|
2003-02-12 04:11:55 +03:00
|
|
|
_applink= (winapp)? new PortLink(winapp->_receiver) : NULL;
|
2003-02-07 15:53:57 +03:00
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
// _receiver is the port to which the app sends messages for the server
|
2003-02-12 04:11:55 +03:00
|
|
|
_receiver=create_port(30,_title->String());
|
2003-02-07 15:53:57 +03:00
|
|
|
|
2003-02-12 04:11:55 +03:00
|
|
|
_active=false;
|
|
|
|
|
|
|
|
// Spawn our message monitoring _monitorthread
|
|
|
|
_monitorthread=spawn_thread(MonitorWin,_title->String(),B_NORMAL_PRIORITY,this);
|
|
|
|
if(_monitorthread!=B_NO_MORE_THREADS && _monitorthread!=B_NO_MEMORY)
|
|
|
|
resume_thread(_monitorthread);
|
2003-02-07 15:53:57 +03:00
|
|
|
|
2003-02-20 16:13:01 +03:00
|
|
|
_workspace_index=index;
|
2003-02-20 21:05:35 +03:00
|
|
|
_workspace=NULL;
|
2003-02-07 15:53:57 +03:00
|
|
|
|
2003-03-12 22:34:47 +03:00
|
|
|
_token=win_token_handler.GetToken();
|
|
|
|
|
2003-02-07 15:53:57 +03:00
|
|
|
AddWindowToDesktop(this,index);
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
//!Tears down all connections with the user application, kills the monitoring thread.
|
2003-02-07 15:53:57 +03:00
|
|
|
ServerWindow::~ServerWindow(void)
|
|
|
|
{
|
2003-02-12 04:11:55 +03:00
|
|
|
RemoveWindowFromDesktop(this);
|
|
|
|
if(_applink)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-12 04:11:55 +03:00
|
|
|
delete _applink;
|
|
|
|
_applink=NULL;
|
|
|
|
delete _title;
|
|
|
|
delete _winlink;
|
2003-02-24 18:47:06 +03:00
|
|
|
delete _winborder;
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
2003-02-12 04:11:55 +03:00
|
|
|
kill_thread(_monitorthread);
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Requests an update of the specified rectangle
|
|
|
|
\param rect The area to update, in the parent's coordinates
|
|
|
|
|
|
|
|
This could be considered equivalent to BView::Invalidate()
|
|
|
|
*/
|
2003-02-07 15:53:57 +03:00
|
|
|
void ServerWindow::RequestDraw(BRect rect)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
_winlink->SetOpCode(AS_LAYER_DRAW);
|
2003-02-12 04:11:55 +03:00
|
|
|
_winlink->Attach(&rect,sizeof(BRect));
|
|
|
|
_winlink->Flush();
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
//! Requests an update for the entire window
|
|
|
|
void ServerWindow::RequestDraw(void)
|
|
|
|
{
|
|
|
|
RequestDraw(_frame);
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Forces the window border to update its decorator
|
2003-02-12 04:11:55 +03:00
|
|
|
void ServerWindow::ReplaceDecorator(void)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
_winborder->UpdateDecorator();
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
//! Requests that the ServerWindow's BWindow quit
|
2003-02-07 15:53:57 +03:00
|
|
|
void ServerWindow::Quit(void)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
_winlink->SetOpCode(B_QUIT_REQUESTED);
|
|
|
|
_winlink->Flush();
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Gets the title for the window
|
|
|
|
\return The title for the window
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
const char *ServerWindow::GetTitle(void)
|
|
|
|
{
|
|
|
|
return _title->String();
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Gets the window's ServerApp
|
|
|
|
\return The ServerApp for the window
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
ServerApp *ServerWindow::GetApp(void)
|
|
|
|
{
|
|
|
|
return _app;
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
//! Shows the window's WinBorder
|
2003-02-07 15:53:57 +03:00
|
|
|
void ServerWindow::Show(void)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
if(_winborder)
|
|
|
|
_winborder->Show();
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
//! Hides the window's WinBorder
|
2003-02-07 15:53:57 +03:00
|
|
|
void ServerWindow::Hide(void)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
if(_winborder)
|
|
|
|
_winborder->Hide();
|
2003-02-12 04:11:55 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*
|
|
|
|
\brief Determines whether the window is hidden or not
|
|
|
|
\return true if hidden, false if not
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
bool ServerWindow::IsHidden(void)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
if(_winborder)
|
|
|
|
return _winborder->IsHidden();
|
|
|
|
return true;
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Handles focus and redrawing when changing focus states
|
|
|
|
|
|
|
|
The ServerWindow is set to (in)active and its decorator is redrawn based on its active status
|
|
|
|
*/
|
2003-02-07 15:53:57 +03:00
|
|
|
void ServerWindow::SetFocus(bool value)
|
|
|
|
{
|
2003-02-12 04:11:55 +03:00
|
|
|
if(_active!=value)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-12 04:11:55 +03:00
|
|
|
_active=value;
|
2003-02-24 18:47:06 +03:00
|
|
|
_winborder->RequestDraw();
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Determines whether or not the window is active
|
|
|
|
\return true if active, false if not
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
bool ServerWindow::HasFocus(void)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-12 04:11:55 +03:00
|
|
|
return _active;
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Notifies window of workspace (de)activation
|
|
|
|
\param workspace Index of the workspace changed
|
|
|
|
\param active New active status of the workspace
|
|
|
|
*/
|
|
|
|
void ServerWindow::WorkspaceActivated(int32 workspace, bool active)
|
|
|
|
{
|
|
|
|
// TODO: implement
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Notifies window of a workspace switch
|
|
|
|
\param oldone index of the previous workspace
|
|
|
|
\param newone index of the new workspace
|
|
|
|
*/
|
|
|
|
void ServerWindow::WorkspacesChanged(int32 oldone,int32 newone)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
// TODO: implement
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Notifies window of a change in focus
|
|
|
|
\param active New active status of the window
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
void ServerWindow::WindowActivated(bool active)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
// TODO: implement
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Notifies window of a change in screen resolution
|
|
|
|
\param frame Size of the new resolution
|
|
|
|
\param color_space Color space of the new screen mode
|
|
|
|
*/
|
|
|
|
void ServerWindow::ScreenModeChanged(const BRect frame, const color_space cspace)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
// TODO: implement
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*
|
|
|
|
\brief Sets the frame size of the window
|
|
|
|
\rect New window size
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
void ServerWindow::SetFrame(const BRect &rect)
|
|
|
|
{
|
|
|
|
_frame=rect;
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Returns the frame of the window in screen coordinates
|
|
|
|
\return The frame of the window in screen coordinates
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
BRect ServerWindow::Frame(void)
|
|
|
|
{
|
|
|
|
return _frame;
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Locks the window
|
|
|
|
\return B_OK if everything is ok, B_ERROR if something went wrong
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
status_t ServerWindow::Lock(void)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
return (_locker.Lock())?B_OK:B_ERROR;
|
2003-02-12 04:11:55 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
//! Unlocks the window
|
2003-02-12 04:11:55 +03:00
|
|
|
void ServerWindow::Unlock(void)
|
|
|
|
{
|
|
|
|
_locker.Unlock();
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Determines whether or not the window is locked
|
|
|
|
\return True if locked, false if not.
|
|
|
|
*/
|
2003-02-12 04:11:55 +03:00
|
|
|
bool ServerWindow::IsLocked(void)
|
|
|
|
{
|
|
|
|
return _locker.IsLocked();
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
void ServerWindow::DispatchMessage(int32 code, int8 *msgbuffer)
|
|
|
|
{
|
|
|
|
switch(code)
|
|
|
|
{
|
|
|
|
case AS_LAYER_CREATE:
|
|
|
|
{
|
|
|
|
// Received when a view is attached to a window. This will require
|
|
|
|
// us to attach a layer in the tree in the same manner and invalidate
|
|
|
|
// the area in which the new layer resides assuming that it is
|
|
|
|
// visible.
|
|
|
|
|
|
|
|
// Attached Data:
|
|
|
|
// 1) (int32) id of the parent view
|
|
|
|
// 2) (BRect) frame in parent's coordinates
|
|
|
|
// 3) (int32) resize flags
|
|
|
|
// 4) (int32) view flags
|
|
|
|
// 5) (uint16) view's hide level
|
|
|
|
|
|
|
|
// This is a synchronous call, so reply immediately with the ID of the layer
|
|
|
|
// so the BView can identify itself
|
|
|
|
|
|
|
|
// TODO: Implement
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AS_LAYER_DELETE:
|
|
|
|
{
|
|
|
|
// Received when a view is detached from a window. This is definitely
|
|
|
|
// the less taxing operation - we call PruneTree() on the removed
|
|
|
|
// layer, detach the layer itself, delete it, and invalidate the
|
|
|
|
// area assuming that the view was visible when removed
|
|
|
|
|
|
|
|
// Attached Data:
|
|
|
|
// 1) (int32) id of the removed view
|
|
|
|
|
|
|
|
// TODO: Implement
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AS_SHOW_WINDOW:
|
|
|
|
{
|
|
|
|
Show();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case AS_HIDE_WINDOW:
|
|
|
|
{
|
|
|
|
Hide();
|
|
|
|
break;
|
|
|
|
}
|
2003-03-19 04:12:53 +03:00
|
|
|
case AS_SEND_BEHIND:
|
|
|
|
case AS_ENABLE_UPDATES:
|
|
|
|
case AS_DISABLE_UPDATES:
|
|
|
|
case AS_NEEDS_UPDATE:
|
|
|
|
case AS_WINDOW_TITLE:
|
|
|
|
case AS_ADD_TO_SUBSET:
|
|
|
|
case AS_REM_FROM_SUBSET:
|
|
|
|
case AS_SET_LOOK:
|
|
|
|
case AS_SET_FLAGS:
|
|
|
|
case AS_SET_FEEL:
|
|
|
|
case AS_SET_ALIGNMENT:
|
|
|
|
case AS_GET_ALIGNMENT:
|
|
|
|
case AS_GET_WORKSPACES:
|
|
|
|
case AS_SET_WORKSPACES:
|
|
|
|
case AS_WINDOW_RESIZEBY:
|
|
|
|
case AS_WINDOW_RESIZETO:
|
2003-02-24 18:47:06 +03:00
|
|
|
case B_MINIMIZE:
|
|
|
|
case B_WINDOW_ACTIVATED:
|
|
|
|
case B_ZOOM:
|
|
|
|
case B_WINDOW_MOVE_TO:
|
|
|
|
case B_WINDOW_MOVE_BY:
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
printf("ServerWindow %s received unexpected code %lx",_title->String(),code);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-03-19 04:12:53 +03:00
|
|
|
/*!
|
|
|
|
\brief Iterator for graphics update messages
|
|
|
|
\param msgsize Size of the buffer containing the graphics messages
|
|
|
|
\param msgbuffer Buffer containing the graphics message
|
|
|
|
*/
|
|
|
|
void ServerWindow::DispatchGraphicsMessage(int32 msgsize, int8 *msgbuffer)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Message-dispatching loop for the ServerWindow
|
|
|
|
|
|
|
|
MonitorWin() watches the ServerWindow's message port and dispatches as necessary
|
|
|
|
\param data The thread's ServerWindow
|
|
|
|
\return Throwaway code. Always 0.
|
|
|
|
*/
|
|
|
|
int32 ServerWindow::MonitorWin(void *data)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
ServerWindow *win=(ServerWindow *)data;
|
|
|
|
|
2003-02-07 15:53:57 +03:00
|
|
|
int32 msgcode;
|
|
|
|
int8 *msgbuffer=NULL;
|
|
|
|
ssize_t buffersize,bytesread;
|
|
|
|
|
|
|
|
for(;;)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
buffersize=port_buffer_size(win->_receiver);
|
2003-02-07 15:53:57 +03:00
|
|
|
|
|
|
|
if(buffersize>0)
|
|
|
|
{
|
|
|
|
msgbuffer=new int8[buffersize];
|
2003-02-24 18:47:06 +03:00
|
|
|
bytesread=read_port(win->_receiver,&msgcode,msgbuffer,buffersize);
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
else
|
2003-02-24 18:47:06 +03:00
|
|
|
bytesread=read_port(win->_receiver,&msgcode,NULL,0);
|
2003-02-07 15:53:57 +03:00
|
|
|
|
|
|
|
if (bytesread != B_BAD_PORT_ID && bytesread != B_TIMED_OUT && bytesread != B_WOULD_BLOCK)
|
|
|
|
{
|
|
|
|
switch(msgcode)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
case B_QUIT_REQUESTED:
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
// Our BWindow sent us this message when it quit.
|
|
|
|
// We need to ask its ServerApp to delete our monitor
|
|
|
|
win->_applink->SetOpCode(AS_DELETE_WINDOW);
|
|
|
|
win->_applink->Attach((int32)win->_token);
|
|
|
|
win->_applink->Flush();
|
2003-02-07 15:53:57 +03:00
|
|
|
break;
|
|
|
|
}
|
2003-03-19 04:12:53 +03:00
|
|
|
case AS_BEGIN_UPDATE:
|
|
|
|
{
|
|
|
|
win->DispatchGraphicsMessage(buffersize,msgbuffer);
|
|
|
|
break;
|
|
|
|
}
|
2003-02-07 15:53:57 +03:00
|
|
|
default:
|
2003-02-24 18:47:06 +03:00
|
|
|
win->DispatchMessage(msgcode,msgbuffer);
|
2003-02-07 15:53:57 +03:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(buffersize>0)
|
|
|
|
delete msgbuffer;
|
|
|
|
|
|
|
|
if(msgcode==B_QUIT_REQUESTED)
|
|
|
|
break;
|
|
|
|
}
|
2003-02-12 04:11:55 +03:00
|
|
|
|
|
|
|
exit_thread(0);
|
2003-02-07 15:53:57 +03:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Passes mouse event messages to the appropriate window
|
|
|
|
\param code Message code of the mouse message
|
|
|
|
\param buffer Attachment buffer for the mouse message
|
|
|
|
*/
|
2003-02-07 15:53:57 +03:00
|
|
|
void ServerWindow::HandleMouseEvent(int32 code, int8 *buffer)
|
|
|
|
{
|
2003-02-14 04:53:53 +03:00
|
|
|
/* ServerWindow *mousewin=NULL;
|
2003-02-07 15:53:57 +03:00
|
|
|
int8 *index=buffer;
|
|
|
|
|
|
|
|
// Find the window which will receive our mouse event.
|
|
|
|
Layer *root=GetRootLayer();
|
2003-02-14 04:53:53 +03:00
|
|
|
WinBorder *_winborder;
|
2003-02-07 15:53:57 +03:00
|
|
|
|
|
|
|
// activeborder is used to remember windows when resizing/moving windows
|
|
|
|
// or sliding a tab
|
|
|
|
ASSERT(root!=NULL);
|
|
|
|
|
|
|
|
// Dispatch the mouse event to the proper window
|
|
|
|
switch(code)
|
|
|
|
{
|
|
|
|
case B_MOUSE_DOWN:
|
|
|
|
{
|
|
|
|
// Attached data:
|
|
|
|
// 1) int64 - time of mouse click
|
|
|
|
// 2) float - x coordinate of mouse click
|
|
|
|
// 3) float - y coordinate of mouse click
|
|
|
|
// 4) int32 - modifier keys down
|
|
|
|
// 5) int32 - buttons down
|
|
|
|
// 6) int32 - clicks
|
|
|
|
|
|
|
|
// int64 time=*((int64*)index);
|
|
|
|
index+=sizeof(int64);
|
|
|
|
float x=*((float*)index);
|
|
|
|
index+=sizeof(float);
|
|
|
|
float y=*((float*)index);
|
|
|
|
index+=sizeof(float);
|
|
|
|
int32 modifiers=*((int32*)index);
|
|
|
|
index+=sizeof(uint32);
|
|
|
|
uint32 buttons=*((uint32*)index);
|
|
|
|
index+=sizeof(uint32);
|
|
|
|
// int32 clicks=*((int32*)index);
|
|
|
|
BPoint pt(x,y);
|
|
|
|
|
|
|
|
// If we have clicked on a window,
|
2003-02-14 04:53:53 +03:00
|
|
|
_winborder=(WinBorder*)root->GetChildAt(pt);
|
2003-02-12 04:11:55 +03:00
|
|
|
if(_winborder)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-14 04:53:53 +03:00
|
|
|
mousewin=_winborder->Window();
|
|
|
|
_winborder->MouseDown(pt,buttons,modifiers);
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case B_MOUSE_UP:
|
|
|
|
{
|
|
|
|
// Attached data:
|
|
|
|
// 1) int64 - time of mouse click
|
|
|
|
// 2) float - x coordinate of mouse click
|
|
|
|
// 3) float - y coordinate of mouse click
|
|
|
|
// 4) int32 - modifier keys down
|
|
|
|
|
|
|
|
// int64 time=*((int64*)index);
|
|
|
|
index+=sizeof(int64);
|
|
|
|
float x=*((float*)index);
|
|
|
|
index+=sizeof(float);
|
|
|
|
float y=*((float*)index);
|
|
|
|
index+=sizeof(float);
|
|
|
|
// int32 modifiers=*((int32*)index);
|
|
|
|
BPoint pt(x,y);
|
|
|
|
|
2003-02-14 04:53:53 +03:00
|
|
|
set_is_moving_window(false);
|
|
|
|
_winborder=(WinBorder*)root->GetChildAt(pt);
|
2003-02-12 04:11:55 +03:00
|
|
|
if(_winborder)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-14 04:53:53 +03:00
|
|
|
mousewin=_winborder->Window();
|
2003-02-07 15:53:57 +03:00
|
|
|
|
|
|
|
// Eventually, we will build in MouseUp messages with buttons specified
|
|
|
|
// For now, we just "assume" no mouse specification with a 0.
|
2003-02-12 04:11:55 +03:00
|
|
|
// _winborder->MouseUp(pt,0,0);
|
2003-02-07 15:53:57 +03:00
|
|
|
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case B_MOUSE_MOVED:
|
|
|
|
{
|
|
|
|
// Attached data:
|
|
|
|
// 1) int64 - time of mouse click
|
|
|
|
// 2) float - x coordinate of mouse click
|
|
|
|
// 3) float - y coordinate of mouse click
|
|
|
|
// 4) int32 - buttons down
|
|
|
|
// int64 time=*((int64*)index);
|
|
|
|
index+=sizeof(int64);
|
|
|
|
float x=*((float*)index);
|
|
|
|
index+=sizeof(float);
|
|
|
|
float y=*((float*)index);
|
|
|
|
index+=sizeof(float);
|
|
|
|
uint32 buttons=*((uint32*)index);
|
|
|
|
BPoint pt(x,y);
|
|
|
|
|
2003-02-14 04:53:53 +03:00
|
|
|
if(is_moving_window() || is_resizing_window() || is_sliding_tab())
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
|
|
|
mousewin=active_serverwindow;
|
2003-02-14 04:53:53 +03:00
|
|
|
mousewin->_winborder->MouseMoved(pt,buttons,0);
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-02-14 04:53:53 +03:00
|
|
|
_winborder=(WinBorder*)root->GetChildAt(pt);
|
2003-02-12 04:11:55 +03:00
|
|
|
if(_winborder)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-14 04:53:53 +03:00
|
|
|
mousewin=_winborder->Window();
|
|
|
|
_winborder->MouseMoved(pt,buttons,0);
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2003-02-14 04:53:53 +03:00
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Passes key event messages to the appropriate window
|
|
|
|
\param code Message code of the key message
|
|
|
|
\param buffer Attachment buffer for the key message
|
|
|
|
*/
|
2003-02-14 04:53:53 +03:00
|
|
|
void ServerWindow::HandleKeyEvent(int32 code, int8 *buffer)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
/* ServerWindow *keywin=NULL;
|
|
|
|
int8 *index=buffer;
|
|
|
|
|
|
|
|
// Dispatch the key event to the active window
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Returns the Workspace object to which the window belongs
|
|
|
|
|
|
|
|
If the window belongs to all workspaces, it returns the current workspace
|
|
|
|
*/
|
|
|
|
Workspace *ServerWindow::GetWorkspace(void)
|
|
|
|
{
|
|
|
|
if(_workspace_index==B_ALL_WORKSPACES)
|
|
|
|
return _workspace->GetScreen()->GetActiveWorkspace();
|
|
|
|
|
|
|
|
return _workspace;
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Assign the window to a particular workspace object
|
|
|
|
\param The ServerWindow's new workspace
|
|
|
|
*/
|
2003-02-20 21:05:35 +03:00
|
|
|
void ServerWindow::SetWorkspace(Workspace *wkspc)
|
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
_workspace=wkspc;
|
2003-02-20 21:05:35 +03:00
|
|
|
}
|
|
|
|
|
2003-02-24 18:47:06 +03:00
|
|
|
/*!
|
|
|
|
\brief Handles window activation stuff. Called by Desktop functions
|
|
|
|
*/
|
2003-02-20 16:13:01 +03:00
|
|
|
void ActivateWindow(ServerWindow *oldwin,ServerWindow *newwin)
|
2003-02-07 15:53:57 +03:00
|
|
|
{
|
2003-02-24 18:47:06 +03:00
|
|
|
if(oldwin==newwin)
|
2003-02-07 15:53:57 +03:00
|
|
|
return;
|
2003-02-24 18:47:06 +03:00
|
|
|
|
|
|
|
if(oldwin)
|
|
|
|
oldwin->SetFocus(false);
|
|
|
|
|
|
|
|
if(newwin)
|
|
|
|
newwin->SetFocus(true);
|
2003-02-07 15:53:57 +03:00
|
|
|
}
|