blob: 4eb05f9835609cb29f2434fea70b7b455ab6c0a1 (
plain)
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
|
// **********************************************************************
//
// Copyright (c) 2003-2007 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(String name, DirectoryI parent)
{
_name = name;
_parent = parent;
// Create an identity. The parent has the fixed identity "/"
//
Ice.Identity myID =
_adapter.getCommunicator().stringToIdentity(_parent != null ? Ice.Util.generateUUID() : "RootDir");
// Add the identity to the object adapter
//
_adapter.add(this, myID);
// Create a proxy for the new node and add it as a child to the parent
//
NodePrx thisNode = NodePrxHelper.uncheckedCast(_adapter.createProxy(myID));
if (_parent != null)
_parent.addChild(thisNode);
}
// 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);
}
public static Ice.ObjectAdapter _adapter;
private String _name;
private DirectoryI _parent;
private java.util.ArrayList _contents = new java.util.ArrayList();
}
|