diff options
| author | Tudor Florea <tudor.florea@enea.com> | 2015-10-08 22:51:41 +0200 |
|---|---|---|
| committer | Tudor Florea <tudor.florea@enea.com> | 2015-10-08 22:51:41 +0200 |
| commit | 1219bf8a90a7bf8cd3a5363551ef635d51e8fc8e (patch) | |
| tree | a21a5fc103bb3bd65ecd85ed22be5228fc54e447 /meta-oe/classes/gitpkgv.bbclass | |
| download | meta-openembedded-1219bf8a90a7bf8cd3a5363551ef635d51e8fc8e.tar.gz | |
initial commit for Enea Linux 5.0 arm
Signed-off-by: Tudor Florea <tudor.florea@enea.com>
Diffstat (limited to 'meta-oe/classes/gitpkgv.bbclass')
| -rw-r--r-- | meta-oe/classes/gitpkgv.bbclass | 113 |
1 files changed, 113 insertions, 0 deletions
diff --git a/meta-oe/classes/gitpkgv.bbclass b/meta-oe/classes/gitpkgv.bbclass new file mode 100644 index 0000000000..7bdc538939 --- /dev/null +++ b/meta-oe/classes/gitpkgv.bbclass | |||
| @@ -0,0 +1,113 @@ | |||
| 1 | # gitpkgv.bbclass provides a GITPKGV and GITPKGVTAG variables to be | ||
| 2 | # used in PKGV, as described bellow: | ||
| 3 | # | ||
| 4 | # - GITPKGV which is a sortable version with the format NN+GITHASH, to | ||
| 5 | # be used in PKGV, where | ||
| 6 | # | ||
| 7 | # NN equals the total number of revs up to SRCREV | ||
| 8 | # GITHASH is SRCREV's (full) hash | ||
| 9 | # | ||
| 10 | # - GITPKGVTAG which is the output of 'git describe' allowing for | ||
| 11 | # automatic versioning | ||
| 12 | # | ||
| 13 | # gitpkgv.bbclass assumes the git repository has been cloned, and | ||
| 14 | # contains SRCREV. So ${GITPKGV} and ${GITPKGVTAG} should never be | ||
| 15 | # used in PV, only in PKGV. It can handle SRCREV = ${AUTOREV}, as | ||
| 16 | # well as SRCREV = "<some fixed git hash>". | ||
| 17 | # | ||
| 18 | # WARNING: if upstream repository is always using consistent and | ||
| 19 | # sortable tag name scheme you can get sortable version including tag | ||
| 20 | # name with ${GITPKGVTAG}, but be aware that ie tag sequence "v1.0, | ||
| 21 | # v1.2, xtest, v2.0" will force you to increment PE to get upgradeable | ||
| 22 | # path to v2.0 revisions | ||
| 23 | # | ||
| 24 | # use example: | ||
| 25 | # | ||
| 26 | # inherit gitpkgv | ||
| 27 | # | ||
| 28 | # PV = "1.0+gitr${SRCPV}" # expands to something like 1.0+gitr3+4c1c21d7dbbf93b0df336994524313dfe0d4963b | ||
| 29 | # PKGV = "1.0+gitr${GITPKGV}" # expands also to something like 1.0+gitr31337+4c1c21d7d | ||
| 30 | # | ||
| 31 | # or | ||
| 32 | # | ||
| 33 | # inherit gitpkgv | ||
| 34 | # | ||
| 35 | # PV = "1.0+gitr${SRCPV}" # expands to something like 1.0+gitr3+4c1c21d7dbbf93b0df336994524313dfe0d4963b | ||
| 36 | # PKGV = "${GITPKGVTAG}" # expands to something like 1.0-31337+g4c1c21d | ||
| 37 | # if there is tag v1.0 before this revision or | ||
| 38 | # ver1.0-31337+g4c1c21d if there is tag ver1.0 | ||
| 39 | |||
| 40 | GITPKGV = "${@get_git_pkgv(d, False)}" | ||
| 41 | GITPKGVTAG = "${@get_git_pkgv(d, True)}" | ||
| 42 | |||
| 43 | def gitpkgv_drop_tag_prefix(version): | ||
| 44 | import re | ||
| 45 | if re.match("v\d", version): | ||
| 46 | return version[1:] | ||
| 47 | else: | ||
| 48 | return version | ||
| 49 | |||
| 50 | def get_git_pkgv(d, use_tags): | ||
| 51 | import os | ||
| 52 | import bb | ||
| 53 | from pipes import quote | ||
| 54 | |||
| 55 | src_uri = d.getVar('SRC_URI', 1).split() | ||
| 56 | fetcher = bb.fetch2.Fetch(src_uri, d) | ||
| 57 | ud = fetcher.ud | ||
| 58 | |||
| 59 | # | ||
| 60 | # If SRCREV_FORMAT is set respect it for tags | ||
| 61 | # | ||
| 62 | format = d.getVar('SRCREV_FORMAT', True) | ||
| 63 | if not format: | ||
| 64 | format = 'default' | ||
| 65 | |||
| 66 | found = False | ||
| 67 | for url in ud.values(): | ||
| 68 | if url.type == 'git': | ||
| 69 | for name, rev in url.revisions.items(): | ||
| 70 | if not os.path.exists(url.localpath): | ||
| 71 | return None | ||
| 72 | |||
| 73 | found = True | ||
| 74 | |||
| 75 | vars = { 'repodir' : quote(url.localpath), | ||
| 76 | 'rev' : quote(rev) } | ||
| 77 | |||
| 78 | rev = bb.fetch2.get_srcrev(d).split('+')[1] | ||
| 79 | rev_file = os.path.join(url.localpath, "oe-gitpkgv_" + rev) | ||
| 80 | |||
| 81 | if not os.path.exists(rev_file) or os.path.getsize(rev_file)==0: | ||
| 82 | commits = bb.fetch2.runfetchcmd( | ||
| 83 | "cd %(repodir)s && " | ||
| 84 | "git rev-list %(rev)s -- 2> /dev/null " | ||
| 85 | "| wc -l" % vars, | ||
| 86 | d, quiet=True).strip().lstrip('0') | ||
| 87 | |||
| 88 | if commits != "": | ||
| 89 | oe.path.remove(rev_file, recurse=False) | ||
| 90 | open(rev_file, "w").write("%d\n" % int(commits)) | ||
| 91 | else: | ||
| 92 | commits = "0" | ||
| 93 | else: | ||
| 94 | commits = open(rev_file, "r").readline(128).strip() | ||
| 95 | |||
| 96 | if use_tags: | ||
| 97 | try: | ||
| 98 | output = bb.fetch2.runfetchcmd( | ||
| 99 | "cd %(repodir)s && " | ||
| 100 | "git describe %(rev)s 2>/dev/null" % vars, | ||
| 101 | d, quiet=True).strip() | ||
| 102 | ver = gitpkgv_drop_tag_prefix(output) | ||
| 103 | except Exception: | ||
| 104 | ver = "0.0-%s-g%s" % (commits, rev[:7]) | ||
| 105 | else: | ||
| 106 | ver = "%s+%s" % (commits, rev[:7]) | ||
| 107 | |||
| 108 | format = format.replace(name, ver) | ||
| 109 | |||
| 110 | if found: | ||
| 111 | return format | ||
| 112 | |||
| 113 | return '0+0' | ||
