From 3594ff27d4931b660b93128167cd0c602d0aec8a Mon Sep 17 00:00:00 2001 From: vthriller Date: Thu, 31 Oct 2013 18:43:44 +0400 Subject: [PATCH 1/2] =?UTF-8?q?Seems=20like=20thoughts=20on=20importance?= =?UTF-8?q?=20of=20tag=20ordering=20were=20wrong=E2=80=A6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This reverts commit 7df65cf48641fa2921646afc65656627532fe0c7 "reorder tags a bit to make generated RPMs usable again". --- makerpm.cc | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/makerpm.cc b/makerpm.cc index ad93471..ac4e0d0 100644 --- a/makerpm.cc +++ b/makerpm.cc @@ -309,10 +309,6 @@ std::string make_index2(const rpmprops_t& props) { uint32_t totsize = 0; uint64_t totlongsize = 0; - // despite it's name, the index entry does not allow one to store tags in random order; - // some misplacements are not fatal, some may lead to various metadata glitches (e.g. appearance of non-stored tags or incorrect file ownership). - // current tag order is actually incorrect; for correct ones, see `rpm --querytags`. - //store.add(rpm::TAG_HEADERI18NTABLE, props.locale); store.add(rpm::TAG_NAME, props.name, false); @@ -329,6 +325,9 @@ std::string make_index2(const rpmprops_t& props) { store.add(rpm::TAG_URL, props.url, false); store.add(rpm::TAG_OS, props.os, false); store.add(rpm::TAG_ARCH, props.arch, false); + store.add(rpm::TAG_PAYLOADFORMAT, props.payload_format, false); + store.add(rpm::TAG_PAYLOADCOMPRESSOR, props.payload_compressor, false); + store.add(rpm::TAG_PLATFORM, props.platform, false); // for details, see yum's rpmUtils/miscutils.py, function pkgTupleFromHeader(), // or createrepo's createrepo/yumbased.py, method CreateRepoPackage.isSrpm() @@ -340,10 +339,6 @@ std::string make_index2(const rpmprops_t& props) { if(props.arch == "src") store.add(rpm::TAG_SOURCEPACKAGE, (uint32_t)1); - store.add(rpm::TAG_PAYLOADFORMAT, props.payload_format, false); - store.add(rpm::TAG_PAYLOADCOMPRESSOR, props.payload_compressor, false); - store.add(rpm::TAG_PLATFORM, props.platform, false); - store.add(rpm::TAG_OPTFLAGS, props.optflags, false); store.add(rpm::TAG_RPMVERSION, props.rpmversion, false); From 0ab57c54b2f05cc7ae420d6f2995a94bdc9f69a3 Mon Sep 17 00:00:00 2001 From: vthriller Date: Thu, 31 Oct 2013 18:49:16 +0400 Subject: [PATCH 2/2] fixing incorrect lead's type --- makerpm.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/makerpm.cc b/makerpm.cc index ac4e0d0..1ce83de 100644 --- a/makerpm.cc +++ b/makerpm.cc @@ -634,7 +634,7 @@ mfile make_rpm(const rpmprops_t& props, const std::string& payload_file, std::st mfile ret = make_index1(index2, payload, payload_file + ".gz", header); std::string lead = make_lead( props.name, - htons((uint16_t)(props.arch != "src")) /* 0 for source, 1 for binary */ + htons((uint16_t)(props.arch == "src")) /* 1 for source, 0 for binary */ ); header = lead + header + index2;