haiku/src/bin/alert.cpp
Axel Dörfler 7f77e4bd76 Applied patch by Vasilis Kaoutsis:
* removed directive #include <cstdlib>
  removed directive #include <cassert>
  Removed also the use of assert()
  as BAlert::Go() returns always 0, or 1, or 2.
  renamed cstring to string.h
  and cstdio to stdio.h since
  our coding style prefers C-style headers.
* Merged the two classes to AlertApplication since
  i see no reason to have them both.
* removed some getter functions and used the
  private data members instead, since this doesn't
  break the "hide the implementation details rule" (i think).
* Modified Signature application from
  "application/x-vnd.OBOS.cmd-alert" to
  "application/x-vnd.Haiku.cmd-alert"
* Make some defines const char* and int32
  according to the corresponding types.
* Changed AlertApplication::SetChoice(const int32 but)
  to AlertApplication::SetChoice(int32 buttonIndex).
* The usual coding style clean-up (tabs, spaces, etc).
* Added documentation for more readable code here and there;
  and doxygen style documentation for two functions:
  AlertApplication::ArgvReceived(int32 argc, char** argv)
  and AlertApplication::ReadyToRun()
* Add myself to the authors' list, since that makes good
  to my psycology, and makes me more productive!


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@19655 a95241bf-73f2-0310-859d-f6bbb57e9c96
2006-12-29 11:29:00 +00:00

237 lines
5.2 KiB
C++

/*
* Copyright 2002-2006, Haiku Inc. All Rights Reserved.
* Distributed under the terms of the MIT License.
*
* Authors:
* Mathew Hounsell
* Vasilis Kaoutsis, kaoutsis@sch.gr
*/
#include <Alert.h>
#include <Application.h>
#include <stdio.h>
#include <string.h>
const char* kSignature = "application/x-vnd.Haiku.cmd-alert";
const char* kButtonDefault = "OK";
const int32 kErrorInitFail = 127;
const int32 kErrorArgumentsFail = 126;
class AlertApplication : public BApplication {
public:
AlertApplication();
virtual ~AlertApplication() { }
virtual void ReadyToRun();
virtual void ArgvReceived(int32 argc, char** argv);
bool GoodArguments() const { return fOk; }
int32 ChoiceNumber() const { return fChoiceNumber; }
char const* ChoiceText() const { return fChoiceText; }
private:
void _SetChoice(int32 buttonIndex);
void _Usage() const;
private:
bool fOk;
bool fModal;
alert_type fIcon;
char* fArgumentText;
char* fArgumentButton0;
char* fArgumentButton1;
char* fArgumentButton2;
char* fChoiceText;
int32 fChoiceNumber;
};
AlertApplication::AlertApplication()
: BApplication(kSignature),
fOk(false),
fModal(false),
fIcon(B_INFO_ALERT),
fArgumentText(NULL),
fArgumentButton0(NULL),
fArgumentButton1(NULL),
fArgumentButton2(NULL),
fChoiceText(NULL),
fChoiceNumber(0)
{
}
/*!
Invoked when the application receives a B_ARGV_RECEIVED message.
The message is sent when command line arguments are used in launching the
app from the shell. The function isn't called if there were no command
line arguments.
*/
void
AlertApplication::ArgvReceived(int32 argc, char** argv)
{
// Now there is at least one
// command line argument option.
const uint32 kArgCount = argc - 1;
uint32 index = 1;
bool iconFlag = false;
// Look for valid '--' options.
for (; index <= kArgCount; ++index) {
if (argv[index][0] == '-' && argv[index][1] == '-') {
const char* option = argv[index] + 2;
if (!strcmp(option, "modal"))
fModal = true;
else if (!strcmp(option, "empty") && !iconFlag) {
fIcon = B_EMPTY_ALERT;
iconFlag = true;
} else if (!strcmp(option, "info") && !iconFlag) {
fIcon = B_INFO_ALERT;
iconFlag = true;
} else if (!strcmp(option, "idea") && !iconFlag) {
fIcon = B_IDEA_ALERT;
iconFlag = true;
} else if (!strcmp(option, "warning") && !iconFlag) {
fIcon = B_WARNING_ALERT;
iconFlag = true;
} else if (!strcmp(option, "stop") && !iconFlag) {
fIcon = B_STOP_ALERT;
iconFlag = true;
} else {
// Unrecognized '--' opition.
fprintf(stdout, "Unrecognized option %s\n", argv[index]);
return;
}
} else {
// Option doesn't start with '--'
break;
}
if (index == kArgCount) {
// User provides arguments that all begins with '--',
// so none can be considered as text argument.
fprintf(stdout, "Missing the text argument!\n");
return;
}
}
fArgumentText = strdup(argv[index]);
// First argument that start without --,
// so grub it as the text argument.
if (index == kArgCount) {
// No more text argument. Give Button0
// the default label.
fArgumentButton0 = strdup(kButtonDefault);
fOk = true;
return;
}
if (index < kArgCount) {
// There is another argument,
// so let that be the Button0 label.
fArgumentButton0 = strdup(argv[++index]);
}
if (index < kArgCount) {
// There is another argument,
// so let that be the Button1 label.
fArgumentButton1 = strdup(argv[++index]);
}
if (index < kArgCount) {
// There is another argument,
// so let that be the Button2 label.
fArgumentButton2 = strdup(argv[++index]);
}
// Ignore all other arguments if they exist,
// since they are useless.
fOk = true;
}
void
AlertApplication::_SetChoice(int32 buttonIndex)
{
fChoiceNumber = buttonIndex;
switch (fChoiceNumber) {
case 0:
fChoiceText = fArgumentButton0;
break;
case 1:
fChoiceText = fArgumentButton1;
break;
case 2:
fChoiceText = fArgumentButton2;
break;
}
}
void
AlertApplication::_Usage() const
{
fprintf(stderr,
"usage: alert [ <type> ] [ --modal ] [ --help ] text [ button1 [ button2 [ button3 ]]]\n"
"<type> is --empty | --info | --idea | --warning | --stop\n"
"--modal makes the alert system modal and shows it in all workspaces.\n"
"If any button argument is given, exit status is button number (starting with 0)\n"
"and 'alert' will print the title of the button pressed to stdout.\n");
}
/*!
Is called when the app receives a B_READY_TO_RUN message. The message
is sent automatically during the Run() function, and is sent after the
initial B_REFS_RECEIVED and B_ARGV_RECEIVED messages (if any) have been
handled.
*/
void
AlertApplication::ReadyToRun()
{
if (GoodArguments()) {
BAlert* alert = new BAlert("alert", fArgumentText,
fArgumentButton0, fArgumentButton1, fArgumentButton2,
B_WIDTH_AS_USUAL, fIcon);
if (fModal)
alert->SetFeel(B_MODAL_ALL_WINDOW_FEEL);
_SetChoice(alert->Go());
} else
_Usage();
Quit();
}
// #pragma mark -
int
main(int argc, char** argv)
{
AlertApplication app;
if (app.InitCheck() != B_OK)
return kErrorInitFail;
app.Run();
if (!app.GoodArguments())
return kErrorArgumentsFail;
fprintf(stdout, "%s\n", app.ChoiceText());
return app.ChoiceNumber();
}