Some work on the getting model back
This commit is contained in:
@@ -19,9 +19,9 @@ class LocalModel(AbstractModel):
|
||||
SERVICE_TYPE = "_olpc_model._tcp"
|
||||
SERVICE_PORT = 6300
|
||||
|
||||
def __init__(self, group, model_id):
|
||||
def __init__(self, pservice, model_id):
|
||||
AbstractModel.__init__(self)
|
||||
self._group = group
|
||||
self._pservice = pservice
|
||||
self._model_id = model_id
|
||||
self._values = {}
|
||||
|
||||
@@ -37,10 +37,11 @@ class LocalModel(AbstractModel):
|
||||
self._notifier.notify(key)
|
||||
|
||||
def _setup_service(self):
|
||||
service = Service(self._model_id, LocalModel.SERVICE_TYPE,
|
||||
LocalModel.SERVICE_PORT)
|
||||
self._service = self._pservice.share_activity(self,
|
||||
stype=LocalModel.SERVICE_TYPE,
|
||||
'', port=LocalModel.PORT_TYPE
|
||||
properties=properties)
|
||||
self._setup_server(service)
|
||||
service.register(self._group)
|
||||
|
||||
# FIXME this is duplicated with StreamReader
|
||||
def _setup_server(self, service):
|
||||
|
||||
@@ -1,22 +0,0 @@
|
||||
from sugar.p2p.model.RemoteModel import RemoteModel
|
||||
from sugar.p2p.model.LocalModel import LocalModel
|
||||
|
||||
class Store:
|
||||
def __init__(self, group):
|
||||
self._group = group
|
||||
self._local_models = {}
|
||||
|
||||
def create_model(self, model_id):
|
||||
model = LocalModel(self._group, model_id)
|
||||
self._local_models[model_id] = model
|
||||
return model
|
||||
|
||||
def get_model(self, model_id):
|
||||
if self._local_models.has_key(model_id):
|
||||
return self._local_models[model_id]
|
||||
else:
|
||||
service = self._group.get_service(model_id, LocalModel.SERVICE_TYPE)
|
||||
if service:
|
||||
return RemoteModel(self._group, service)
|
||||
else:
|
||||
return None
|
||||
Reference in New Issue
Block a user