[sugar] Re: [PATCH] Bundle API now provides write functionality.

Andrew Clunis orospakr at linux.ca
Fri Mar 2 13:36:05 EST 2007


-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

Marco Pesenti Gritti wrote:
> On Wed, 2007-02-28 at 23:23 -0500, Andrew Clunis wrote:
>> * now provides property setters and write_info() method, which will write
>>   the activity metadata back to activity.info.
>> * now supports the comment and host_version fields.
>> * various cleanups.
>> ---
>>  sugar/activity/bundle.py |  128 ++++++++++++++++++++++++++++++++++++++--------
>>  1 files changed, 105 insertions(+), 23 deletions(-)
>>
>> diff --git a/sugar/activity/bundle.py b/sugar/activity/bundle.py
>> index 6a6ebdd..482b105 100644
>> --- a/sugar/activity/bundle.py
>> +++ b/sugar/activity/bundle.py
>> @@ -8,18 +8,25 @@ _PYTHON_FACTORY='sugar-activity-factory'
>>  
>>  class Bundle:
>>      """Info about an activity bundle. Wraps the activity.info file."""
>> +    
>> +    section = 'Activity'
>> +    
> 
> Please move this up to the module and call it _SECTION.

Cool, I was wondering about that.

> 
>> +        if cp.has_option(self.section, 'host_version'):
>> +            self._host_version = int(cp.get(self.section,
>> 'host_version'))
> 
> This is actually a required field. Though I'm not quite sure the spec
> about this is finalized so it's not worth breaking activities. Just put
> a "FIXME this should be a required field" or something.

Should I take the logic out? it seems OK as is. at least, it doesn't
hurt anything.

> 
>>      def get_icon(self):
>> +        """Get the activity icon file name"""
>> +        activity_path = os.path.join(self._path, 'activity')
>> +        icon = os.path.join(activity_path, self._icon_name + ".svg")
>> +        return icon
>> +    
> 
> Use get_icon_path and """Get the activity icon path"""

Actually, I'd rather not do that, because that breaks the API.

I just moved the logic for get_icon() into the getter, rather than
setting _icon in the constructor.  I did all this to make it cleaner to
store the original value from the .info file in the object, so it could
be saved back to the .info without any path + name + ".svg" munging.

> 
>> +    def get_icon_name(self):
>>          """Get the activity icon name"""
>> -        return self._icon
>> +        return self._icon_name
>> +    
>> +    def set_icon_name(self, icon_name):
>> +        """Set the activity icon name"""
>> +        self._icon_name = icon_name
>>  
>>      def get_activity_version(self):
>>          """Get the activity version"""
>>          return self._activity_version
>> +    
>> +    def set_activity_version(self, activity_version):
>> +        """Set the activity version"""
>> +        self._activity_version = activity_version
>> +        
>> +    def get_host_version(self):
>> +        """Get the host version required for this activity"""
>> +        return self._host_version
>> +    
>> +    def set_host_version(self, host_version):
>> +        """Set the host version required for this activity"""
>> +        self._host_version = host_version
>>  
>>      def get_exec(self):
>>          """Get the command to execute to launch the activity factory"""
>>          return self._exec
>> +    
>> +    def set_exec(self, exec_name):
>> +        """Set the command to execute to launch the activity factory"""
>> +        self._exec = exec_name
>>  
>>      def get_class(self):
>>          """Get the main Activity class"""
>> -        return self._exec
>> +        return self._class
>> +    
>> +    def set_class(self, klass):
>> +        """Set the main Activity class"""
>> +        self._class = klass
>>  
>>      def get_show_launcher(self):
>>          """Get whether there should be a visible launcher for the activity"""
>>          return self._show_launcher
>> +    
>> +    def set_show_launcher(self, show_launcher):
>> +        self._show_launcher = show_launcher
>> +
>> +    def write_info(self):
>> +        """Write changed configuration parameters back to the activity.info
>> +        file"""
>> +        cp = ConfigParser()
>> +        info_fd = open(self._info_path, "wb")
>> +        cp.add_section(self.section)
>> +        cp.set(self.section, "name", self._name)
>> +        cp.set(self.section, "icon", self._icon_name)
>> +        cp.set(self.section, "service_name"er, self._service_name)
>> +        if self._comment is not None:
>> +            cp.set(self.section, "comment", self._comment)
> 
> There is no "comment" in the spec.

Yeah, must be a hangover from an original howto. Develop's .info had a
comment field, so I figured it was used for something.

> 
> http://wiki.laptop.org/go/Activity_Bundles
> 
> What's the use case?

Develop activity needs to write bundles.  Now, it could have had its own
logic for this, but it seems better to keep that code together, which
seems much more maintainable/reusable.

> 
> Marco
> 
- --
Regards,
Andrew Clunis

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.3 (GNU/Linux)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org

iD8DBQFF6G6VALkUMXSNow8RAtFZAKDCC/sbA6VI0xSliNpX/e+08fWF1ACffJ3j
/WdsfoKZDdWfu4GvwcDBxG8=
=/4qX
-----END PGP SIGNATURE-----


More information about the Sugar mailing list