view src/main/java/alice/topology/node/PrepareToClose.java @ 547:e91a574b69de dispose

remove index
author Nozomi Teruya <e125769@ie.u-ryukyu.ac.jp>
date Tue, 18 Aug 2015 16:15:17 +0900
parents 15eeb439830c
children
line wrap: on
line source

package alice.topology.node;

import java.util.List;

import alice.codesegment.CodeSegment;
import alice.datasegment.CommandType;
import alice.datasegment.DataSegmentManager;
import alice.datasegment.Receiver;

public class PrepareToClose extends CodeSegment {

    private Receiver info = ids.create(CommandType.PEEK);
    private Receiver info1 = ids.create(CommandType.TAKE);

    public PrepareToClose() {
        info.setKey("_CLOSEMESSEAGE", this);
        info1.setKey("_CLIST", this);
    }

    @SuppressWarnings("unchecked")
    @Override
    public void run() {
        String managerKey = info.asString();
        List<String> list = info1.asClass(List.class);
        if (list.contains(managerKey)) {
            list.remove(managerKey);
            DataSegmentManager manager = aliceDaemon.dataSegment.get(managerKey);
            manager.setSendError(false);

            ods.put(managerKey, "_CLOSEREADY", managerKey);
            ods.put("_CLOSEREADY", managerKey);

            new CloseRemoteDataSegment();
        } else {
            // lost node is this node's parent, so already removed
            new ReceiveCloseMessage(CommandType.TAKE);
        }
        ods.put(info1.key, list);

    }

}