From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga11.intel.com (mga11.intel.com [192.55.52.93]) by mail.openembedded.org (Postfix) with ESMTP id 9DF516CEDB for ; Thu, 21 Nov 2013 16:41:26 +0000 (UTC) Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga102.fm.intel.com with ESMTP; 21 Nov 2013 08:41:26 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.93,745,1378882800"; d="scan'208";a="437431791" Received: from pmcgurk-mobl.ger.corp.intel.com (HELO helios.localnet) ([10.252.121.225]) by fmsmga002.fm.intel.com with ESMTP; 21 Nov 2013 08:41:22 -0800 From: Paul Eggleton To: Hongxu Jia Date: Thu, 21 Nov 2013 16:41:20 +0000 Message-ID: <1673532.sZIipt1mGd@helios> Organization: Intel Corporation User-Agent: KMail/4.10.5 (Linux/3.8.0-31-generic; KDE/4.10.5; i686; ; ) In-Reply-To: References: MIME-Version: 1.0 Cc: openembedded-core@lists.openembedded.org, saul.wold@intel.com Subject: Re: [PATCH 1/1] license.bbclass: fix copying license directories failed X-BeenThere: openembedded-core@lists.openembedded.org X-Mailman-Version: 2.1.12 Precedence: list List-Id: Patches and discussions about the oe-core layer List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 21 Nov 2013 16:41:26 -0000 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Hi Hongxu, On Wednesday 20 November 2013 18:39:02 Hongxu Jia wrote: > For each recipe, it populated license files to ${LICENSE_DIRECTORY}/${PN}, > such as kernel's license dir was > ${LICENSE_DIRECTORY}/kernel-3.10.17-yocto-standard; > > In do_rootfs task, it copied license directories from ${LICENSE_DIRECTORY}/ > ${pkg}, and ${pkg} was listed in ${INSTALLED_PKGS}; > > We got ${INSTALLED_PKGS} by rpm query, such as the kernel were 'kernel-*', > but the kernel's PN was linux-yocto, so searching ${LICENSE_DIRECTORY}/ > kernel-* failed. > > Copied license directories from ${LICENSE_DIRECTORY}/${PN} fixed this issue. > > [YOCTO #5572] > > Signed-off-by: Hongxu Jia > --- > meta/classes/license.bbclass | 9 ++++++--- > 1 file changed, 6 insertions(+), 3 deletions(-) > > diff --git a/meta/classes/license.bbclass b/meta/classes/license.bbclass > index 6d7ee94..32605ff 100644 > --- a/meta/classes/license.bbclass > +++ b/meta/classes/license.bbclass > @@ -68,15 +68,18 @@ license_create_manifest() { > if [ "${COPY_LIC_DIRS}" = "1" ]; then > for pkg in ${INSTALLED_PKGS}; do > mkdir -p ${IMAGE_ROOTFS}/usr/share/common-licenses/${pkg} > - for lic in `ls ${LICENSE_DIRECTORY}/${pkg}`; do > + pkged_pn="$(sed -n "/^PACKAGE NAME: ${pkg}$/,/^$/ \ > + {s/^RECIPE NAME: //; /^PACKAGE > NAME:/d; /^PACKAGE VERSION:/d; /^LICENSE:/d; p}" \ + > ${LICENSE_MANIFEST})" > + for lic in `ls ${LICENSE_DIRECTORY}/${pkged_pn}`; do This isn't the right way to do this. If you need to look up the recipe name from the target package name, in master you can now use: oe-pkgdata-util lookup-recipe ${PKGDATA_DIR} "" Cheers, Paul -- Paul Eggleton Intel Open Source Technology Centre