This repository has been archived by the owner on Jan 28, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.py
executable file
·71 lines (63 loc) · 1.91 KB
/
main.py
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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# ***** BEGIN GPL LICENSE BLOCK *****
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software Foundation,
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# The Original Code is Copyright (C) 2010 by Sergey Sharybin
# All rights reserved.
#
# The Original Code is: all of this file.
#
# Contributor(s): none yet.
#
# ***** END GPL LICENSE BLOCK *****
#
import os
import sys
from optparse import OptionParser
# Append libs to search path
abs_file = os.path.abspath(__file__)
cwd = os.path.dirname(abs_file)
sys.path.append(cwd + os.path.sep + 'lib')
import Logger
import Version
from config import Config
# Some default values
role = Config.role
# Parse command line
op = OptionParser()
op.add_option('--role', default=None)
(opts, args) = op.parse_args()
if opts.role is not None:
if opts.role not in ['master', 'slave']:
raise Exception('Invalid role specified: {0} ' +
'(expected [master|slave])' . format(role))
else:
role = opts.role
# Banner
Logger.log('=' * 23, False)
Logger.log(' bfarm version {0} ' . format(Version.bfarm_version), False)
Logger.log('=' * 23, False)
Logger.log('', False)
if role == 'master':
from master import Master
master = Master()
master.run()
else:
from slave import Slave
slave = Slave()
slave.run()