* Implemented loading icons from resources - doesn't seem to work yet, though.
* Fixed leaking menu items in StatusReplicant::_PrepareMenu(). * Renamed private methods to have an underscore prefix. * Some minor style cleanup. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@20531 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
1407f23d9b
commit
3eb30a22b2
@ -1,6 +1,7 @@
|
|||||||
SubDir HAIKU_TOP src servers net ;
|
SubDir HAIKU_TOP src servers net ;
|
||||||
|
|
||||||
UsePrivateHeaders app net ;
|
UsePrivateHeaders app net ;
|
||||||
|
UseLibraryHeaders icon ;
|
||||||
|
|
||||||
#UseHeaders [ FDirName $(HAIKU_TOP) src add-ons kernel network ppp shared libppp headers ] ;
|
#UseHeaders [ FDirName $(HAIKU_TOP) src add-ons kernel network ppp shared libppp headers ] ;
|
||||||
#UseHeaders [ FDirName $(HAIKU_TOP) src add-ons kernel network ppp shared libkernelppp headers ] ;
|
#UseHeaders [ FDirName $(HAIKU_TOP) src add-ons kernel network ppp shared libkernelppp headers ] ;
|
||||||
|
@ -990,8 +990,8 @@ NetServer::_UpdateReplicantStatus()
|
|||||||
if (it->second > prevaling)
|
if (it->second > prevaling)
|
||||||
prevaling = it->second;
|
prevaling = it->second;
|
||||||
|
|
||||||
message.AddString("intf:name", it->first.c_str());
|
message.AddString("interface:name", it->first.c_str());
|
||||||
message.AddInt32("intf:status", it->second);
|
message.AddInt32("interface:status", it->second);
|
||||||
}
|
}
|
||||||
|
|
||||||
message.AddInt32("net:status", prevaling);
|
message.AddInt32("net:status", prevaling);
|
||||||
|
@ -6,19 +6,27 @@
|
|||||||
* Hugo Santos, hugosantos@gmail.com
|
* Hugo Santos, hugosantos@gmail.com
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "NetServer.h"
|
|
||||||
#include "StatusReplicant.h"
|
#include "StatusReplicant.h"
|
||||||
|
|
||||||
|
#include "NetServer.h"
|
||||||
|
#include "NetworkStatusIcons.h"
|
||||||
|
|
||||||
#include <Alert.h>
|
#include <Alert.h>
|
||||||
|
#include <Application.h>
|
||||||
|
#include <Bitmap.h>
|
||||||
|
#include <IconUtils.h>
|
||||||
#include <MenuItem.h>
|
#include <MenuItem.h>
|
||||||
#include <Message.h>
|
#include <Message.h>
|
||||||
#include <Messenger.h>
|
#include <Messenger.h>
|
||||||
|
#include <Resources.h>
|
||||||
#include <TextView.h>
|
#include <TextView.h>
|
||||||
|
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/sockio.h>
|
#include <sys/sockio.h>
|
||||||
|
|
||||||
|
|
||||||
const char *kStatusReplicant = "NetStatusView";
|
const char *kStatusReplicant = "NetStatusView";
|
||||||
static const uint32 kShowConfiguration = 'shcf';
|
static const uint32 kShowConfiguration = 'shcf';
|
||||||
|
|
||||||
@ -42,7 +50,6 @@ static const information_entry kInformationEntries[] = {
|
|||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static const char *kStatusDescriptions[] = {
|
static const char *kStatusDescriptions[] = {
|
||||||
"Unknown",
|
"Unknown",
|
||||||
"No Link",
|
"No Link",
|
||||||
@ -54,22 +61,25 @@ static const char *kStatusDescriptions[] = {
|
|||||||
|
|
||||||
StatusReplicant::StatusReplicant()
|
StatusReplicant::StatusReplicant()
|
||||||
: BView(BRect(0, 0, 15, 15), kStatusReplicant, B_FOLLOW_ALL, 0),
|
: BView(BRect(0, 0, 15, 15), kStatusReplicant, B_FOLLOW_ALL, 0),
|
||||||
fPopup("", false, false)
|
fPopUp("", false, false)
|
||||||
{
|
{
|
||||||
|
_Init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
StatusReplicant::StatusReplicant(BMessage *message)
|
StatusReplicant::StatusReplicant(BMessage *message)
|
||||||
: BView(message), fPopup("", false, false)
|
: BView(message),
|
||||||
|
fPopUp("", false, false)
|
||||||
{
|
{
|
||||||
// TODO: Load status bitmaps from resources
|
_Init();
|
||||||
for (int i = 0; i < kStatusCount; i++)
|
|
||||||
fBitmaps[i] = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
StatusReplicant::~StatusReplicant()
|
StatusReplicant::~StatusReplicant()
|
||||||
{
|
{
|
||||||
|
for (int32 i = 0; i < kStatusCount; i++) {
|
||||||
|
delete fBitmaps[i];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -78,6 +88,7 @@ StatusReplicant::Instantiate(BMessage *data)
|
|||||||
{
|
{
|
||||||
if (validate_instantiation(data, kStatusReplicant))
|
if (validate_instantiation(data, kStatusReplicant))
|
||||||
return new StatusReplicant(data);
|
return new StatusReplicant(data);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -102,8 +113,8 @@ StatusReplicant::AttachedToWindow()
|
|||||||
// TODO: Remove myself from Deskbar
|
// TODO: Remove myself from Deskbar
|
||||||
}
|
}
|
||||||
|
|
||||||
ChangeStatus(kStatusUnknown);
|
_ChangeStatus(kStatusUnknown);
|
||||||
PrepareMenu(InterfaceStatusList());
|
_PrepareMenu(InterfaceStatusList());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -111,15 +122,16 @@ void
|
|||||||
StatusReplicant::MessageReceived(BMessage *message)
|
StatusReplicant::MessageReceived(BMessage *message)
|
||||||
{
|
{
|
||||||
switch (message->what) {
|
switch (message->what) {
|
||||||
case kStatusUpdate:
|
case kStatusUpdate:
|
||||||
UpdateFromMessage(message);
|
_UpdateFromMessage(message);
|
||||||
break;
|
break;
|
||||||
case kShowConfiguration:
|
case kShowConfiguration:
|
||||||
ShowConfiguration(message);
|
_ShowConfiguration(message);
|
||||||
break;
|
break;
|
||||||
default:
|
|
||||||
BView::MessageReceived(message);
|
default:
|
||||||
break;
|
BView::MessageReceived(message);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,49 +145,79 @@ StatusReplicant::MouseDown(BPoint point)
|
|||||||
GetMouse(&where, &buttons, true);
|
GetMouse(&where, &buttons, true);
|
||||||
where = ConvertToScreen(point);
|
where = ConvertToScreen(point);
|
||||||
|
|
||||||
fPopup.SetTargetForItems(this);
|
fPopUp.SetTargetForItems(this);
|
||||||
fPopup.Go(where, true, true);
|
fPopUp.Go(where, true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
StatusReplicant::UpdateFromMessage(BMessage *message)
|
StatusReplicant::_Init()
|
||||||
{
|
{
|
||||||
int32 newStatus, intfStatus;
|
// Load status bitmaps from resources
|
||||||
|
|
||||||
|
BResources* resources = BApplication::AppResources();
|
||||||
|
|
||||||
|
for (int i = 0; i < kStatusCount; i++) {
|
||||||
|
fBitmaps[i] = NULL;
|
||||||
|
|
||||||
|
if (resources != NULL) {
|
||||||
|
const void* data = NULL;
|
||||||
|
size_t size;
|
||||||
|
data = resources->LoadResource(B_VECTOR_ICON_TYPE,
|
||||||
|
kNetworkStatusNoDevice + i, &size);
|
||||||
|
if (data != NULL) {
|
||||||
|
BBitmap* icon = new BBitmap(Bounds(), B_RGB32);
|
||||||
|
if (icon->InitCheck() == B_OK
|
||||||
|
&& BIconUtils::GetVectorIcon((const uint8 *)data,
|
||||||
|
size, icon) == B_OK) {
|
||||||
|
fBitmaps[i] = icon;
|
||||||
|
} else
|
||||||
|
delete icon;
|
||||||
|
|
||||||
|
free((void*)data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
StatusReplicant::_UpdateFromMessage(BMessage *message)
|
||||||
|
{
|
||||||
|
int32 newStatus;
|
||||||
if (message->FindInt32("net:status", &newStatus) != B_OK
|
if (message->FindInt32("net:status", &newStatus) != B_OK
|
||||||
|| newStatus < 0 || newStatus >= kStatusCount)
|
|| newStatus < 0 || newStatus >= kStatusCount)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
InterfaceStatusList status;
|
InterfaceStatusList status;
|
||||||
int index = 0;
|
int32 interfaceStatus;
|
||||||
while (message->FindInt32("intf:status", index, &intfStatus) == B_OK) {
|
|
||||||
if (intfStatus < 0 || intfStatus >= kStatusCount)
|
for (uint32 index = 0; message->FindInt32("interface:status", index,
|
||||||
|
&interfaceStatus) == B_OK; index++) {
|
||||||
|
if (interfaceStatus < 0 || interfaceStatus >= kStatusCount)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
const char *name;
|
const char *name;
|
||||||
if (message->FindString("intf:name", index, &name) != B_OK)
|
if (message->FindString("interface:name", index, &name) != B_OK)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
status.push_back(InterfaceStatus(name, intfStatus));
|
status.push_back(InterfaceStatus(name, interfaceStatus));
|
||||||
|
|
||||||
index++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ChangeStatus(newStatus);
|
_ChangeStatus(newStatus);
|
||||||
PrepareMenu(status);
|
_PrepareMenu(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
StatusReplicant::ShowConfiguration(BMessage *message)
|
StatusReplicant::_ShowConfiguration(BMessage *message)
|
||||||
{
|
{
|
||||||
const char *device;
|
const char *device;
|
||||||
if (message->FindString("intf:name", &device) != B_OK)
|
if (message->FindString("interface:name", &device) != B_OK)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int32 status;
|
int32 status;
|
||||||
if (message->FindInt32("intf:status", &status) != B_OK)
|
if (message->FindInt32("interface:status", &status) != B_OK)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (status != kStatusConnected && status != kStatusLinkNoConfig)
|
if (status != kStatusConnected && status != kStatusLinkNoConfig)
|
||||||
@ -233,13 +275,13 @@ StatusReplicant::ShowConfiguration(BMessage *message)
|
|||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
StatusReplicant::PrepareMenu(const InterfaceStatusList &status)
|
StatusReplicant::_PrepareMenu(const InterfaceStatusList &status)
|
||||||
{
|
{
|
||||||
while (fPopup.RemoveItem((int32)0));
|
fPopUp.RemoveItems(0, fPopUp.CountItems(), true);
|
||||||
|
|
||||||
if (status.empty()) {
|
if (status.empty()) {
|
||||||
fPopup.AddItem(new BMenuItem("No interfaces available.", NULL));
|
fPopUp.AddItem(new BMenuItem("No interfaces available.", NULL));
|
||||||
fPopup.ItemAt(0)->SetEnabled(false);
|
fPopUp.ItemAt(0)->SetEnabled(false);
|
||||||
} else {
|
} else {
|
||||||
for (InterfaceStatusList::const_iterator i = status.begin();
|
for (InterfaceStatusList::const_iterator i = status.begin();
|
||||||
i != status.end(); ++i) {
|
i != status.end(); ++i) {
|
||||||
@ -248,21 +290,21 @@ StatusReplicant::PrepareMenu(const InterfaceStatusList &status)
|
|||||||
label += kStatusDescriptions[i->second];
|
label += kStatusDescriptions[i->second];
|
||||||
|
|
||||||
BMessage *message = new BMessage(kShowConfiguration);
|
BMessage *message = new BMessage(kShowConfiguration);
|
||||||
message->AddString("intf:name", i->first.c_str());
|
message->AddString("interface:name", i->first.c_str());
|
||||||
message->AddInt32("intf:status", i->second);
|
message->AddInt32("interface:status", i->second);
|
||||||
|
|
||||||
BMenuItem *item = new BMenuItem(label.c_str(), message);
|
BMenuItem *item = new BMenuItem(label.c_str(), message);
|
||||||
if (i->second != kStatusConnected &&
|
if (i->second != kStatusConnected &&
|
||||||
i->second != kStatusLinkNoConfig)
|
i->second != kStatusLinkNoConfig)
|
||||||
item->SetEnabled(false);
|
item->SetEnabled(false);
|
||||||
fPopup.AddItem(item);
|
fPopUp.AddItem(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
StatusReplicant::ChangeStatus(int newStatus)
|
StatusReplicant::_ChangeStatus(int newStatus)
|
||||||
{
|
{
|
||||||
if (fBitmaps[newStatus]) {
|
if (fBitmaps[newStatus]) {
|
||||||
SetViewColor(Parent()->ViewColor());
|
SetViewColor(Parent()->ViewColor());
|
||||||
|
@ -5,10 +5,10 @@
|
|||||||
* Authors:
|
* Authors:
|
||||||
* Hugo Santos, hugosantos@gmail.com
|
* Hugo Santos, hugosantos@gmail.com
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _STATUS_REPLICANT_H
|
#ifndef _STATUS_REPLICANT_H
|
||||||
#define _STATUS_REPLICANT_H
|
#define _STATUS_REPLICANT_H
|
||||||
|
|
||||||
|
|
||||||
#include "NetServer.h"
|
#include "NetServer.h"
|
||||||
|
|
||||||
#include <PopUpMenu.h>
|
#include <PopUpMenu.h>
|
||||||
@ -18,35 +18,38 @@
|
|||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
|
||||||
static const uint32 kRegisterStatusReplicant = 'rnsr';
|
static const uint32 kRegisterStatusReplicant = 'rnsr';
|
||||||
static const uint32 kStatusUpdate = 'stup';
|
static const uint32 kStatusUpdate = 'stup';
|
||||||
extern const char *kStatusReplicant;
|
extern const char *kStatusReplicant;
|
||||||
|
|
||||||
|
|
||||||
class StatusReplicant : public BView {
|
class StatusReplicant : public BView {
|
||||||
public:
|
public:
|
||||||
StatusReplicant();
|
StatusReplicant();
|
||||||
StatusReplicant(BMessage *);
|
StatusReplicant(BMessage *archive);
|
||||||
virtual ~StatusReplicant();
|
virtual ~StatusReplicant();
|
||||||
|
|
||||||
static StatusReplicant *Instantiate(BMessage *);
|
static StatusReplicant *Instantiate(BMessage *archive);
|
||||||
status_t Archive(BMessage *, bool deep) const;
|
status_t Archive(BMessage *archive, bool deep) const;
|
||||||
|
|
||||||
void AttachedToWindow();
|
void AttachedToWindow();
|
||||||
void MessageReceived(BMessage *);
|
void MessageReceived(BMessage *message);
|
||||||
|
|
||||||
void MouseDown(BPoint point);
|
void MouseDown(BPoint point);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef std::pair<std::string, int> InterfaceStatus;
|
typedef std::pair<std::string, int> InterfaceStatus;
|
||||||
typedef std::vector<InterfaceStatus> InterfaceStatusList;
|
typedef std::vector<InterfaceStatus> InterfaceStatusList;
|
||||||
|
|
||||||
void UpdateFromMessage(BMessage *);
|
void _Init();
|
||||||
void ShowConfiguration(BMessage *);
|
void _UpdateFromMessage(BMessage *message);
|
||||||
void PrepareMenu(const InterfaceStatusList &);
|
void _ShowConfiguration(BMessage *message);
|
||||||
void ChangeStatus(int newStatus);
|
void _PrepareMenu(const InterfaceStatusList &list);
|
||||||
|
void _ChangeStatus(int newStatus);
|
||||||
|
|
||||||
BPopUpMenu fPopup;
|
BPopUpMenu fPopUp;
|
||||||
BBitmap *fBitmaps[kStatusCount];
|
BBitmap *fBitmaps[kStatusCount];
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif // _STATUS_REPLICANT_H
|
||||||
|
Loading…
Reference in New Issue
Block a user