On 02/19/2012 10:40 PM, Xiaofeng Yan wrote:
On 2012年02月18日 07:52, Saul Wold wrote:

Xiaofeng & Community:

We had a chat with Chris Larson and Mark Hatle here at ELC.

We focused this issue down to a fewer number of options that meet the
needs of the licenses. Please review this and let us know if there are
any issues or concerns.


Hi Saul,

I comment my understanding as follow:
Best Practices:
- Archive during build, we do not support nor recommend post archiving
- Original tarball and patches w/ordering file (maybe comment the
series), grab non-patch files also.
for example:
file://a.patch
file://b.config.in
we also archive b.config.in.

Yes, correct.

- Unless requesting configured sources, which will just be the
configured source tarball
- Grab temp as postfunc of do_package - latest logs via links & pid

That means logs package include all of logs in temp. for example.
You has described a following function we will realize at the previous
email.
3 - Original Source code & Patches & temp (scripts & logs)

source codes and patches should be in the stage do_patch[postfunc] = "
do_get_source"
logs should be in the stage do_package[postfunc] = " do_get_logs"
So logs file shouldn't be archived in do_patch[postfunc] = " do_get_logs"
The logs in the stage of do_packge are more than do_patch.

Correct, you want to get the logs and scripts from temp when they are most complete (after do_package not after do_patch).

As mentioned below, you would use the variable SOURCE_ARCHIVE_LOG in the do_package[postfunc] to determine if you need to archive the logs or not.


For sstate Builds (LATER):
- need to verify that fetch/patch/configure will get re-run for archiving
- Add temp dir to sstate capture (without links)

3 Implementations classes
- Filter in oe/lib/license.py
- source_archive.bb
- archives tarballs to ${BP}/...
- reuse copyleft_compliance for patch handling
- srpm
- take output from above and create SRPM - (LATER)

We will do the archive work according the license . I will implement two
functions, one is for left, the other for right.
I am not sure what you mean by one is for left and the other is for right?

Can you explain your thoughts here.


2 Configuration classes
- uses prefunc/postfunc at correct place
- Original Tarball / Patches
- Post Configuration

We can define 8 classes to complete 8 kinds of archiving methods. every
class will inherit archiver.bbclass.

I am not sure we need 8 classes anymore, that was the point of this email to simplify the needs.

2 Classes:

source_patches.bbclass
 - Original Tarball & Patches & Other files
 - do_patch[postfunc] = <archive ${S}/patches with Original tarball>
 - Included temp dir if enabled via SOURCE_ARCHIVE_LOG

configured_source.bbclass
 - Get the ${S} dir (or $S & any build dir) after do_configure
 - do_configure[postfunc] = <archive configured source>
 - Include temp dir if enabled via SOURCE_ARCHIVE_LOG


and then realize do_stage[prefunc/postfunc] in this class.
stage include unpack, patch, configure, build package and so on.
for example. we want only to get original tarball, then we can define a
bbclass named "source.bbclass"
source.bbclass:
inherit archiver.bbclass
do_unpack[postfunc] = " do_get_source"

if we want to get both original and patches tarball, then we can define
bbclass names "source_patches.bbclass"
source_patches.bbclass
inherit archiver.bbclass
do_unpack[postfunc] = " do_get_source_patches"

SOURCE_ARCHIVE_PACKAGE_TYPE = {tar, srpm}
SOURCE_ARCHIVE_LOG = {True, False}

Please let us know if you have any questions.

Sau!

If my understanding don't meet your ideas, Please correct me.

I should be available via IRC in your afternoon, I will be away during your morning.

Sau!

Thanks for your help very much.

Thanks
Yan
On 02/15/2012 05:19 PM, Xiaofeng Yan wrote:



_______________________________________________
Openembedded-core mailing list
[email protected]
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/openembedded-core

Reply via email to