Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 3 Current »

package MementoPattern;
//This is our Memento
public class EditorState {
    private final String content;

    public EditorState(String content) {
        this.content = content;
    }

    public String getContent() {
        return content;
    }
}

The EditorState class serves as the Memento and is responsible for storing the state of an editor. Let's break down the code:

The code snippet above demonstrates the following:

  • The class is declared within the MementoPattern package.

  • The EditorState class has a single attribute, content, which represents the state of the editor. The attribute is marked as final, indicating that it cannot be changed after initialization.

  • The constructor EditorState(String content) is used to create an instance of the EditorState class. It takes the content parameter, which represents the state to be stored in the Memento.

  • The getContent() method is a getter method that returns the stored content/state.

The purpose of this EditorState class is to encapsulate and store the state of an editor at a specific point in time. It follows the Memento pattern by providing a way to capture and retrieve the state of an object without exposing its internal details. This allows the editor object to save and restore its state using instances of the EditorState class, which can be managed by a caretaker object (not shown in the provided code).

package MementoPattern;
//This is out Originator
public class Editor {
    private String content;

    public EditorState createState() {
        return new EditorState(content);
    }

    public void restore(EditorState state) {
        content = state.getContent();
    }

    public String getContent() {
        return content;
    }

    public void setContent(String content) {
        this.content = content;
    }
}

The provided code represents an Originator class in the context of the Memento design pattern.

Let's break down the code:

The code snippet above demonstrates the following:

  • The class is declared within the MementoPattern package.

  • The Editor class serves as the Originator, which is the object whose state needs to be saved and restored.

  • The Editor class has an attribute content, which represents the current state of the editor.

  • The createState() method creates an EditorState object that encapsulates the current state of the editor. It returns an instance of the EditorState class, passing the current content as a parameter.

  • The restore(EditorState state) method takes an EditorState object and restores the state of the editor to the state captured in the EditorState object. It retrieves the content/state from the EditorState object and assigns it to the content attribute of the Editor class.

  • The getContent() method is a getter method that returns the current content/state of the editor.

  • The setContent(String content) method is a setter method that allows updating the content/state of the editor.

The purpose of this Editor class is to serve as the Originator, which is responsible for creating Memento objects (EditorState) that capture the state of the editor, as well as restoring the state of the editor from a given Memento. It encapsulates the state within the content attribute and provides methods to create and restore Memento objects.

package MementoPattern;
import java.util.ArrayList;
import java.util.List;
//This is out Caretaker
public class History {
    //We could actually use a stack here - but I have chosen to use a LIST
    private List<EditorState> states = new ArrayList<>();

    public void push(EditorState state) {
        states.add(state);
    }

    public EditorState pop() {
        var lastIndex = states.size() - 1;
        var lastState = states.get(lastIndex);
        states.remove(lastState);

        return lastState;
    }
}

The provided code represents a Caretaker class in the context of the Memento design pattern.

Let's break down the code:

The code snippet above demonstrates the following:

  • The class is declared within the MementoPattern package.

  • The History class serves as the Caretaker, responsible for storing and managing the Memento objects (EditorState).

  • The History class maintains a list, states, which stores instances of EditorState.

  • The push(EditorState state) method is used to add a new EditorState object to the list of states. It takes an EditorState parameter and adds it to the states list.

  • The pop() method retrieves the most recent EditorState object from the list, removes it from the list, and returns it. The last state in the states list is obtained using the index lastIndex. The lastState is then removed from the list using states.remove(lastState), and finally, lastState is returned.

The purpose of this History class is to serve as the Caretaker, responsible for managing the Memento objects (EditorState). It provides methods to add new states (push) and retrieve the most recent state (pop). The states list acts as a storage for Memento objects, allowing the Originator (Editor) to save and restore its state.

Note: The implementation in the History class uses a simple List to store the states. Although a stack data structure is typically used for the Caretaker in the Memento pattern, the code snippet opts for an ArrayList. However, it is important to note that using a List does not affect the essence of the Memento pattern's concept and functionality.

Driver:

package MementoPattern;

public class MementoDriver {
    public static void main(String[] args){
        var editor = new Editor();
        var history = new History();

        editor.setContent("Hello");
        history.push(editor.createState());

        editor.setContent("World!");
        history.push(editor.createState());

        editor.setContent("Welcome to OOP Design");
        history.push(editor.createState());

        editor.restore(history.pop());
        System.out.println(editor.getContent());
        editor.restore(history.pop());
        System.out.println(editor.getContent());
        editor.restore(history.pop());
        System.out.println(editor.getContent());
    }
}

The provided code demonstrates the usage of the Memento design pattern in a simple scenario. Let's break it down:

The code snippet above demonstrates the following:

  • The MementoDriver class serves as the entry point for the program.

  • The Editor and History classes are instantiated to create an editor and manage its state history.

  • The Editor instance, editor, is initially created.

  • The setContent(String content) method of the Editor is used to set the content/state of the editor to "Hello".

  • The createState() method of the Editor is called to create an EditorState object representing the current state of the editor. This EditorState is then added to the History using history.push().

  • Similar steps are repeated to set and save two more states for the editor: "World!" and "Welcome to OOP Design".

  • The restore(EditorState state) method of the Editor is used to restore the state of the editor to the most recently saved state in the History. This is done by popping the last saved state from the History using history.pop().

  • The content of the editor after each restoration is printed using System.out.println(editor.getContent()).

Overall, this code demonstrates the use of the Memento pattern to save and restore the state of an editor using the Editor and History classes. It shows how the editor's content/state can be changed, saved, and restored from the history using the Memento design pattern's principles and components.

  • No labels