view src/main/java/jp/ac/u_ryukyu/ie/cr/jungle/data/list/headNode.java @ 211:74648c746dd4

List fix
author tatsuki
date Tue, 04 Aug 2015 07:54:30 +0900
parents 9166735b34c9
children 7da9056e9357
line wrap: on
line source

package jp.ac.u_ryukyu.ie.cr.jungle.data.list;

/**
 * Created by e115731 on 15/05/18.
 */
public class headNode<T> implements Node<T> {
    private final Node next;


    public headNode() {
        this.next = new TailNode<T>();
    }

    public headNode(Node next) {
        this.next = next;
    }

    public int getNum() {
        return -1;
    }

    public Node getNext() {
        return next;
    }

    public T getAttribute() {
        return null;
    }

    public Node<T> add(int currentNum, int num, T attribute) {
        if (num == 0) {
            Node<T> newNode = new DefaultNode<>(attribute, next);
            return new headNode<T>(newNode);
        }
        Node<T> newNode = next.add(currentNum + 1, num, attribute);
        if (newNode == null)
            return this;
        return new headNode(newNode);
    }

    public Node<T> addLast(T attribute) {
        Node<T> node = next.addLast(attribute);
        return new headNode<T>(node);
    }

    public Node<T> delete(int currentNum, int deleteNum) {
        if (currentNum == deleteNum) {
            return new headNode(this.next.getNext());
        }

        Node<T> newNode = next.delete(currentNum + 1, deleteNum);
        if (newNode == null)
            return this;
        return new headNode(newNode);
    }

    @Override
    public Node<T> replaceNode(int currentNum, int num, T attribute) {
        Node<T> nextNode = getNext();
        Node<T> newNode = nextNode.replaceNode(currentNum, num, attribute);
        if (newNode == null)
            return this;
        return new headNode(newNode);
    }

    @Override
    public int length() {
        return next.length();
    }
}