* Copyright 2006, Haiku.
* Distributed under the terms of the MIT License.
*
* Authors:
* Stephan Aßmus <superstippi@gmx.de>
*/
#include "MoveTransformersCommand.h"
#include <new>
#include <stdio.h>
#include <Catalog.h>
#include <Locale.h>
#include "Shape.h"
#include "Transformer.h"
#undef B_TRANSLATION_CONTEXT
#define B_TRANSLATION_CONTEXT "Icon-O-Matic-MoveTransformersCmd"
using std::nothrow;
MoveTransformersCommand::MoveTransformersCommand(Shape* container,
Transformer** transformers,
int32 count,
int32 toIndex)
: Command(),
fContainer(container),
fTransformers(transformers),
fIndices(count > 0 ? new (nothrow) int32[count] : NULL),
fToIndex(toIndex),
fCount(count)
{
if (!fContainer || !fTransformers || !fIndices)
return;
int32 itemsBeforeIndex = 0;
for (int32 i = 0; i < fCount; i++) {
fIndices[i] = fContainer->IndexOf(fTransformers[i]);
if (fIndices[i] >= 0 && fIndices[i] < fToIndex)
itemsBeforeIndex++;
}
fToIndex -= itemsBeforeIndex;
}
MoveTransformersCommand::~MoveTransformersCommand()
{
delete[] fTransformers;
delete[] fIndices;
}
status_t
MoveTransformersCommand::InitCheck()
{
if (!fContainer || !fTransformers || !fIndices)
return B_NO_INIT;
int32 index = fIndices[0];
if (index != fToIndex) {
return B_OK;
}
bool isContiguous = true;
for (int32 i = 1; i < fCount; i++) {
if (fIndices[i] != index + 1) {
isContiguous = false;
break;
}
index = fIndices[i];
}
if (isContiguous) {
return B_ERROR;
}
return B_OK;
}
status_t
MoveTransformersCommand::Perform()
{
status_t ret = B_OK;
for (int32 i = 0; i < fCount; i++) {
if (fTransformers[i]
&& !fContainer->RemoveTransformer(fTransformers[i])) {
ret = B_ERROR;
break;
}
}
if (ret < B_OK)
return ret;
int32 index = fToIndex;
for (int32 i = 0; i < fCount; i++) {
if (fTransformers[i]
&& !fContainer->AddTransformer(fTransformers[i], index++)) {
ret = B_ERROR;
break;
}
}
return ret;
}
status_t
MoveTransformersCommand::Undo()
{
status_t ret = B_OK;
for (int32 i = 0; i < fCount; i++) {
if (fTransformers[i]
&& !fContainer->RemoveTransformer(fTransformers[i])) {
ret = B_ERROR;
break;
}
}
if (ret < B_OK)
return ret;
for (int32 i = 0; i < fCount; i++) {
if (fTransformers[i]
&& !fContainer->AddTransformer(fTransformers[i], fIndices[i])) {
ret = B_ERROR;
break;
}
}
return ret;
}
void
MoveTransformersCommand::GetName(BString& name)
{
if (fCount > 1)
name << B_TRANSLATE("Move Transformers");
else
name << B_TRANSLATE("Move Transformer");
}