##// END OF EJS Templates
client profile defaults to running IPython profile...
MinRK -
Show More
@@ -28,6 +28,9 b' pjoin = os.path.join'
28 import zmq
28 import zmq
29 # from zmq.eventloop import ioloop, zmqstream
29 # from zmq.eventloop import ioloop, zmqstream
30
30
31 from IPython.config.configurable import MultipleInstanceError
32 from IPython.core.application import BaseIPythonApplication
33
31 from IPython.utils.jsonutil import rekey
34 from IPython.utils.jsonutil import rekey
32 from IPython.utils.path import get_ipython_dir
35 from IPython.utils.path import get_ipython_dir
33 from IPython.utils.traitlets import (HasTraits, Int, Instance, Unicode,
36 from IPython.utils.traitlets import (HasTraits, Int, Instance, Unicode,
@@ -117,13 +120,14 b' class Client(HasTraits):'
117 Parameters
120 Parameters
118 ----------
121 ----------
119
122
120 url_or_file : bytes; zmq url or path to ipcontroller-client.json
123 url_or_file : bytes or unicode; zmq url or path to ipcontroller-client.json
121 Connection information for the Hub's registration. If a json connector
124 Connection information for the Hub's registration. If a json connector
122 file is given, then likely no further configuration is necessary.
125 file is given, then likely no further configuration is necessary.
123 [Default: use profile]
126 [Default: use profile]
124 profile : bytes
127 profile : bytes
125 The name of the Cluster profile to be used to find connector information.
128 The name of the Cluster profile to be used to find connector information.
126 [Default: 'default']
129 If run from an IPython application, the default profile will be the same
130 as the running application, otherwise it will be 'default'.
127 context : zmq.Context
131 context : zmq.Context
128 Pass an existing zmq.Context instance, otherwise the client will create its own.
132 Pass an existing zmq.Context instance, otherwise the client will create its own.
129 debug : bool
133 debug : bool
@@ -237,7 +241,20 b' class Client(HasTraits):'
237 metadata = Instance('collections.defaultdict', (Metadata,))
241 metadata = Instance('collections.defaultdict', (Metadata,))
238 history = List()
242 history = List()
239 debug = Bool(False)
243 debug = Bool(False)
240 profile=Unicode('default')
244
245 profile=Unicode()
246 def _profile_default(self):
247 if BaseIPythonApplication.initialized():
248 # an IPython app *might* be running, try to get its profile
249 try:
250 return BaseIPythonApplication.instance().profile
251 except (AttributeError, MultipleInstanceError):
252 # could be a *different* subclass of config.Application,
253 # which would raise one of these two errors.
254 return u'default'
255 else:
256 return u'default'
257
241
258
242 _outstanding_dict = Instance('collections.defaultdict', (set,))
259 _outstanding_dict = Instance('collections.defaultdict', (set,))
243 _ids = List()
260 _ids = List()
@@ -258,18 +275,24 b' class Client(HasTraits):'
258 _ignored_control_replies=Int(0)
275 _ignored_control_replies=Int(0)
259 _ignored_hub_replies=Int(0)
276 _ignored_hub_replies=Int(0)
260
277
261 def __init__(self, url_or_file=None, profile='default', profile_dir=None, ipython_dir=None,
278 def __new__(self, *args, **kw):
279 # don't raise on positional args
280 return HasTraits.__new__(self, **kw)
281
282 def __init__(self, url_or_file=None, profile=None, profile_dir=None, ipython_dir=None,
262 context=None, debug=False, exec_key=None,
283 context=None, debug=False, exec_key=None,
263 sshserver=None, sshkey=None, password=None, paramiko=None,
284 sshserver=None, sshkey=None, password=None, paramiko=None,
264 timeout=10, **extra_args
285 timeout=10, **extra_args
265 ):
286 ):
287 if profile:
266 super(Client, self).__init__(debug=debug, profile=profile)
288 super(Client, self).__init__(debug=debug, profile=profile)
289 else:
290 super(Client, self).__init__(debug=debug)
267 if context is None:
291 if context is None:
268 context = zmq.Context.instance()
292 context = zmq.Context.instance()
269 self._context = context
293 self._context = context
270
294
271
295 self._setup_profile_dir(self.profile, profile_dir, ipython_dir)
272 self._setup_profile_dir(profile, profile_dir, ipython_dir)
273 if self._cd is not None:
296 if self._cd is not None:
274 if url_or_file is None:
297 if url_or_file is None:
275 url_or_file = pjoin(self._cd.security_dir, 'ipcontroller-client.json')
298 url_or_file = pjoin(self._cd.security_dir, 'ipcontroller-client.json')
General Comments 0
You need to be logged in to leave comments. Login now