From 5f82fc3a95dd342ad2ae16007dcf36bae632568a Mon Sep 17 00:00:00 2001 From: Wolf Bergenheim Date: Thu, 16 Sep 2010 10:11:33 +0300 Subject: Final unification changes --- resourceqt-client/client.cpp | 66 ++++++++++++++++++++++++++++++++------------ 1 file changed, 48 insertions(+), 18 deletions(-) (limited to 'resourceqt-client/client.cpp') diff --git a/resourceqt-client/client.cpp b/resourceqt-client/client.cpp index adf1feb..b15f054 100644 --- a/resourceqt-client/client.cpp +++ b/resourceqt-client/client.cpp @@ -8,6 +8,8 @@ #include "client.h" +#define outputln output << "\n" + using namespace ResourcePolicy; QMap Client::commandList; @@ -55,7 +57,7 @@ Client::~Client() void Client::showPrompt() { - output << "res-client> " << flush; + output << "resource-Qt> " << flush; } bool Client::initialize(const CommandLineParser &parser) @@ -113,7 +115,7 @@ bool Client::initialize(const CommandLineParser &parser) this, SLOT(doExit()))) { return false; } - + output << "accepting input" << endl; showPrompt(); return true; @@ -161,7 +163,7 @@ const char * resourceTypeToString(ResourceType type) void Client::showResources(const QList &resList) { - output << "Resource Set:\n"; + outputln << "Resource Set:\n"; foreach(ResourceType resource, resList) { output << "\t" << resourceTypeToString(resource) << endl; } @@ -169,7 +171,7 @@ void Client::showResources(const QList &resList) void Client::showResources(const QList &resList) { - output << "Resource Set:\n"; + outputln << "Resource Set:\n"; foreach(Resource* resource, resList) { output << "\t" << resourceTypeToString(resource->type()); if (resource->isOptional()) @@ -180,20 +182,25 @@ void Client::showResources(const QList &resList) } } -void Client::resourceAcquiredHandler(const QList& /*grantedResList*/) +void Client::resourceAcquiredHandler(const QList&) { long int ms = stop_timer(); if (ms > 0) { - output << "Operation took " << ms << "ms"; + outputln << "Operation took " << ms << "ms" << endl; } QList list = resourceSet->resources(); if (!list.count()) { - qFatal("Granted resource set is empty. Possible bug?"); + qFatal("Resource set is empty, but we received a grant. Possible bug?"); } else { - output << "\nReceived a grant.\n"; - showResources(list); + QList grantedResources; + foreach(ResourcePolicy::Resource *resource, list) { + if (resource->isGranted()) { + grantedResources << resource->type(); + } + } + output << "granted:" << grantedResources << endl; } showPrompt(); } @@ -202,10 +209,10 @@ void Client::resourceDeniedHandler() { long int ms = stop_timer(); if (ms > 0) { - output << "Operation took " << ms << "ms"; + outputln << "Operation took " << ms << "ms" << endl; } - - output << "\nManager denies access to resources!" << endl; + QList allResources = resourceSet->resources(); + output << "denied:" << allResources << endl; showPrompt(); } @@ -213,10 +220,11 @@ void Client::resourceLostHandler() { long int ms = stop_timer(); if (ms > 0) { - output << "Operation took " << ms << "ms"; + outputln << "Operation took " << ms << "ms" << endl; } - output << "\nLost resources from manager!" << endl; + QList allResources = resourceSet->resources(); + outputln << "lost:" << allResources << endl; showPrompt(); } @@ -224,17 +232,17 @@ void Client::resourceReleasedHandler() { long int ms = stop_timer(); if (ms > 0) { - output << "Operation took " << ms << "ms"; + outputln << "Operation took " << ms << "ms" << endl; } - output << "\nAll resources released" << endl; + QList allResources = resourceSet->resources(); + outputln << "released:"<< allResources << endl; showPrompt(); } void Client::resourcesBecameAvailableHandler(const QList &availableResources) { - output << "Manager advice: These resources are available:\n"; - showResources(availableResources); + outputln << "advice:" << availableResources << endl; showPrompt(); } @@ -431,3 +439,25 @@ void Client::readLine(int) showPrompt(); } +QTextStream & operator<<(QTextStream &output, + const QListresources) +{ + char separator = ' '; + foreach(Resource* resource, resources) { + output << separator << resourceTypeToString(resource->type()); + separator = ','; + } + return output; +} + +QTextStream & operator<< (QTextStream &output, + const QListresources) +{ + char separator = ' '; + foreach(ResourceType resource, resources) { + output << separator << resourceTypeToString(resource); + separator = ','; + } + return output; +} + -- cgit v1.2.3