Merge pull request #317 from icarito/master
Fix regression for GTK2 activities caused by 2f2b2d2
This commit is contained in:
commit
632fff1278
@ -35,11 +35,15 @@ DBusGMainLoop(set_as_default=True)
|
|||||||
from sugar3.activity import activityhandle
|
from sugar3.activity import activityhandle
|
||||||
from sugar3 import config
|
from sugar3 import config
|
||||||
from sugar3.bundle.activitybundle import ActivityBundle
|
from sugar3.bundle.activitybundle import ActivityBundle
|
||||||
from sugar3.activity.activityfactory import get_environment
|
|
||||||
from sugar3 import logger
|
from sugar3 import logger
|
||||||
|
|
||||||
from sugar3.bundle.bundle import MalformedBundleException
|
from sugar3.bundle.bundle import MalformedBundleException
|
||||||
|
|
||||||
|
from distutils.dir_util import mkpath
|
||||||
|
import time
|
||||||
|
import hashlib
|
||||||
|
import random
|
||||||
|
|
||||||
def create_activity_instance(constructor, handle):
|
def create_activity_instance(constructor, handle):
|
||||||
activity = constructor(handle)
|
activity = constructor(handle)
|
||||||
activity.show()
|
activity.show()
|
||||||
@ -124,7 +128,22 @@ def main():
|
|||||||
activity_class = bundle.get_command().split(" ")[1]
|
activity_class = bundle.get_command().split(" ")[1]
|
||||||
|
|
||||||
if 'SUGAR_VERSION' not in os.environ:
|
if 'SUGAR_VERSION' not in os.environ:
|
||||||
environ = get_environment(bundle)
|
profile_id = os.environ.get('SUGAR_PROFILE', 'default')
|
||||||
|
home_dir = os.environ.get('SUGAR_HOME', os.path.expanduser('~/.sugar'))
|
||||||
|
base = os.path.join(home_dir, profile_id)
|
||||||
|
activity_root = os.path.join(base, bundle.get_bundle_id())
|
||||||
|
|
||||||
|
instance_dir = os.path.join(activity_root, 'instance')
|
||||||
|
mkpath(instance_dir)
|
||||||
|
|
||||||
|
data_dir = os.path.join(activity_root, 'data')
|
||||||
|
mkpath(data_dir)
|
||||||
|
|
||||||
|
tmp_dir = os.path.join(activity_root, 'tmp')
|
||||||
|
mkpath(tmp_dir)
|
||||||
|
|
||||||
|
os.environ['SUGAR_ACTIVITY_ROOT'] = activity_root
|
||||||
|
os.environ['SUGAR_BUNDLE_PATH'] = bundle.get_path()
|
||||||
|
|
||||||
os.environ['SUGAR_BUNDLE_ID'] = bundle.get_bundle_id()
|
os.environ['SUGAR_BUNDLE_ID'] = bundle.get_bundle_id()
|
||||||
os.environ['SUGAR_BUNDLE_NAME'] = bundle.get_name()
|
os.environ['SUGAR_BUNDLE_NAME'] = bundle.get_name()
|
||||||
@ -149,7 +168,10 @@ def main():
|
|||||||
activity_constructor = getattr(module, class_name)
|
activity_constructor = getattr(module, class_name)
|
||||||
|
|
||||||
if not options.activity_id:
|
if not options.activity_id:
|
||||||
options.activity_id = bundle.get_name()
|
# Generate random hash
|
||||||
|
data = '%s%s' % (time.time(), random.randint(10000, 100000))
|
||||||
|
random_hash = hashlib.sha1(data).hexdigest()
|
||||||
|
options.activity_id = random_hash
|
||||||
options.bundle_id = bundle.get_bundle_id()
|
options.bundle_id = bundle.get_bundle_id()
|
||||||
|
|
||||||
activity_handle = activityhandle.ActivityHandle(
|
activity_handle = activityhandle.ActivityHandle(
|
||||||
|
Loading…
Reference in New Issue
Block a user