diff options
| -rw-r--r-- | meta/classes/archive-configured-source.bbclass | 49 | ||||
| -rw-r--r-- | meta/classes/archive-original-source.bbclass | 49 | ||||
| -rw-r--r-- | meta/classes/archive-patched-source.bbclass | 49 | ||||
| -rw-r--r-- | meta/classes/archiver.bbclass | 40 | 
4 files changed, 167 insertions, 20 deletions
| diff --git a/meta/classes/archive-configured-source.bbclass b/meta/classes/archive-configured-source.bbclass index 1eaaf4cf25..e492ce300d 100644 --- a/meta/classes/archive-configured-source.bbclass +++ b/meta/classes/archive-configured-source.bbclass @@ -8,10 +8,53 @@  inherit archiver  # Get archiving package with configured sources including patches -do_configure[postfuncs] += "do_archive_configured_sources " +addtask do_archive_configured_sources after do_configure  # Get archiving package with temp(logs) and scripts(.bb and inc files) -do_package_write_rpm[prefuncs] += "do_archive_scripts_logs " +addtask do_archive_scripts_logs after do_package_write_rpm  # Get dump date and create diff file  -do_package_write_rpm[postfuncs] += "do_dumpdata_create_diff_gz " +addtask do_dumpdata_create_diff_gz after do_package_write_rpm before do_build + +python () { +    if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True) != 'srpm': +        """ +        If package type is not 'srpm' then add tasks to move archive packages of +        configured sources and scripts/logs in ${DEPLOY_DIR}/sources. +        """ +        pn = d.getVar('PN', True) +        d.appendVarFlag('do_compile', 'depends', ' %s:do_archive_configured_sources' %pn) +        build_deps = ' %s:do_archive_configured_sources' %pn +        build_deps += ' %s:do_archive_scripts_logs' %pn +        d.appendVarFlag('do_build', 'depends', build_deps) + +    else: +        d.prependVarFlag('do_configure', 'postfuncs', "do_archive_configured_sources") +        d.prependVarFlag('do_package_write_rpm', 'prefuncs', "do_archive_scripts_logs") +} + +ARCHIVE_SSTATE_OUTDIR = "${DEPLOY_DIR}/sources/" +ARCHIVE_SSTATE_SCRIPTS_LOGS_INDIR = "${WORKDIR}/script-logs/" +ARCHIVE_SSTATE_DIFFGZ_ENVDATA_INDIR = "${WORKDIR}/diffgz-envdata/" + +SSTATETASKS += "do_archive_scripts_logs" +do_archive_scripts_logs[sstate-name] = "archive_scripts_logs" +do_archive_scripts_logs[sstate-inputdirs] = "${ARCHIVE_SSTATE_SCRIPTS_LOGS_INDIR}" +do_archive_scripts_logs[sstate-outputdirs] = "${ARCHIVE_SSTATE_OUTDIR}" + +python do_archive_scripts_logs_setscene () { +    sstate_setscene(d) +} + +addtask do_archive_scripts_logs_setscene + +SSTATETASKS += "do_dumpdata_create_diff_gz" +do_dumpdata_create_diff_gz[sstate-name] = "dumpdata_create_diff_gz" +do_dumpdata_create_diff_gz[sstate-inputdirs] = "${ARCHIVE_SSTATE_DIFFGZ_ENVDATA_INDIR}" +do_dumpdata_create_diff_gz[sstate-outputdirs] = "${ARCHIVE_SSTATE_OUTDIR}" + +python do_dumpdata_create_diff_gz_setscene () { +    sstate_setscene(d) +} + +addtask do_dumpdata_create_diff_gz_setscene diff --git a/meta/classes/archive-original-source.bbclass b/meta/classes/archive-original-source.bbclass index 1b3f8d0b34..f123cafcb0 100644 --- a/meta/classes/archive-original-source.bbclass +++ b/meta/classes/archive-original-source.bbclass @@ -8,10 +8,53 @@  inherit archiver  # Get original sources archiving package with patches -do_unpack[postfuncs] += "do_archive_original_sources_patches " +addtask do_archive_original_sources_patches after do_unpack  # Get archiving package with temp(logs) and scripts(.bb and inc files) -do_package_write_rpm[prefuncs] += "do_archive_scripts_logs " +addtask do_archive_scripts_logs after do_package_write_rpm  # Get dump date and create diff file  -do_package_write_rpm[postfuncs] += "do_dumpdata_create_diff_gz " +addtask do_dumpdata_create_diff_gz after do_package_write_rpm before do_build + +python () { +    if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True) != 'srpm': +        """ +        If package type is not 'srpm' then add tasks to move archive packages of +        original sources and scripts/logs in ${DEPLOY_DIR}/sources. +        """ +        pn = d.getVar('PN', True) +        d.appendVarFlag('do_patch', 'depends', ' %s:do_archive_original_sources_patches' %pn) +        build_deps = ' %s:do_archive_original_sources_patches' %pn +        build_deps += ' %s:do_archive_scripts_logs' %pn +        d.appendVarFlag('do_build', 'depends', build_deps) + +    else: +        d.prependVarFlag('do_unpack', 'postfuncs', "do_archive_original_sources_patches") +        d.prependVarFlag('do_package_write_rpm', 'prefuncs', "do_archive_scripts_logs") +} + +ARCHIVE_SSTATE_OUTDIR = "${DEPLOY_DIR}/sources/" +ARCHIVE_SSTATE_SCRIPTS_LOGS_INDIR = "${WORKDIR}/script-logs/" +ARCHIVE_SSTATE_DIFFGZ_ENVDATA_INDIR = "${WORKDIR}/diffgz-envdata/" + +SSTATETASKS += "do_archive_scripts_logs" +do_archive_scripts_logs[sstate-name] = "archive_scripts_logs" +do_archive_scripts_logs[sstate-inputdirs] = "${ARCHIVE_SSTATE_SCRIPTS_LOGS_INDIR}" +do_archive_scripts_logs[sstate-outputdirs] = "${ARCHIVE_SSTATE_OUTDIR}" + +python do_archive_scripts_logs_setscene () { +    sstate_setscene(d) +} + +addtask do_archive_scripts_logs_setscene + +SSTATETASKS += "do_dumpdata_create_diff_gz" +do_dumpdata_create_diff_gz[sstate-name] = "dumpdata_create_diff_gz" +do_dumpdata_create_diff_gz[sstate-inputdirs] = "${ARCHIVE_SSTATE_DIFFGZ_ENVDATA_INDIR}" +do_dumpdata_create_diff_gz[sstate-outputdirs] = "${ARCHIVE_SSTATE_OUTDIR}" + +python do_dumpdata_create_diff_gz_setscene () { +    sstate_setscene(d) +} + +addtask do_dumpdata_create_diff_gz_setscene diff --git a/meta/classes/archive-patched-source.bbclass b/meta/classes/archive-patched-source.bbclass index 40b2dcb0ea..f9f558e652 100644 --- a/meta/classes/archive-patched-source.bbclass +++ b/meta/classes/archive-patched-source.bbclass @@ -8,10 +8,53 @@  inherit archiver  # Get archiving package with patched sources including patches -do_patch[postfuncs] += "do_archive_patched_sources " +addtask do_archive_patched_sources after do_patch  # Get archiving package with logs(temp) and scripts(.bb and .inc files) -do_package_write_rpm[prefuncs] += "do_archive_scripts_logs " +addtask do_archive_scripts_logs after do_package_write_rpm  # Get dump date and create diff file  -do_package_write_rpm[postfuncs] += "do_dumpdata_create_diff_gz " +addtask do_dumpdata_create_diff_gz after do_package_write_rpm before do_build + +python () { +    if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True) != 'srpm': +        """ +        If package type is not 'srpm' then add tasks to move archive packages of +        patched sources and scripts/logs in ${DEPLOY_DIR}/sources. +        """ +        pn = d.getVar('PN', True) +        d.appendVarFlag('do_configure', 'depends', ' %s:do_archive_patched_sources' %pn) +        build_deps = ' %s:do_archive_patched_sources' %pn +        build_deps += ' %s:do_archive_scripts_logs' %pn +        d.appendVarFlag('do_build', 'depends', build_deps) + +    else: +        d.prependVarFlag('do_patch', 'postfuncs', "do_archive_patched_sources") +        d.prependVarFlag('do_package_write_rpm', 'prefuncs', "do_archive_scripts_logs") +} + +ARCHIVE_SSTATE_OUTDIR = "${DEPLOY_DIR}/sources/" +ARCHIVE_SSTATE_SCRIPTS_LOGS_INDIR = "${WORKDIR}/script-logs/" +ARCHIVE_SSTATE_DIFFGZ_ENVDATA_INDIR = "${WORKDIR}/diffgz-envdata/" + +SSTATETASKS += "do_archive_scripts_logs" +do_archive_scripts_logs[sstate-name] = "archive_scripts_logs" +do_archive_scripts_logs[sstate-inputdirs] = "${ARCHIVE_SSTATE_SCRIPTS_LOGS_INDIR}" +do_archive_scripts_logs[sstate-outputdirs] = "${ARCHIVE_SSTATE_OUTDIR}" + +python do_archive_scripts_logs_setscene () { +    sstate_setscene(d) +} + +addtask do_archive_scripts_logs_setscene + +SSTATETASKS += "do_dumpdata_create_diff_gz" +do_dumpdata_create_diff_gz[sstate-name] = "dumpdata_create_diff_gz" +do_dumpdata_create_diff_gz[sstate-inputdirs] = "${ARCHIVE_SSTATE_DIFFGZ_ENVDATA_INDIR}" +do_dumpdata_create_diff_gz[sstate-outputdirs] = "${ARCHIVE_SSTATE_OUTDIR}" + +python do_dumpdata_create_diff_gz_setscene () { +    sstate_setscene(d) +} + +addtask do_dumpdata_create_diff_gz_setscene diff --git a/meta/classes/archiver.bbclass b/meta/classes/archiver.bbclass index a4a2158099..43238272c5 100644 --- a/meta/classes/archiver.bbclass +++ b/meta/classes/archiver.bbclass @@ -94,9 +94,11 @@ def get_bb_inc(d):      work_dir = d.getVar('WORKDIR', True)      bbfile = d.getVar('FILE', True)      bbdir = os.path.dirname(bbfile) -    script_logs = os.path.join(work_dir, 'script-logs') +    target_sys = d.getVar('TARGET_SYS', True) +    pf = d.getVar('PF', True) +    licenses = get_licenses(d) +    script_logs = os.path.join(work_dir, 'script-logs/'+ target_sys + '/' + licenses + '/' + pf + '/script-logs')      bb_inc = os.path.join(script_logs, 'bb_inc') -    bb.mkdirhier(script_logs)      bb.mkdirhier(bb_inc)      def find_file(dir, file): @@ -124,6 +126,18 @@ def get_bb_inc(d):      for bbincfile in bbinc:          shutil.copy(bbincfile, bb_inc) +    return script_logs + +def get_logs(d): +    """ +    create a directory "script-logs" in ${WORKDIR} +    """ +    work_dir = d.getVar('WORKDIR', True) +    target_sys = d.getVar('TARGET_SYS', True) +    pf = d.getVar('PF', True) +    licenses = get_licenses(d) +    script_logs = os.path.join(work_dir, 'script-logs/'+ target_sys + '/' + licenses + '/' + pf + '/script-logs') +      try:          bb.mkdirhier(os.path.join(script_logs, 'temp'))          oe.path.copytree(os.path.join(work_dir, 'temp'), os.path.join(script_logs, 'temp')) @@ -309,7 +323,8 @@ def archive_logs(d, logdir, bbinc=False):      work_dir = d.getVar('WORKDIR', True)      log_dir =  os.path.basename(logdir)      tarname = pf + '-' + log_dir + ".tar.gz" -    tarname = do_tarball(work_dir, log_dir, tarname) +    archive_dir = os.path.join( logdir, '..' ) +    tarname = do_tarball(archive_dir, log_dir, tarname)      if bbinc:          shutil.rmtree(logdir, ignore_errors=True)      return tarname @@ -414,6 +429,7 @@ def archive_scripts_logs(d):      archive scripts and logs. scripts include .bb and .inc files and      logs include stuff in "temp".      """ +    import shutil      if tar_filter(d):          return @@ -421,18 +437,20 @@ def archive_scripts_logs(d):      temp_dir = os.path.join(work_dir, 'temp')      source_archive_log_with_scripts = d.getVar('SOURCE_ARCHIVE_LOG_WITH_SCRIPTS', True)      if source_archive_log_with_scripts == 'logs_with_scripts': +        logdir = get_logs(d)          logdir = get_bb_inc(d) -        tarlog = archive_logs(d, logdir, True)      elif source_archive_log_with_scripts == 'logs': -        if os.path.exists(temp_dir): -            tarlog = archive_logs(d, temp_dir, False) +        logdir = get_logs(d)      else:          return -    if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True) != 'srpm': -        move_tarball_deploy(d, [tarlog]) +    tarlog = archive_logs(d, logdir, True) -    else: +    if d.getVar('SOURCE_ARCHIVE_PACKAGE_TYPE', True) == 'srpm': +        if os.path.exists(work_dir+ '/' + tarlog): +            os.remove(work_dir+ '/' + tarlog) +        shutil.move(os.path.join(logdir, '..', tarlog), work_dir) +        shutil.rmtree(os.path.join(work_dir,'script-logs'))          store_package(d, tarlog)  def dumpdata(d): @@ -449,7 +467,7 @@ def dumpdata(d):      pf = d.getVar('PF', True)      target_sys = d.getVar('TARGET_SYS', True)      licenses = get_licenses(d) -    dumpdir = d.getVar('DEPLOY_DIR', True) + '/sources/' + target_sys + '/' + licenses + '/' + pf +    dumpdir = os.path.join(workdir, 'diffgz-envdata/'+ target_sys + '/' + licenses + '/' + pf )      if not os.path.exists(dumpdir):          bb.mkdirhier(dumpdir) @@ -480,7 +498,7 @@ def create_diff_gz(d):      pf = d.getVar('PF', True)      licenses = get_licenses(d)      target_sys = d.getVar('TARGET_SYS', True) -    diff_dir = d.getVar('DEPLOY_DIR', True) + '/sources/' + target_sys + '/' + licenses + '/' + pf +    diff_dir = os.path.join(work_dir, 'diffgz-envdata/'+ target_sys + '/' + licenses + '/' + pf )      diff_file = os.path.join(diff_dir, bb.data.expand("${P}-${PR}.diff.gz",d))      f = open(os.path.join(work_dir,'temp/exclude-from-file'), 'a') | 
