本文整理汇总了Python中sugar3.bundle.activitybundle.ActivityBundle.get_command方法的典型用法代码示例。如果您正苦于以下问题:Python ActivityBundle.get_command方法的具体用法?Python ActivityBundle.get_command怎么用?Python ActivityBundle.get_command使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类sugar3.bundle.activitybundle.ActivityBundle
的用法示例。
在下文中一共展示了ActivityBundle.get_command方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: _main
# 需要导入模块: from sugar3.bundle.activitybundle import ActivityBundle [as 别名]
# 或者: from sugar3.bundle.activitybundle.ActivityBundle import get_command [as 别名]
def _main():
"""Launch this activity from the command line."""
ab = ActivityBundle(os.path.dirname(__file__) or '.')
ai = ActivityInfo(name=ab.get_name(),
icon=None,
bundle_id=ab.get_bundle_id(),
version=ab.get_activity_version(),
path=ab.get_path(),
show_launcher=ab.get_show_launcher(),
command=ab.get_command(),
favorite=True,
installation_time=ab.get_installation_time(),
position_x=0, position_y=0)
env = activityfactory.get_environment(ai)
cmd_args = activityfactory.get_command(ai)
os.execvpe(cmd_args[0], cmd_args, env)
示例2: __init__
# 需要导入模块: from sugar3.bundle.activitybundle import ActivityBundle [as 别名]
# 或者: from sugar3.bundle.activitybundle.ActivityBundle import get_command [as 别名]
def __init__(self, window_xid, bundle_path, document_path,
sugar_toolkit_path, title):
Gtk.Window.__init__(self)
_logger.debug('ViewSource paths: %r %r %r', bundle_path,
document_path, sugar_toolkit_path)
self.set_decorated(False)
self.set_position(Gtk.WindowPosition.CENTER_ALWAYS)
self.set_border_width(style.LINE_WIDTH)
self.set_has_resize_grip(False)
width = Gdk.Screen.width() - style.GRID_CELL_SIZE * 2
height = Gdk.Screen.height() - style.GRID_CELL_SIZE * 2
self.set_size_request(width, height)
self._parent_window_xid = window_xid
self._sugar_toolkit_path = sugar_toolkit_path
self.connect('realize', self.__realize_cb)
self.connect('destroy', self.__destroy_cb, document_path)
self.connect('key-press-event', self.__key_press_event_cb)
vbox = Gtk.VBox()
self.add(vbox)
vbox.show()
toolbar = Toolbar(title, bundle_path, document_path,
sugar_toolkit_path)
vbox.pack_start(toolbar, False, True, 0)
toolbar.connect('stop-clicked', self.__stop_clicked_cb)
toolbar.connect('source-selected', self.__source_selected_cb)
toolbar.show()
pane = Gtk.HPaned()
vbox.pack_start(pane, True, True, 0)
pane.show()
self._selected_bundle_file = None
self._selected_sugar_file = None
file_name = ''
activity_bundle = ActivityBundle(bundle_path)
command = activity_bundle.get_command()
if len(command.split(' ')) > 1:
name = command.split(' ')[1].split('.')[-1]
tmppath = command.split(' ')[1].replace('.', '/')
file_name = tmppath[0:-(len(name) + 1)] + '.py'
path = os.path.join(activity_bundle.get_path(), file_name)
self._selected_bundle_file = path
# Split the tree pane into two vertical panes, one of which
# will be hidden
tree_panes = Gtk.VPaned()
tree_panes.show()
self._bundle_source_viewer = FileViewer(bundle_path, file_name)
self._bundle_source_viewer.connect('file-selected',
self.__file_selected_cb)
tree_panes.add1(self._bundle_source_viewer)
self._bundle_source_viewer.show()
file_name = 'env.py'
self._selected_sugar_file = os.path.join(sugar_toolkit_path, file_name)
self._sugar_source_viewer = FileViewer(sugar_toolkit_path, file_name)
self._sugar_source_viewer.connect('file-selected',
self.__file_selected_cb)
tree_panes.add2(self._sugar_source_viewer)
self._sugar_source_viewer.hide()
pane.add1(tree_panes)
self._source_display = SourceDisplay()
pane.add2(self._source_display)
self._source_display.show()
self._source_display.file_path = self._selected_bundle_file
if document_path is not None:
self._select_source(document_path)
示例3: _is_web_activity
# 需要导入模块: from sugar3.bundle.activitybundle import ActivityBundle [as 别名]
# 或者: from sugar3.bundle.activitybundle.ActivityBundle import get_command [as 别名]
def _is_web_activity(bundle_path):
activity_bundle = ActivityBundle(bundle_path)
return activity_bundle.get_command() == 'sugar-activity-web'
示例4: main
# 需要导入模块: from sugar3.bundle.activitybundle import ActivityBundle [as 别名]
# 或者: from sugar3.bundle.activitybundle.ActivityBundle import get_command [as 别名]
def main():
usage = 'usage: %prog [options] [activity dir] [python class]'
epilog = 'If you are running from a directory containing an Activity, ' \
'the argument may be omitted. Otherwise please provide either '\
'a directory containing a Sugar Activity [activity dir], a '\
'[python_class], or both.'
parser = OptionParser(usage=usage, epilog=epilog)
parser.add_option('-b', '--bundle-id', dest='bundle_id',
help='identifier of the activity bundle')
parser.add_option('-a', '--activity-id', dest='activity_id',
help='identifier of the activity instance')
parser.add_option('-o', '--object-id', dest='object_id',
help='identifier of the associated datastore object')
parser.add_option('-u', '--uri', dest='uri',
help='URI to load')
parser.add_option('-s', '--single-process', dest='single_process',
action='store_true',
help='start all the instances in the same process')
parser.add_option('-i', '--invited', dest='invited',
action='store_true', default=False,
help='the activity is being launched for handling an '
'invite from the network')
(options, args) = parser.parse_args()
logger.start()
activity_class = None
if len(args) == 2:
activity_class = args[1]
os.chdir(args[0])
elif len(args) == 1:
if os.path.isdir(args[0]):
os.chdir(args[0])
else:
activity_class = args[0]
bundle_path = os.path.abspath(os.curdir)
sys.path.insert(0, bundle_path)
try:
bundle = ActivityBundle(bundle_path)
except MalformedBundleException:
parser.print_help()
exit(0)
if not activity_class:
command = bundle.get_command()
if command.startswith('sugar-activity'):
if not command.startswith('sugar-activity3'):
logging.warning("Activity written for Python 2, consider porting to Python 3.")
activity_class = command.split(" ")[1]
# when an activity is started outside sugar,
# activityfactory.get_environment has not executed in parent
# process, so parts of get_environment must happen here.
if 'SUGAR_BUNDLE_PATH' not in os.environ:
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')
_makedirs(instance_dir)
data_dir = os.path.join(activity_root, 'data')
_makedirs(data_dir)
tmp_dir = os.path.join(activity_root, 'tmp')
_makedirs(tmp_dir)
os.environ['SUGAR_BUNDLE_PATH'] = bundle_path
os.environ['SUGAR_BUNDLE_ID'] = bundle.get_bundle_id()
os.environ['SUGAR_ACTIVITY_ROOT'] = activity_root
os.environ['SUGAR_BUNDLE_NAME'] = bundle.get_name()
os.environ['SUGAR_BUNDLE_VERSION'] = str(bundle.get_activity_version())
# must be done early, some activities set translations globally, SL #3654
activity_locale_path = os.environ.get("SUGAR_LOCALEDIR",
config.locale_path)
gettext.bindtextdomain(bundle.get_bundle_id(), activity_locale_path)
gettext.bindtextdomain('sugar-toolkit-gtk3', config.locale_path)
gettext.textdomain(bundle.get_bundle_id())
splitted_module = activity_class.rsplit('.', 1)
module_name = splitted_module[0]
class_name = splitted_module[1]
module = __import__(module_name)
for comp in module_name.split('.')[1:]:
module = getattr(module, comp)
activity_constructor = getattr(module, class_name)
if not options.activity_id:
# Generate random hash
data = '%s%s' % (time.time(), random.randint(10000, 100000))
random_hash = hashlib.sha1(data.encode()).hexdigest()
#.........这里部分代码省略.........