blob: bdd9d048bf565b2f62bf3a404f16a6600b0d8483 (
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
70
71
72
73
74
75
76
77
|
// **********************************************************************
//
// Copyright (c) 2003-2015 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.
//
// **********************************************************************
using System;
using System.Collections.Generic;
namespace IceBox
{
public class Server
{
public class App : Ice.Application
{
private static void usage()
{
Console.Error.WriteLine("Usage: iceboxnet [options] --Ice.Config=<file>\n");
Console.Error.WriteLine(
"Options:\n" +
"-h, --help Show this message.\n"
);
}
public override int run(string[] args)
{
List<String> argSeq = new List<String>(args);
const String prefix = "IceBox.Service.";
Ice.Properties properties = communicator().getProperties();
Dictionary<string, string> services = properties.getPropertiesForPrefix(prefix);
foreach(KeyValuePair<string, string> pair in services)
{
String name = pair.Key.Substring(prefix.Length);
for(int i = 0; i < argSeq.Count; ++i)
{
if(argSeq[i].StartsWith("--" + name, StringComparison.CurrentCulture))
{
argSeq.RemoveAt(i);
i--;
}
}
}
foreach(String s in argSeq)
{
if(s.Equals("-h") || s.Equals("--help"))
{
usage();
return 0;
}
else
{
Console.Error.WriteLine("Server: unknown option `" + s + "'");
usage();
return 1;
}
}
ServiceManagerI serviceManagerImpl = new ServiceManagerI(communicator(), args);
return serviceManagerImpl.run();
}
}
public static int Main(string[] args)
{
Ice.InitializationData initData = new Ice.InitializationData();
initData.properties = Ice.Util.createProperties();
initData.properties.setProperty("Ice.Admin.DelayCreation", "1");
App server = new App();
return server.main(args, initData);
}
}
}
|