// Copyright (c) 2008, Rodrigo Braz Monteiro // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // // * Redistributions of source code must retain the above copyright notice, // this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above copyright notice, // this list of conditions and the following disclaimer in the documentation // and/or other materials provided with the distribution. // * Neither the name of the Aegisub Group nor the names of its contributors // may be used to endorse or promote products derived from this software // without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE // POSSIBILITY OF SUCH DAMAGE. // // ----------------------------------------------------------------------------- // // AEGISUB/ATHENASUB // // Website: http://www.aegisub.net // Contact: mailto:amz@aegisub.net // #include "actionlist.h" #include "model.h" using namespace Athenasub; /////////////// // Constructor CActionList::CActionList(weak_ptr _model,String _actionName,const String _owner,bool _undoAble) : model(dynamic_pointer_cast(Model(_model))), owner(_owner), undoAble(_undoAble) { valid = false; Start(_actionName); } ////////////// // Destructor CActionList::~CActionList() { } ////////////////////////////// // Add an action to the queue void CActionList::AddAction(Action action) { if (!valid) THROW_ATHENA_EXCEPTION(Exception::Invalid_ActionList); actions.push_back(action); if (actions.size() > 2) { int a = 0; a++; } } /////////////////////////////////////////// // Add an action to the start of the queue void CActionList::AddActionStart(const Action action) { if (!valid) THROW_ATHENA_EXCEPTION(Exception::Invalid_ActionList); actions.push_front(action); if (actions.size() > 2) { int a = 0; a++; } } ///////////////////////////// // Starts performing actions void CActionList::Start(const String name) { if (valid) Finish(); actionName = name; valid = true; } //////////////////////// // Ends the action list void CActionList::Finish() { if (valid) { shared_ptr(model)->ProcessActionList(*this); actions.clear(); valid = false; } } ////////////////////////////////// // Create an "insert line" action void CActionList::InsertLine(Entry line,int position,const String section) { Action action = Action (new ActionInsert(model.lock(),line,position,section)); AddAction(action); } ///////////////////////////////// // Create a "remove line" action void CActionList::RemoveLine(int position,const String section) { Action action = Action (new ActionRemove(model.lock(),position,section)); AddAction(action); } ///////////////////////////////// // Insert a "modify line" action Entry CActionList::ModifyLine(int position,const String section) { Section sect = shared_ptr(model)->GetMutableSection(section); Entry entry = sect->GetEntry(position)->Clone(); Action action = Action (new ActionModify(model.lock(),entry,position,section,false)); AddAction(action); return entry; } //////////////////////////////////////// // Insert a "modify lines" batch action std::vector CActionList::ModifyLines(Selection selection,const String section) { // Get section Section sect = shared_ptr(model)->GetMutableSection(section); // Generate entries std::vector entries(selection->GetCount()); size_t len = selection->GetRanges(); size_t n = 0; for (size_t i=0;iGetLinesInRange(i); for (size_t j=0;jGetEntryRef(selection->GetLineInRange(j,i))->Clone(); } } // Generate the action AddAction(Action(new ActionModifyBatch(model.lock(),entries,std::vector(),selection,section,false))); return entries; }