Date: Wed, 22 Jul 2020 17:05:02 -0400 From: "Dan Langille" <dan@langille.org> To: =?UTF-8?Q?Ulrich_Sp=C3=B6rlein?= <uqs@freebsd.org> Cc: freebsd-git@freebsd.org Subject: Re: FreshPorts status update 2020.07.21 Message-ID: <33a7ddfa-224e-4834-af59-f0794e6232d7@www.fastmail.com> In-Reply-To: <20200722171717.GG16439@acme.spoerlein.net> References: <3c7b8854-f5e8-4c72-acb3-f1147eae9df3@www.fastmail.com> <20200722171717.GG16439@acme.spoerlein.net>
index | next in thread | previous in thread | raw e-mail
On Wed, Jul 22, 2020, at 1:17 PM, Ulrich Spörlein wrote: > On Tue, 2020-07-21 at 20:02:48 -0400, Dan Langille wrote: > > Hello, > > > > At present, devgit.FreshPorts.org is keeping up with all port commits. > > > > Processing is initiated manually. I run a script to set some flags. This could be run by a commit-hook pulling a URL. FreshPorts can do the rest. I welcome discussion on how to do this. > > > > I'd rather keep the URL private, for less abuse-potential. We could add in some auth or ACL. Invoking the URL will get FreshPorts to query the FreeBSD repo. > > > > > > I've posted the following issue at https://github.com/FreshPorts/git_proc_commit/issues/23 > > > > ### > > I am having trouble detecting a port delete or copy. Under subversion, as seen at https://svnweb.freebsd.org/ports?view=revision&revision=542761, you get a deleted notice. > > > > In the email (https://docs.freebsd.org/cgi/getmsg.cgi?fetch=1326960+0+current/svn-ports-head) this turns up as: head/net/kdav/ under Deleted. > > > > In git, it does not, from what I can tell. I can find: > > > > $ grep net/kda 2020.07.21.17.15.38.000000.d016c9140a6e4b7627d26485926a659f2686185d.xml > > - net/kdav became a framework and was therefore moved to net/kf5-kdav. > > <FILE Action="Delete" Path="net/kdav/distinfo"/> > > <FILE Action="Rename" Path="net/kdav/Makefile" Destination="net/kf5-kdav/Makefile"/> > > <FILE Action="Rename" Path="net/kdav/pkg-plist" Destination="net/kf5-kdav/pkg-plist"/> > > > > (Sorry, the above is the XML generated by https://github.com/FreshPorts/git_proc_commit/blob/master/git-to-freshports/git-to-freshports-xml.py) > > > > Knowing that a file has been deleted within a commit is vital. Detecting it from within the commit log is the optimal approach. Does anything have a suggestion here? > > > > I can see that the Makefile & pkg-plist have been renamed, and distinfo has been deleted. Perhaps it's just a matter of changing my approach. However, this does not yet sound like a solid plan. > > > > I welcome suggestions for something I have missed in the git interface please. > > I don't know how stable these interfaces and outputs are in git over > time, but you can get the full diff with git log -p or git show -p and > could feed that through, say diffstat. > > A better approach might be to use --compact-summary (see the git log > manpage for some possible outputs and variants of it). > > (I'm using --format here to suppress printing of the commit message, > which might mess up parsing the output we're actually interested in) > > $ git show --compact-summary --format=%h > 44b2876caf1f56d6e940a329a2f8e06724fd621f > 44b2876caf1f > > MOVED | 1 + > devel/Makefile | 1 - > devel/py-trio/Makefile (gone) | 38 -------------------------------------- > devel/py-trio/distinfo (gone) | 3 --- > devel/py-trio/pkg-descr (gone) | 13 ------------- > 5 files changed, 1 insertion(+), 55 deletions(-) > > Probably even better is this: > $ git show --summary --format=%h 44b2876caf1f56d6e940a329a2f8e06724fd621f > 44b2876caf1f > > delete mode 100644 devel/py-trio/Makefile > delete mode 100644 devel/py-trio/distinfo > delete mode 100644 devel/py-trio/pkg-descr > > (why does this drop the changes to MOVED and devel/Makefile though? The > manpage entry is cryptic enough: > Output a condensed summary of extended header information such as > creations, renames and mode changes. > ) I think the rule so far is: * if cat/port/Makefile is deleted or renamed, that port has been deleted I could reproduce what you did here, with the beta repo: [dan@pro02:~/src/freebsd-ports-beta] $ git show --summary --format=%h 44b2876caf1f56d6e940a329a2f8e06724fd621f 44b2876caf1f delete mode 100644 devel/py-trio/Makefile delete mode 100644 devel/py-trio/distinfo delete mode 100644 devel/py-trio/pkg-descr [dan@pro02:~/src/freebsd-ports-beta] $ Now, moving over to Github repo with the comment I mentioned above: [dan@pro02:~/src/freebsd-ports] $ git show --summary --format=%h d016c9140a6e4b7627d26485926a659f2686185d d016c9140a6e delete mode 100644 devel/kf5-kcrash/files/patch-src_kcrash.cpp delete mode 100644 devel/kf5-solid/files/patch-CMakeLists.txt delete mode 100644 net/kdav/distinfo rename net/{kdav => kf5-kdav}/Makefile (82%) create mode 100644 net/kf5-kdav/distinfo rename net/{kdav => kf5-kdav}/pkg-plist (92%) [dan@pro02:~/src/freebsd-ports] $ That is very similar to what Adriaan de Groot showed me via https://docs.freebsd.org/cgi/getmsg.cgi?fetch=2171670+0+current/svn-ports-head ### git tells me: delete mode 100644 net/kdav/distinfo rename net/{kdav => kf5-kdav}/Makefile (82%) create mode 100644 net/kf5-kdav/distinfo rename net/{kdav => kf5-kdav}/pkg-plist (92%) ### That output 'rename net/{kdav => kf5-kdav}/Makefile' may proof non-trivial to parse. I think so far the above rule is the best option. Thank you. -- Dan Langille dan@langille.orghelp
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?33a7ddfa-224e-4834-af59-f0794e6232d7>
