1
0
mirror of https://github.com/cookiengineer/audacity synced 2025-06-16 16:10:06 +02:00
audacity/src/commands/CommandTargets.h
James Crook b1b1a362ed Doxygen, Clips and Labels
- Classes renamed and better doxygenated
- GetInfo: Type=Clips added
- GetInfo: Type=Labels added.
2018-02-24 14:20:24 -05:00

374 lines
11 KiB
C++

/**********************************************************************
Audacity - A Digital Audio Editor
Copyright 1999-2009 Audacity Team
License: GPL v2 - see LICENSE.txt
Dan Horgan
******************************************************************//**
\file CommandTargets
\brief Contains classes for 'command output targets' - objects which can
receive output from a command. For instance, a progress target might pass the
information to a GUI ProgressDialog. Using abstract targets means the command
objects needn't be concerned with what happens to the information.
Note: currently, reusing target objects is not generally safe - perhaps they
should be reference-counted.
\class CommandMessageTargetDecorator
\brief CommandMessageTargetDecorator is a CommandOutputTarget that forwards
its work on to another one. Typically we derive from it to modify some
functionality and forward the rest.
\class BriefCommandMessageTarget
\brief BriefCommandMessageTarget is a CommandOutputTarget that provides
status in a briefer listing
\class LispyCommandMessageTarget
\brief LispyCommandMessageTarget is a CommandOutputTarget that provides status
in a lispy style.
\class MessageDialogTarget
\brief MessageDialogTarget is a CommandOutputTarget that sends its status
to the LongMessageDialog.
\class CommandOutputTargets
\brief CommandOutputTargets a mix of three output classes to output
progress indication, status messages and errors.
\class BriefCommandOutputTargets
\brief BriefCommandOutputTargets is a CommandOutputTargets that replaces the
status message target with the BriefCommandMessageTarget version.
\class LispifiedCommandOutputTargets
\brief LispifiedCommandOutputTargets is a CommandOutputTargets that replaces the
status message target with the LispyCommandMessageTarget version.
\class ProgressToMessageTarget
\brief ProgressToMessageTarget formats the percentage complete text as a message
and sends it to that message target.
*//*******************************************************************/
#ifndef __COMMANDTARGETS__
#define __COMMANDTARGETS__
#include "../MemoryX.h"
#include <wx/string.h>
#include <wx/statusbr.h>
//#include "../src/Project.h"
#include "../widgets/ProgressDialog.h"
#include "../commands/ResponseQueue.h"
#include "../widgets/ErrorDialog.h"
/// Interface for objects that can receive command progress information
class CommandProgressTarget /* not final */
{
public:
virtual ~CommandProgressTarget() {}
virtual void Update(double completed) = 0;
};
/// Interface for objects that can receive (string) messages from a command
class CommandMessageTarget /* not final */
{
public:
CommandMessageTarget() {mCounts.push_back(0);}
virtual ~CommandMessageTarget() { Flush();}
virtual void Update(const wxString &message) = 0;
virtual void StartArray();
virtual void EndArray();
virtual void StartStruct();
virtual void EndStruct();
virtual void AddItem(const wxString &value , const wxString &name="" );
virtual void AddItem(const bool value , const wxString &name="" );
virtual void AddItem(const double value , const wxString &name="" );
virtual void AddField( const wxString &name="" );
virtual void Flush();
wxArrayInt mCounts;
};
class CommandMessageTargetDecorator : public CommandMessageTarget
{
public:
CommandMessageTargetDecorator( CommandMessageTarget & target): mTarget(target) {};
virtual ~CommandMessageTargetDecorator() { };
virtual void Update(const wxString &message) { mTarget.Update( message );};
virtual void StartArray() { mTarget.StartArray();};
virtual void EndArray(){ mTarget.EndArray();};
virtual void StartStruct(){ mTarget.StartStruct();};
virtual void EndStruct(){ mTarget.EndStruct();};
virtual void AddItem(const wxString &value , const wxString &name="" ){ mTarget.AddItem(value,name);};
virtual void AddItem(const bool value , const wxString &name="" ){ mTarget.AddItem(value,name);};
virtual void AddItem(const double value , const wxString &name="" ){ mTarget.AddItem(value,name);};
virtual void AddField( const wxString &name="" ){ mTarget.AddField(name);};
virtual void Flush(){ mTarget.Flush();};
CommandMessageTarget & mTarget;
};
class LispyCommandMessageTarget : public CommandMessageTargetDecorator /* not final */
{
public:
LispyCommandMessageTarget( CommandMessageTarget & target): CommandMessageTargetDecorator(target) {};
virtual void StartArray() override;
virtual void EndArray() override;
virtual void StartStruct() override;
virtual void EndStruct() override;
virtual void AddItem(const wxString &value , const wxString &name="" )override;
virtual void AddItem(const bool value , const wxString &name="" )override;
virtual void AddItem(const double value , const wxString &name="" )override;
virtual void AddField( const wxString &name="" )override;
};
class BriefCommandMessageTarget : public CommandMessageTargetDecorator /* not final */
{
public:
BriefCommandMessageTarget( CommandMessageTarget & target): CommandMessageTargetDecorator(target) {};
virtual void StartArray() override;
virtual void EndArray() override;
virtual void StartStruct() override;
virtual void EndStruct() override;
virtual void AddItem(const wxString &value , const wxString &name="" )override;
virtual void AddItem(const bool value , const wxString &name="" )override;
virtual void AddItem(const double value , const wxString &name="" )override;
virtual void AddField( const wxString &name="" )override;
};
/// Used to ignore a command's progress updates
class NullProgressTarget final : public CommandProgressTarget
{
public:
virtual ~NullProgressTarget() {}
void Update(double WXUNUSED(completed)) override {}
};
/// Sends command progress information to a ProgressDialog
class GUIProgressTarget final : public CommandProgressTarget
{
private:
ProgressDialog &mProgress;
public:
GUIProgressTarget(ProgressDialog &pd)
: mProgress(pd)
{}
virtual ~GUIProgressTarget() {}
void Update(double completed) override
{
mProgress.Update(completed);
}
};
///
class ProgressToMessageTarget final : public CommandProgressTarget
{
private:
std::unique_ptr<CommandMessageTarget> mTarget;
public:
ProgressToMessageTarget(std::unique_ptr<CommandMessageTarget> &&target)
: mTarget(std::move(target))
{ }
virtual ~ProgressToMessageTarget()
{
}
void Update(double completed) override
{
mTarget->Update(wxString::Format(wxT("%.2f%%"), completed*100));
}
};
/// Used to ignore a command's message updates
class NullMessageTarget final : public CommandMessageTarget
{
public:
virtual ~NullMessageTarget() {}
void Update(const wxString &) override {}
};
/// Displays messages from a command in an AudacityMessageBox
class MessageBoxTarget final : public CommandMessageTarget
{
public:
virtual ~MessageBoxTarget() {}
void Update(const wxString &message) override
{
AudacityMessageBox(message);
}
};
/// Displays messages from a command in a wxStatusBar
class StatusBarTarget final : public CommandMessageTarget
{
private:
wxStatusBar &mStatus;
public:
StatusBarTarget(wxStatusBar &sb)
: mStatus(sb)
{}
void Update(const wxString &message) override
{
mStatus.SetStatusText(message, 0);
}
};
/// Adds messages to a response queue (to be sent back to a script)
class ResponseQueueTarget final : public CommandMessageTarget
{
private:
ResponseQueue &mResponseQueue;
public:
ResponseQueueTarget(ResponseQueue &responseQueue)
: mResponseQueue(responseQueue)
{ }
virtual ~ResponseQueueTarget()
{
mResponseQueue.AddResponse(wxString(wxT("\n")));
}
void Update(const wxString &message) override
{
mResponseQueue.AddResponse(message);
}
};
/// Sends messages to two message targets at once
class CombinedMessageTarget final : public CommandMessageTarget
{
private:
std::unique_ptr<CommandMessageTarget> m1, m2;
public:
CombinedMessageTarget(std::unique_ptr<CommandMessageTarget> &&t1,
std::unique_ptr<CommandMessageTarget> &&t2)
: m1(std::move(t1)), m2(std::move(t2))
{
wxASSERT(m1);
wxASSERT(m2);
}
~CombinedMessageTarget()
{
}
void Update(const wxString &message) override
{
m1->Update(message);
m2->Update(message);
}
};
/**
\class TargetFactory
\brief TargetFactory makes Command output targets. By default, we ignore progress
updates but display all other messages directly
*/
class TargetFactory
{
public:
static std::unique_ptr<CommandProgressTarget> ProgressDefault()
{
return std::make_unique<NullProgressTarget>();
}
static std::shared_ptr<CommandMessageTarget> MessageDefault()
{
return std::make_shared<MessageBoxTarget>();
}
};
/// Used to aggregate the various output targets a command may have.
/// Assumes responsibility for pointers passed into it.
class CommandOutputTargets
{
public:
std::unique_ptr<CommandProgressTarget> mProgressTarget;
std::shared_ptr<CommandMessageTarget> mStatusTarget;
std::shared_ptr<CommandMessageTarget> mErrorTarget;
public:
CommandOutputTargets(std::unique_ptr<CommandProgressTarget> &&pt = TargetFactory::ProgressDefault(),
std::shared_ptr<CommandMessageTarget> &&st = TargetFactory::MessageDefault(),
std::shared_ptr<CommandMessageTarget> &&et = TargetFactory::MessageDefault())
: mProgressTarget(std::move(pt)), mStatusTarget(st), mErrorTarget(et)
{ }
~CommandOutputTargets()
{
}
// Lots of forwarding...
void Progress(double completed)
{
if (mProgressTarget)
mProgressTarget->Update(completed);
}
void Status(const wxString &status)
{
if (mStatusTarget)
mStatusTarget->Update(status);
}
void Error(const wxString &message)
{
if (mErrorTarget)
mErrorTarget->Update(message);
}
void StartArray()
{
if (mStatusTarget)
mStatusTarget->StartArray();
}
void EndArray()
{
if (mStatusTarget)
mStatusTarget->EndArray();
}
void StartStruct()
{
if (mStatusTarget)
mStatusTarget->StartStruct();
}
void EndStruct()
{
if (mStatusTarget)
mStatusTarget->EndStruct();
}
void AddItem(const wxString &value , const wxString &name="" )
{
if (mStatusTarget)
mStatusTarget->AddItem( value, name );
}
void AddItem(const bool value , const wxString &name="" )
{
if (mStatusTarget)
mStatusTarget->AddItem( value, name );
}
void AddItem(const double value , const wxString &name="" )
{
if (mStatusTarget)
mStatusTarget->AddItem( value, name );
}
};
class LispifiedCommandOutputTargets : public CommandOutputTargets
{
public :
LispifiedCommandOutputTargets( CommandOutputTargets & target );
~LispifiedCommandOutputTargets();
private:
CommandOutputTargets * pToRestore;
};
class BriefCommandOutputTargets : public CommandOutputTargets
{
public :
BriefCommandOutputTargets( CommandOutputTargets & target );
~BriefCommandOutputTargets();
private:
CommandOutputTargets * pToRestore;
};
class InteractiveOutputTargets : public CommandOutputTargets
{
public:
InteractiveOutputTargets();
};
#endif /* End of include guard: __COMMANDTARGETS__ */