From a2ba3d656212da5e985caf215b1a4513a016ad1e Mon Sep 17 00:00:00 2001 From: Stefano Ceccherini Date: Sat, 21 Nov 2009 19:12:05 +0000 Subject: [PATCH] Removed dependency to the global gMouseClipboard from TermView. Now there's a SetMouseClipboard() method to set one (defaults to be_clipboard, maybe it's not a good idea and should default to NULL instead). git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@34178 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/apps/terminal/AppearPrefView.cpp | 4 +-- src/apps/terminal/TermView.cpp | 46 ++++++++++++++++------------ src/apps/terminal/TermView.h | 4 ++- src/apps/terminal/TermWindow.cpp | 3 +- 4 files changed, 33 insertions(+), 24 deletions(-) diff --git a/src/apps/terminal/AppearPrefView.cpp b/src/apps/terminal/AppearPrefView.cpp index 32efdfd08e..f7f4864d9b 100644 --- a/src/apps/terminal/AppearPrefView.cpp +++ b/src/apps/terminal/AppearPrefView.cpp @@ -167,8 +167,8 @@ AppearancePrefView::MessageReceived(BMessage *msg) break; case MSG_COLOR_CHANGED: { - rgb_color oldColor = PrefHandler::Default()->getRGB( - fColorField->Menu()->FindMarked()->Label()); + rgb_color oldColor = PrefHandler::Default()->getRGB( + fColorField->Menu()->FindMarked()->Label()); if (oldColor != fColorControl->ValueAsColor()) { PrefHandler::Default()->setRGB( fColorField->Menu()->FindMarked()->Label(), diff --git a/src/apps/terminal/TermView.cpp b/src/apps/terminal/TermView.cpp index 7dc56efc45..a99bb61817 100644 --- a/src/apps/terminal/TermView.cpp +++ b/src/apps/terminal/TermView.cpp @@ -46,7 +46,6 @@ #include #include "CodeConv.h" -#include "Globals.h" #include "Shell.h" #include "TermConst.h" #include "TerminalCharClassifier.h" @@ -165,7 +164,7 @@ private: TermView::TermView(BRect frame, int32 argc, const char** argv, int32 historySize) : BView(frame, "termview", B_FOLLOW_ALL, - B_WILL_DRAW | B_FRAME_EVENTS | B_FULL_UPDATE_ON_RESIZE | B_PULSE_NEEDED), + B_WILL_DRAW | B_FRAME_EVENTS | B_FULL_UPDATE_ON_RESIZE), fColumns(COLUMNS_DEFAULT), fRows(ROWS_DEFAULT), fEncoding(M_UTF8), @@ -183,7 +182,7 @@ TermView::TermView(BRect frame, int32 argc, const char** argv, int32 historySize TermView::TermView(int rows, int columns, int32 argc, const char** argv, int32 historySize) : BView(BRect(0, 0, 0, 0), "termview", B_FOLLOW_ALL, - B_WILL_DRAW | B_FRAME_EVENTS | B_FULL_UPDATE_ON_RESIZE | B_PULSE_NEEDED), + B_WILL_DRAW | B_FRAME_EVENTS | B_FULL_UPDATE_ON_RESIZE), fColumns(columns), fRows(rows), fEncoding(M_UTF8), @@ -223,8 +222,8 @@ TermView::TermView(BMessage* archive) fReportButtonMouseEvent(false), fReportAnyMouseEvent(false) { - // We need this - SetFlags(Flags() | B_WILL_DRAW | B_PULSE_NEEDED); + SetFlags(Flags() | B_WILL_DRAW | B_FRAME_EVENTS + | B_FULL_UPDATE_ON_RESIZE); if (archive->FindInt32("encoding", (int32*)&fEncoding) < B_OK) fEncoding = M_UTF8; @@ -232,7 +231,7 @@ TermView::TermView(BMessage* archive) fColumns = COLUMNS_DEFAULT; if (archive->FindInt32("rows", (int32*)&fRows) < B_OK) fRows = ROWS_DEFAULT; - + int32 argc = 0; if (archive->HasInt32("argc")) archive->FindInt32("argc", &argc); @@ -244,7 +243,7 @@ TermView::TermView(BMessage* archive) // TODO: Retrieve colors, history size, etc. from archive _InitObject(argc, argv); - + delete[] argv; } @@ -296,6 +295,7 @@ TermView::_InitObject(int32 argc, const char** argv) fReportNormalMouseEvent = false; fReportButtonMouseEvent = false; fReportAnyMouseEvent = false; + fMouseClipboard = be_clipboard; fTextBuffer = new(std::nothrow) TerminalBuffer; if (fTextBuffer == NULL) @@ -326,8 +326,7 @@ TermView::_InitObject(int32 argc, const char** argv) SetTermFont(be_fixed_font); SetTermSize(fRows, fColumns, false); - //SetIMAware(false); - + status_t status = fShell->Open(fRows, fColumns, EncodingAsShortString(fEncoding), argc, argv); @@ -365,8 +364,9 @@ TermView::~TermView() BArchivable * TermView::Instantiate(BMessage* data) { - if (validate_instantiation(data, "TermView")) + if (validate_instantiation(data, "TermView")) { return new (std::nothrow) TermView(data); + } return NULL; } @@ -577,6 +577,13 @@ TermView::SetEncoding(int encoding) } +void +TermView::SetMouseClipboard(BClipboard *clipboard) +{ + fMouseClipboard = clipboard; +} + + void TermView::GetTermFont(BFont *font) const { @@ -632,9 +639,8 @@ void TermView::SetScrollBar(BScrollBar *scrollBar) { fScrollBar = scrollBar; - if (fScrollBar != NULL) { + if (fScrollBar != NULL) fScrollBar->SetSteps(fFontHeight, fFontHeight * fRows); - } } @@ -976,7 +982,7 @@ void TermView::AttachedToWindow() { fMouseButtons = 0; - + MakeFocus(true); if (fScrollBar) { fScrollBar->SetSteps(fFontHeight, fFontHeight * fRows); @@ -1470,19 +1476,19 @@ TermView::MessageReceived(BMessage *msg) // the contents of the mouse clipboard with the ones from the // system clipboard, in case it contains text data. if (be_clipboard->Lock()) { - if (gMouseClipboard->Lock()) { + if (fMouseClipboard->Lock()) { BMessage* clipMsgA = be_clipboard->Data(); const char* text; ssize_t numBytes; if (clipMsgA->FindData("text/plain", B_MIME_TYPE, (const void**)&text, &numBytes) == B_OK ) { - gMouseClipboard->Clear(); - BMessage* clipMsgB = gMouseClipboard->Data(); + fMouseClipboard->Clear(); + BMessage* clipMsgB = fMouseClipboard->Data(); clipMsgB->AddData("text/plain", B_MIME_TYPE, text, numBytes); - gMouseClipboard->Commit(); + fMouseClipboard->Commit(); } - gMouseClipboard->Unlock(); + fMouseClipboard->Unlock(); } be_clipboard->Unlock(); } @@ -2154,7 +2160,7 @@ TermView::MouseDown(BPoint where) // paste button if ((buttons & (B_SECONDARY_MOUSE_BUTTON | B_TERTIARY_MOUSE_BUTTON)) != 0) { - Paste(gMouseClipboard); + Paste(fMouseClipboard); fLastClickPoint = where; return; } @@ -2338,7 +2344,7 @@ TermView::MouseUp(BPoint where) } else { if ((buttons & B_PRIMARY_MOUSE_BUTTON) == 0 && (fMouseButtons & B_PRIMARY_MOUSE_BUTTON) != 0) { - Copy(gMouseClipboard); + Copy(fMouseClipboard); } } diff --git a/src/apps/terminal/TermView.h b/src/apps/terminal/TermView.h index 225aa1e784..828d765cd0 100644 --- a/src/apps/terminal/TermView.h +++ b/src/apps/terminal/TermView.h @@ -62,10 +62,11 @@ public: int Encoding() const; void SetEncoding(int encoding); - //void SetIMAware(bool); void SetScrollBar(BScrollBar* scrollBar); BScrollBar* ScrollBar() const { return fScrollBar; }; + void SetMouseClipboard(BClipboard *); + virtual void SetTitle(const char* title); virtual void NotifyQuit(int32 reason); @@ -266,6 +267,7 @@ private: bool fReportNormalMouseEvent; bool fReportButtonMouseEvent; bool fReportAnyMouseEvent; + BClipboard* fMouseClipboard; // Input Method parameter. int fIMViewPtr; diff --git a/src/apps/terminal/TermWindow.cpp b/src/apps/terminal/TermWindow.cpp index f4794a2a39..93be937eee 100644 --- a/src/apps/terminal/TermWindow.cpp +++ b/src/apps/terminal/TermWindow.cpp @@ -32,6 +32,7 @@ #include "AppearPrefView.h" #include "Encoding.h" #include "FindWindow.h" +#include "Globals.h" #include "PrefWindow.h" #include "PrefHandler.h" #include "SmartTabView.h" @@ -800,7 +801,7 @@ TermWindow::_AddTab(Arguments *args) // and update the title using the last executed command ? // Or like Gnome's Terminal and use the current path ? view->SetScrollBar(scrollView->ScrollBar(B_VERTICAL)); - + view->SetMouseClipboard(gMouseClipboard); view->SetEncoding(EncodingID( PrefHandler::Default()->getString(PREF_TEXT_ENCODING)));