1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
// **********************************************************************
//
// Copyright (c) 2003-2009 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************
package Filesystem;
public final class DirectoryI extends _DirectoryDisp
{
// DirectoryI constructor
public
DirectoryI(Ice.Communicator communicator, String name, DirectoryI parent)
{
_name = name;
_parent = parent;
// Create an identity. The root directory has the fixed identity "RootDir"
//
_id = new Ice.Identity();
_id.name = _parent != null ? Ice.Util.generateUUID() : "RootDir";
}
// Slice Node::name() operation
public String
name(Ice.Current current)
{
return _name;
}
// Slice Directory::list() operation
public NodePrx[]
list(Ice.Current current)
{
NodePrx[] result = new NodePrx[_contents.size()];
_contents.toArray(result);
return result;
}
// addChild is called by the child in order to add
// itself to the _contents member of the parent
void
addChild(NodePrx child)
{
_contents.add(child);
}
// activate adds the servant to the object adapter and
// adds child nodes ot the parent's _contents list.
public void
activate(Ice.ObjectAdapter a)
{
NodePrx thisNode = NodePrxHelper.uncheckedCast(a.add(this, _id));
if(_parent != null)
{
_parent.addChild(thisNode);
}
}
private String _name;
private DirectoryI _parent;
private Ice.Identity _id;
private java.util.List<NodePrx> _contents = new java.util.ArrayList<NodePrx>();
}
|