/*
* Copyright 2015-present Facebook, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
package com.facebook.buck.intellij.ideabuck.ui.tree;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.List;
import javax.swing.tree.TreeNode;
public class BuckTreeNodeTarget implements TreeNode {
private String mTarget;
private List<BuckTreeNodeFileError> mFileError;
private BuckTreeNodeBuild mParent;
public BuckTreeNodeTarget(BuckTreeNodeBuild build, String target) {
mTarget = target;
mParent = build;
mFileError = new ArrayList<BuckTreeNodeFileError>();
}
public void addFileError(BuckTreeNodeFileError error) {
mFileError.add(error);
}
@Override
public TreeNode getChildAt(int childIndex) {
return mFileError.get(childIndex);
}
@Override
public int getChildCount() {
return mFileError.size();
}
@Override
public TreeNode getParent() {
return mParent;
}
@Override
public int getIndex(TreeNode node) {
return 0;
}
@Override
public boolean getAllowsChildren() {
return true;
}
@Override
public boolean isLeaf() {
return false;
}
@Override
public Enumeration children() {
return new Enumeration<TreeNode>() {
private int currentIndex = 0;
@Override
public boolean hasMoreElements() {
if (currentIndex >= BuckTreeNodeTarget.this.mFileError.size()) {
return false;
}
return true;
}
@Override
public TreeNode nextElement() {
return BuckTreeNodeTarget.this.mFileError.get(++currentIndex);
}
};
}
public String getTarget() {
return mTarget;
}
}