The Battle for Wesnoth  1.13.4+dev
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Public Member Functions | Protected Attributes | List of all members
editor::editor_action_paste Class Reference

Paste a map fragment into the map. More...

#include <action.hpp>

Inheritance diagram for editor::editor_action_paste:
Inheritance graph

Public Member Functions

 editor_action_paste (const map_fragment &paste, const map_location &offset=map_location::ZERO())
 
editor_action_pasteclone () const
 Action cloning. More...
 
editor_action_pasteperform (map_context &mc) const
 Perform the action, returning an undo action that, when performed, shall reverse any effects of this action. More...
 
void perform_without_undo (map_context &mc) const
 Perform the action without creating an undo action. More...
 
void extend (const editor_map &map, const std::set< map_location > &locs)
 The crux of the extendable contract. More...
 
const char * get_name () const
 
- Public Member Functions inherited from editor::editor_action_extendable
 editor_action_extendable ()
 
- Public Member Functions inherited from editor::editor_action
 editor_action ()
 
virtual ~editor_action ()
 
virtual int action_count () const
 
virtual std::string get_description () const
 A textual description of the action. More...
 
int get_id () const
 Debugging aid. More...
 

Protected Attributes

map_location offset_
 
map_fragment paste_
 

Additional Inherited Members

- Static Public Member Functions inherited from editor::editor_action
static int get_instance_count ()
 Debugging aid. More...
 

Detailed Description

Paste a map fragment into the map.

No offset is used.

Definition at line 224 of file action.hpp.

Constructor & Destructor Documentation

editor::editor_action_paste::editor_action_paste ( const map_fragment paste,
const map_location offset = map_location::ZERO() 
)
inline

Definition at line 227 of file action.hpp.

Referenced by clone(), and perform().

Member Function Documentation

editor_action_paste * editor::editor_action_paste::clone ( ) const
virtual

Action cloning.

Implements editor::editor_action.

Definition at line 158 of file action.cpp.

References editor_action_paste().

void editor::editor_action_paste::extend ( const editor_map map,
const std::set< map_location > &  locs 
)
virtual

The crux of the extendable contract.

This member function must be implemented so that the undo behavior is consistent, exactly the same as would be with separate undo actions for every part of the drag.

Implements editor::editor_action_extendable.

Definition at line 162 of file action.cpp.

References editor::map_fragment::add_tiles(), and paste_.

const char* editor::editor_action_paste::get_name ( ) const
inlinevirtual
Returns
a short name of this action type, defaults to unknown

Reimplemented from editor::editor_action_extendable.

Definition at line 235 of file action.hpp.

editor_action_paste * editor::editor_action_paste::perform ( map_context mc) const
virtual

Perform the action, returning an undo action that, when performed, shall reverse any effects of this action.

The undo action object is owned by the caller. Default behavior is to create a whole-map undo, call the perform_without_undo function and return the undo object.

Reimplemented from editor::editor_action.

Definition at line 166 of file action.cpp.

References editor_action_paste(), editor::map_context::get_map(), editor::map_fragment::get_offset_area(), offset_, paste_, and perform_without_undo().

void editor::editor_action_paste::perform_without_undo ( map_context ) const
virtual

Member Data Documentation

map_location editor::editor_action_paste::offset_
protected

Definition at line 237 of file action.hpp.

Referenced by perform(), and perform_without_undo().

map_fragment editor::editor_action_paste::paste_
protected

Definition at line 238 of file action.hpp.

Referenced by extend(), perform(), and perform_without_undo().


The documentation for this class was generated from the following files: