* Re: pull requests
@ 2020-04-17 4:24 Zach Pearson
2020-04-17 8:11 ` Alex Ott
2020-04-17 16:38 ` Dmitry Gutov
0 siblings, 2 replies; 53+ messages in thread
From: Zach Pearson @ 2020-04-17 4:24 UTC (permalink / raw)
To: Dmitry Gutov, emacs-devel
I’m pretty sure GitHub will also let you open a pull request via the command line if you want. Additionally, it emails PR threads to users that subscribe to them (initially maintainers) — so if you’ve got write access and would strongly prefer to keep your email based workflow it is known that it’s possible to keep it.
> On Apr 16, 2020, at 10:55 PM, Dmitry Gutov <dgutov@yandex.ru> wrote:
>
> Hi Richard,
>
> Sorry for the late reply. I'll try to make a good description.
>
>>>> On 02.04.2020 05:39, Richard Stallman wrote:
>> [[[ To any NSA and FBI agents reading my email: please consider ]]]
>> [[[ whether defending the US Constitution against all enemies, ]]]
>> [[[ foreign or domestic, requires you to follow Snowden's example. ]]]
>> I have never seen what a pull request is like to use. I do not use
>> the systems which support them. In trying to think about their
>> implications, I have to go by the descriptions people have sent me
>> in this discussion.
>> Unfortunately, the descriptions I've reaceived seen to conflict.
>> Perhaps people were describing different ways that different projects
>> or different platforms handle pull requests, but I did not know that
>> when I read them.
>
> AFAIK, there are basically two different things that are called a "pull request".
>
> The first is basically an email with details about the repository and the branch you want code "pulled" from. There are more details here: https://www.kernel.org/doc/html/latest/maintainer/pull-requests.html, but this is largely irrelevant to this discussion because a) we can do this already (and don't need any help with that), b) our developers and contributors don't use this approach. So it's not what we've been discussing.
>
> The second one (which is what we're considering) has been popularized by the proprietary code forge called GitHub. In there, users can make 'forks' of the original repository, where a fork is basically a copy of the original repository that belongs to the user's account (and its URL has the user's username in it). The said user can create a new branch, push some changesets into it, and then propose the said branch to the original repository and its developers for merging. By creating a "pull request".
>
> It's a "thing": Github, as well as similar forges such as Gitlab, have a dedicated type of issue (*) that's called a "pull request". It has all the features of an "issue" (which generally means people can leave comments in it), as well as extra features: it shows the author, the source branch, a multi-line description that the author usually has to fill, the proposed commits, it can show the combined diff of those commits, users can leave comments associated with individual lines of that diff (and the UI displays that neatly), they can lead threaded discussions on said commits (which get semi-hidden as soon as the related code has changed), and the PR tracks the source branch closely, so as soon as the user pushes some new changes to the branch, the information in the PR updates automatically. The PR web page can show the status of the CI build for the proposed branch. The main repository's maintainers can merge the PR with just a couple of clicks with the mouse (this works best with small contributions). There are other features.
>
> Overall, a lot of developers are used to this workflow and would never choose patch submission over email. Of course, not everybody. Some people just don't like web interfaces, for example.
>
> (*) Issues are basically bug reports, but people can use them for discussions, support questions, and so on.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-04-17 4:24 pull requests Zach Pearson
@ 2020-04-17 8:11 ` Alex Ott
2020-04-17 16:36 ` Dmitry Gutov
2020-04-21 1:47 ` Richard Stallman
2020-04-17 16:38 ` Dmitry Gutov
1 sibling, 2 replies; 53+ messages in thread
From: Alex Ott @ 2020-04-17 8:11 UTC (permalink / raw)
To: Zach Pearson, emacs-devel
For GitHub there is https://hub.github.com/ - command line tool that allows
to create a new PR, pull PR into your tree to review, look into issues,
change issues, etc. It's integrated with Emacs tools, like, Magit (via
https://github.com/vermiculus/magithub)
Github also announced recently another tool with similar functionality:
https://github.com/cli/cli, but I haven't try it.
Zach Pearson at "Thu, 16 Apr 2020 23:24:56 -0500" wrote:
ZP> I’m pretty sure GitHub will also let you open a pull request via the command line if you
ZP> want. Additionally, it emails PR threads to users that subscribe to them (initially
ZP> maintainers) — so if you’ve got write access and would strongly prefer to keep your email
ZP> based workflow it is known that it’s possible to keep it.
>> On Apr 16, 2020, at 10:55 PM, Dmitry Gutov <dgutov@yandex.ru> wrote:
>>
>> Hi Richard,
>>
>> Sorry for the late reply. I'll try to make a good description.
>>
>>>>> On 02.04.2020 05:39, Richard Stallman wrote:
>>> [[[ To any NSA and FBI agents reading my email: please consider ]]]
>>> [[[ whether defending the US Constitution against all enemies, ]]]
>>> [[[ foreign or domestic, requires you to follow Snowden's example. ]]]
>>> I have never seen what a pull request is like to use. I do not use
>>> the systems which support them. In trying to think about their
>>> implications, I have to go by the descriptions people have sent me
>>> in this discussion.
>>> Unfortunately, the descriptions I've reaceived seen to conflict.
>>> Perhaps people were describing different ways that different projects
>>> or different platforms handle pull requests, but I did not know that
>>> when I read them.
>>
>> AFAIK, there are basically two different things that are called a "pull request".
>>
>> The first is basically an email with details about the repository and the branch you
>> want code "pulled" from. There are more details here:
>> https://www.kernel.org/doc/html/latest/maintainer/pull-requests.html, but this is
>> largely irrelevant to this discussion because a) we can do this already (and don't need
>> any help with that), b) our developers and contributors don't use this approach. So it's
>> not what we've been discussing.
>>
>> The second one (which is what we're considering) has been popularized by the proprietary
>> code forge called GitHub. In there, users can make 'forks' of the original repository,
>> where a fork is basically a copy of the original repository that belongs to the user's
>> account (and its URL has the user's username in it). The said user can create a new
>> branch, push some changesets into it, and then propose the said branch to the original
>> repository and its developers for merging. By creating a "pull request".
>>
>> It's a "thing": Github, as well as similar forges such as Gitlab, have a dedicated type
>> of issue (*) that's called a "pull request". It has all the features of an "issue"
>> (which generally means people can leave comments in it), as well as extra features: it
>> shows the author, the source branch, a multi-line description that the author usually
>> has to fill, the proposed commits, it can show the combined diff of those commits, users
>> can leave comments associated with individual lines of that diff (and the UI displays
>> that neatly), they can lead threaded discussions on said commits (which get semi-hidden
>> as soon as the related code has changed), and the PR tracks the source branch closely,
>> so as soon as the user pushes some new changes to the branch, the information in the PR
>> updates automatically. The PR web page can show the status of the CI build for the
>> proposed branch. The main repository's maintainers can merge the PR with just a couple
>> of clicks with the mouse (this works best with small contributions). There are other
>> features.
>>
>> Overall, a lot of developers are used to this workflow and would never choose patch
>> submission over email. Of course, not everybody. Some people just don't like web
>> interfaces, for example.
>>
>> (*) Issues are basically bug reports, but people can use them for discussions, support questions, and so on.
--
With best wishes, Alex Ott
http://alexott.net/
Twitter: alexott_en (English), alexott (Russian)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-04-17 8:11 ` Alex Ott
@ 2020-04-17 16:36 ` Dmitry Gutov
2020-04-21 1:47 ` Richard Stallman
1 sibling, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-04-17 16:36 UTC (permalink / raw)
To: Alex Ott, Zach Pearson, emacs-devel
On 17.04.2020 11:11, Alex Ott wrote:
> For GitHub there ishttps://hub.github.com/ - command line tool that allows
> to create a new PR, pull PR into your tree to review, look into issues,
> change issues, etc. It's integrated with Emacs tools, like, Magit (via
> https://github.com/vermiculus/magithub)
>
> Github also announced recently another tool with similar functionality:
> https://github.com/cli/cli, but I haven't try it.
That's good, but we're highly unlikely to ever use Github itself.
Gitlab, maybe. Or some other similar software that's Free. So if anyone
knows of command line tools that would work with any of the
alternatives, it could help.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-04-17 8:11 ` Alex Ott
2020-04-17 16:36 ` Dmitry Gutov
@ 2020-04-21 1:47 ` Richard Stallman
2020-04-21 2:12 ` Po Lu
1 sibling, 1 reply; 53+ messages in thread
From: Richard Stallman @ 2020-04-21 1:47 UTC (permalink / raw)
To: Alex Ott; +Cc: zach, emacs-devel
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
> For GitHub there is https://hub.github.com/ - command line tool that allows
> to create a new PR, pull PR into your tree to review, look into issues,
> change issues, etc. It's integrated with Emacs tools, like, Magit (via
> https://github.com/vermiculus/magithub)
Using something like this does not cause the problems I was concerned with.
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-04-21 1:47 ` Richard Stallman
@ 2020-04-21 2:12 ` Po Lu
2020-04-22 3:19 ` Richard Stallman
0 siblings, 1 reply; 53+ messages in thread
From: Po Lu @ 2020-04-21 2:12 UTC (permalink / raw)
To: Richard Stallman; +Cc: Alex Ott, zach, emacs-devel
Richard Stallman <rms@gnu.org> writes:
> Using something like this does not cause the problems I was concerned with.
IIRC, registering GitHub accounts requires executing non-free
JavaScript. I wouldn't consider that acceptable.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-04-21 2:12 ` Po Lu
@ 2020-04-22 3:19 ` Richard Stallman
2020-04-23 3:15 ` Po Lu
0 siblings, 1 reply; 53+ messages in thread
From: Richard Stallman @ 2020-04-22 3:19 UTC (permalink / raw)
To: Po Lu; +Cc: alexott, zach, emacs-devel
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
> > Using something like this does not cause the problems I was concerned with.
> IIRC, registering GitHub accounts requires executing non-free
> JavaScript. I wouldn't consider that acceptable.
Sorry, I see that my words were not clear. I am not talking about
that specific program. It is just an example.
I'm commenting on the method of handling pull requests which that
program implements.
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-04-17 4:24 pull requests Zach Pearson
2020-04-17 8:11 ` Alex Ott
@ 2020-04-17 16:38 ` Dmitry Gutov
1 sibling, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-04-17 16:38 UTC (permalink / raw)
To: Zach Pearson, emacs-devel
On 17.04.2020 07:24, Zach Pearson wrote:
> so if you’ve got write access and would strongly prefer to keep your email based workflow it is known that it’s possible to keep it
With certain limitations, yes. Such as, I'm not sure it's easy to
partake in a subthread discussing a particular line in the review.
Or, if the first reply to a PR just quotes a line from a diff, it
wouldn't use the relevant features of the PR functionality.
But it's possible, yes.
^ permalink raw reply [flat|nested] 53+ messages in thread
* ELPA: where is chess developed?
@ 2020-03-22 22:35 Jack Hill
2020-03-23 4:26 ` John Wiegley
0 siblings, 1 reply; 53+ messages in thread
From: Jack Hill @ 2020-03-22 22:35 UTC (permalink / raw)
To: emacs-devel
Hi Emacs,
I'm interested in working with the Chess package. According to
1b67906a62fe84cf838f7bb88675af69e0efff13 [0], Chess is developed in the
the main ELPA repository. However, it seems that the previous upstream
location [1] has seen more development activity than the external/chess
branch [2].
[0] https://git.savannah.gnu.org/cgit/emacs/elpa.git/commit/?id=1b67906a62fe84cf838f7bb88675af69e0efff13
[1] https://github.com/jwiegley/emacs-chess
[2] https://git.savannah.gnu.org/cgit/emacs/elpa.git/log/?h=externals/chess
What's going on here? Did the project fork and there are two development
streams going forward? Did the aspiration to develop chess in the ELPA
repository fail, and we should switch back to jwiegley/emacs-chess as
upstream? If I package this for my distribution, which one should I use?
Please copy me on replies.
Thanks,
Jack
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: ELPA: where is chess developed?
2020-03-22 22:35 ELPA: where is chess developed? Jack Hill
@ 2020-03-23 4:26 ` John Wiegley
2020-03-23 13:50 ` dick.r.chiang
0 siblings, 1 reply; 53+ messages in thread
From: John Wiegley @ 2020-03-23 4:26 UTC (permalink / raw)
To: Jack Hill; +Cc: Mario Lang, emacs-devel
>>>>> "JH" == Jack Hill <jackhill@jackhill.us> writes:
JH> What's going on here? Did the project fork and there are two development
JH> streams going forward? Did the aspiration to develop chess in the ELPA
JH> repository fail, and we should switch back to jwiegley/emacs-chess as
JH> upstream? If I package this for my distribution, which one should I use?
I believe that Mario Lang is currently the most active developer, and that he
organized releases to ELPA. Whether that's the home seat of development or
not, I would ask of him. Mario?
--
John Wiegley GPG fingerprint = 4710 CF98 AF9B 327B B80F
http://newartisans.com 60E1 46C4 BD1A 7AC1 4BA2
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: ELPA: where is chess developed?
2020-03-23 4:26 ` John Wiegley
@ 2020-03-23 13:50 ` dick.r.chiang
2020-03-23 14:27 ` Mario Lang
0 siblings, 1 reply; 53+ messages in thread
From: dick.r.chiang @ 2020-03-23 13:50 UTC (permalink / raw)
To: Jack Hill; +Cc: Mario Lang, emacs-devel
Hi John,
The situation looks grim indeed -- a quick inspection shows development
streams between [1] and [2] to have diverged 20140604 (the last "Sync from ELPA"
commit).
I believe I've the time and taste to get them back in sync, but I think I need
push access to savannah, of which I've been denied in the past (and perhaps
with good reason).
[0] https://git.savannah.gnu.org/cgit/emacs/elpa.git/commit/?id=1b67906a62fe84cf838f7bb88675af69e0efff13
[1] https://github.com/jwiegley/emacs-chess
[2] https://git.savannah.gnu.org/cgit/emacs/elpa.git/log/?h=externals/chess
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: ELPA: where is chess developed?
2020-03-23 13:50 ` dick.r.chiang
@ 2020-03-23 14:27 ` Mario Lang
2020-03-23 15:12 ` dick.r.chiang
0 siblings, 1 reply; 53+ messages in thread
From: Mario Lang @ 2020-03-23 14:27 UTC (permalink / raw)
To: dick.r.chiang; +Cc: Jack Hill, emacs-devel
dick.r.chiang@gmail.com writes:
> Hi John,
>
> The situation looks grim indeed -- a quick inspection shows development
> streams between [1] and [2] to have diverged 20140604 (the last "Sync from ELPA"
> commit).
>
> I believe I've the time and taste to get them back in sync, but I think I need
> push access to savannah, of which I've been denied in the past (and perhaps
> with good reason).
git should make it relatively easy for you to provide a branch
somewhere which I (or someone else with ELPA access) could merge
after a review. So I dont see why missing push access would be a
showstopper. (Thanks for caring btw).
--
CYa,
⡍⠁⠗⠊⠕
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: ELPA: where is chess developed?
2020-03-23 14:27 ` Mario Lang
@ 2020-03-23 15:12 ` dick.r.chiang
2020-03-24 8:10 ` Philippe Vaucher
0 siblings, 1 reply; 53+ messages in thread
From: dick.r.chiang @ 2020-03-23 15:12 UTC (permalink / raw)
To: Mario Lang; +Cc: Jack Hill, emacs-devel
I'm afraid I'm the type of programmer who requires the tight feedback loop
that push access affords. I understand "moving fast and possibly breaking
things" is becoming increasingly out of fashion.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: ELPA: where is chess developed?
2020-03-23 15:12 ` dick.r.chiang
@ 2020-03-24 8:10 ` Philippe Vaucher
2020-03-24 11:38 ` dick.r.chiang
0 siblings, 1 reply; 53+ messages in thread
From: Philippe Vaucher @ 2020-03-24 8:10 UTC (permalink / raw)
To: dick.r.chiang; +Cc: Mario Lang, Jack Hill, Emacs developers
[-- Attachment #1: Type: text/plain, Size: 496 bytes --]
On Mon, Mar 23, 2020 at 4:13 PM <dick.r.chiang@gmail.com> wrote:
> I'm afraid I'm the type of programmer who requires the tight feedback loop
> that push access affords. I understand "moving fast and possibly breaking
> things" is becoming increasingly out of fashion.
>
Just curious, can you elaborate why the ability to push gives you a tight
feedback loop?
I often work with repositories where I have several remotes, maybe there's
a missunderstanding I can clear.
Kind regards,
Philippe
[-- Attachment #2: Type: text/html, Size: 917 bytes --]
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: ELPA: where is chess developed?
2020-03-24 8:10 ` Philippe Vaucher
@ 2020-03-24 11:38 ` dick.r.chiang
2020-03-24 11:54 ` Philippe Vaucher
0 siblings, 1 reply; 53+ messages in thread
From: dick.r.chiang @ 2020-03-24 11:38 UTC (permalink / raw)
To: Philippe Vaucher; +Cc: Mario Lang, Jack Hill, Emacs developers
> Just curious, can you elaborate why the ability to push gives you a tight
> feedback loop?
Notice how belabored the email-patch mechanism is for prospective
contributors without push access. Nature of the beast I'm afraid... there's
always at least one niggling fixup for the smallest patch submission, and for a
50-commit-behind-50-commit-ahead merge, there's going to be order of 10
fixups. The verbal back-and-forth required is prohibitively costly for a
largely inactive repo like emacs-chess.
The web-based "pull request" mechanism is much more sane than iterating emails
as it's always clear which of the author's iterations is latest, but that's a
separate issue.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: ELPA: where is chess developed?
2020-03-24 11:38 ` dick.r.chiang
@ 2020-03-24 11:54 ` Philippe Vaucher
2020-03-27 2:59 ` pull requests Richard Stallman
0 siblings, 1 reply; 53+ messages in thread
From: Philippe Vaucher @ 2020-03-24 11:54 UTC (permalink / raw)
To: dick.r.chiang; +Cc: Mario Lang, Jack Hill, Emacs developers
[-- Attachment #1: Type: text/plain, Size: 1003 bytes --]
> > Just curious, can you elaborate why the ability to push gives you a tight
> > feedback loop?
>
> Notice how belabored the email-patch mechanism is for prospective
> contributors without push access. Nature of the beast I'm afraid...
> there's
> always at least one niggling fixup for the smallest patch submission, and
> for a
> 50-commit-behind-50-commit-ahead merge, there's going to be order of 10
> fixups. The verbal back-and-forth required is prohibitively costly for a
> largely inactive repo like emacs-chess.
>
> The web-based "pull request" mechanism is much more sane than iterating
> emails
> as it's always clear which of the author's iterations is latest, but
> that's a
> separate issue.
>
Ah, I understood something else. I agree with what you say.
Question for maintainers: is it actually mandatory that all changes are
submitted through patches on the ML? If we need to submit lot of
patches, can we just point to an external repository on some branch?
Kind regards,
Philippe
[-- Attachment #2: Type: text/html, Size: 1371 bytes --]
^ permalink raw reply [flat|nested] 53+ messages in thread
* pull requests
2020-03-24 11:54 ` Philippe Vaucher
@ 2020-03-27 2:59 ` Richard Stallman
2020-03-27 3:49 ` Stefan Monnier
2020-03-27 7:54 ` Eli Zaretskii
0 siblings, 2 replies; 53+ messages in thread
From: Richard Stallman @ 2020-03-27 2:59 UTC (permalink / raw)
To: Philippe Vaucher; +Cc: mlang, jackhill, dick.r.chiang, emacs-devel
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
We had a discussion last year about support for pull requests. The
problem that we identified last year is that allowing proposed patches
into a GNU forge breaks down the simple wall between what the GNU
Project distributes and users' changes.
In place of that simple wall, there would be a criterion that requires
judgment. Emacs developers would understand that criterion, but the
public and the courts would not reliably understand. This could cause
problems of a legal nature, problems of a moral nature, and problems
of explanation.
The legal problems: there could be code without copyright assignments.
The moral problems: there could be code that isn't free.
The explanatoy problems: there could be code or comments that contradict
our message.
I don't remember the precise conclusions last year, but ISTR I
concluded that any pull requests on a GNU forge must be visible _only_
to the developers of the package.
Can someone find that previous discussion and show its actual conclusions?
With a single Message-ID field I could find the discussion.
> Question for maintainers: is it actually mandatory that all changes are
> submitted through patches on the ML? If we need to submit lot of
> patches, can we just point to an external repository on some branch?
I don't feel confident I understand that concretely -- what precisely
would be "on some branch"?
Maybe it is ok to point to an external repository in an email to
emacs-devel. I'd want to have a discussion of that, but I tend to
think that if done properly it is basically equivalent to emailing the
patches themselves to emacs-devel.
The external repo should not be on a site such as GitHub that requires
Javascript to do things users will want to do with that repo. And it
should be clearly labeled as "XYZ's patched version of GNU Emacs M.N,
containing changes submitted for installation."
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 2:59 ` pull requests Richard Stallman
@ 2020-03-27 3:49 ` Stefan Monnier
2020-03-28 2:45 ` Richard Stallman
2020-03-27 7:54 ` Eli Zaretskii
1 sibling, 1 reply; 53+ messages in thread
From: Stefan Monnier @ 2020-03-27 3:49 UTC (permalink / raw)
To: Richard Stallman
Cc: mlang, Philippe Vaucher, emacs-devel, jackhill, dick.r.chiang
> In place of that simple wall, there would be a criterion that requires
> judgment. Emacs developers would understand that criterion, but the
> public and the courts would not reliably understand. This could cause
> problems of a legal nature, problems of a moral nature, and problems
> of explanation.
>
> The legal problems: there could be code without copyright assignments.
I don't see the problem: many packages on Savannah don't have their
copyright assigned to the FSF, so the FSF's servers have been
distributing code without copyright assignments for years already.
Nothing new here.
Stefan
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 3:49 ` Stefan Monnier
@ 2020-03-28 2:45 ` Richard Stallman
2020-03-28 3:03 ` Stefan Monnier
0 siblings, 1 reply; 53+ messages in thread
From: Richard Stallman @ 2020-03-28 2:45 UTC (permalink / raw)
To: Stefan Monnier
Cc: mlang, philippe.vaucher, emacs-devel, jackhill, dick.r.chiang
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
> > The legal problems: there could be code without copyright assignments.
> I don't see the problem: many packages on Savannah don't have their
> copyright assigned to the FSF, so the FSF's servers have been
> distributing code without copyright assignments for years already.
You have equated two different kinds of cases:
FSF-copyrighted packages and non-FSF-copyrighted packages.
Emacs is an FSF-copyrighted package, so we do not allow code into
the repo unless it has a copyright assignment.
This is a legal policy, not a technical one. To change it for
merely technical reasons would be to let the tail wag the dog.
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-28 2:45 ` Richard Stallman
@ 2020-03-28 3:03 ` Stefan Monnier
0 siblings, 0 replies; 53+ messages in thread
From: Stefan Monnier @ 2020-03-28 3:03 UTC (permalink / raw)
To: Richard Stallman
Cc: mlang, philippe.vaucher, emacs-devel, jackhill, dick.r.chiang
> > > The legal problems: there could be code without copyright assignments.
> > I don't see the problem: many packages on Savannah don't have their
> > copyright assigned to the FSF, so the FSF's servers have been
> > distributing code without copyright assignments for years already.
> You have equated two different kinds of cases:
> FSF-copyrighted packages and non-FSF-copyrighted packages.
> Emacs is an FSF-copyrighted package, so we do not allow code into
> the repo unless it has a copyright assignment.
Yes, but it's a choice we make. Not following it wouldn't get us into
legal trouble.
> This is a legal policy, not a technical one.
It's a strategic decision, AFAIK, i.e. dictated neither by technical nor
legal requirements. Which is why the GNU project applies to some
packages and not all.
> To change it for merely technical reasons would be to let the tail wag
> the dog.
I was not arguing to change this policy. I was just pointing out that
whether or not there is non-assigned Emacs-related code somewhere on
gnu.org is not a legal problem, AFAIK. Neither do I think it would
weaken the FSF's hand in case it had to defend its copyright on the
actual Emacs code (assuming we keep following the policy that we only
accept copyright-assigned code into it, obviously).
Stefan
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 2:59 ` pull requests Richard Stallman
2020-03-27 3:49 ` Stefan Monnier
@ 2020-03-27 7:54 ` Eli Zaretskii
2020-03-27 13:00 ` Clément Pit-Claudel
2020-03-28 2:46 ` Richard Stallman
1 sibling, 2 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-27 7:54 UTC (permalink / raw)
To: rms; +Cc: mlang, philippe.vaucher, emacs-devel, jackhill, dick.r.chiang
> From: Richard Stallman <rms@gnu.org>
> Date: Thu, 26 Mar 2020 22:59:35 -0400
> Cc: mlang@delysid.org, jackhill@jackhill.us, dick.r.chiang@gmail.com,
> emacs-devel@gnu.org
>
> I don't remember the precise conclusions last year, but ISTR I
> concluded that any pull requests on a GNU forge must be visible _only_
> to the developers of the package.
IIRC, the most important, at least IMO, conclusion was that we should
host such services on savannah.nongnu.org, so that any code in those
pull requests is not considered to "belong to GNU".
> Can someone find that previous discussion and show its actual conclusions?
> With a single Message-ID field I could find the discussion.
It was on gnu-prog-discuss, not here. One message-ID I have from that
discussion is 871rv8suni.fsf@gnu.org.
There was some "shadow" of that in this mailing list in last November,
try message-ID 83sgmhxp1i.fsf@gnu.org.
> > Question for maintainers: is it actually mandatory that all changes are
> > submitted through patches on the ML? If we need to submit lot of
> > patches, can we just point to an external repository on some branch?
>
> I don't feel confident I understand that concretely -- what precisely
> would be "on some branch"?
>
> Maybe it is ok to point to an external repository in an email to
> emacs-devel. I'd want to have a discussion of that, but I tend to
> think that if done properly it is basically equivalent to emailing the
> patches themselves to emacs-devel.
That's a different proposal altogether, AFAIU. From my POV, it makes
the lives of those who submit patches easier, but complicates the
lives of those who review patches, because pulling those changes into
our local repository for testing them is then more complex, and
requires access to Git servers about whose security we may not know
enough to feel confident. More importantly, given that I did a review
of such a remote branch, how do I communicate my comments so that they
are recorded for posterity? Probably by email, so that doesn't seem
to solve the main problem of avoiding email in the patch submission
and review workflow.
Btw, for an independent lookout and POV of these and related issues,
please see this recent discussion on the GCC mailing list:
https://gcc.gnu.org/pipermail/gcc/2020-March/000113.html
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 7:54 ` Eli Zaretskii
@ 2020-03-27 13:00 ` Clément Pit-Claudel
2020-03-27 13:30 ` Eli Zaretskii
2020-03-27 14:05 ` Stefan Monnier
2020-03-28 2:46 ` Richard Stallman
1 sibling, 2 replies; 53+ messages in thread
From: Clément Pit-Claudel @ 2020-03-27 13:00 UTC (permalink / raw)
To: emacs-devel
On 27/03/2020 03.54, Eli Zaretskii wrote:
> More importantly, given that I did a review
> of such a remote branch, how do I communicate my comments so that they
> are recorded for posterity? Probably by email, so that doesn't seem
> to solve the main problem of avoiding email in the patch submission
> and review workflow.
Assuming you use the web UI, you can typically attach comments to code regions.
Pros over email reviews include the fact that the comments remain attached to the code even after the patch is updated (so if the original author updates an unrelated section of the patch the comments don't disappear) and the fact that you get to see the full code, rather than just the patch.
Cons include inferior text-editing capabilities, and inferior code browsing capabilities compared to applying the patch and browsing around in Emacs (but you can always checkout the branch, which I find nicer than applying patches by hand anyway).
Clément.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 13:00 ` Clément Pit-Claudel
@ 2020-03-27 13:30 ` Eli Zaretskii
2020-03-27 14:37 ` Clément Pit-Claudel
2020-03-27 14:05 ` Stefan Monnier
1 sibling, 1 reply; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-27 13:30 UTC (permalink / raw)
To: Clément Pit-Claudel; +Cc: emacs-devel
> From: Clément Pit-Claudel <cpitclaudel@gmail.com>
> Date: Fri, 27 Mar 2020 09:00:10 -0400
>
> On 27/03/2020 03.54, Eli Zaretskii wrote:
> > More importantly, given that I did a review
> > of such a remote branch, how do I communicate my comments so that they
> > are recorded for posterity? Probably by email, so that doesn't seem
> > to solve the main problem of avoiding email in the patch submission
> > and review workflow.
>
> Assuming you use the web UI, you can typically attach comments to code regions.
And how does one point to such past discussions, or more generally
make sure they end up in some centralized place we could later
revisit?
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 13:30 ` Eli Zaretskii
@ 2020-03-27 14:37 ` Clément Pit-Claudel
2020-03-27 15:21 ` Eli Zaretskii
0 siblings, 1 reply; 53+ messages in thread
From: Clément Pit-Claudel @ 2020-03-27 14:37 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
On 27/03/2020 09.30, Eli Zaretskii wrote:
>> From: Clément Pit-Claudel <cpitclaudel@gmail.com>
>> Date: Fri, 27 Mar 2020 09:00:10 -0400
>>
>> On 27/03/2020 03.54, Eli Zaretskii wrote:
>>> More importantly, given that I did a review
>>> of such a remote branch, how do I communicate my comments so that they
>>> are recorded for posterity? Probably by email, so that doesn't seem
>>> to solve the main problem of avoiding email in the patch submission
>>> and review workflow.
>>
>> Assuming you use the web UI, you can typically attach comments to code regions.
>
> And how does one point to such past discussions, or more generally
> make sure they end up in some centralized place we could later
> revisit?
These comments survive even after the pull request is merged, so the tracker that hosted the discussion and the code comments acts as that centralized place.
Here is a good example, from GTK, which moved to gitlab a while ago with the rest of Gnome: https://gitlab.gnome.org/GNOME/gtk/-/merge_requests/1158 (gitlab calls them "merge requests")
On that page you can see many sections that say `… started a thread on an outdated change`. This means that a project maintainer (or anyone, really) commented on part of the patch, then the original patch author (or anyone able to push to the corresponding branch) updated the code (hence the "outdated" part — but note that the diff under discussion is still available). The part that says `Resolved by … 4 months ago' means that the author or the original commenter indicated that the particular point under discussion had been resoled, so that discussion is now hidden by default to reduce noise.
Here is another example, from nautilus: https://gitlab.gnome.org/GNOME/nautilus/-/merge_requests/417. In both cases the changes have been applied to the master branch ("merged"), but the discussion persists in the tracker.
HTH,
Clément.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 14:37 ` Clément Pit-Claudel
@ 2020-03-27 15:21 ` Eli Zaretskii
2020-03-27 15:41 ` Dmitry Gutov
2020-03-27 16:39 ` Clément Pit-Claudel
0 siblings, 2 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-27 15:21 UTC (permalink / raw)
To: Clément Pit-Claudel; +Cc: emacs-devel
> Cc: emacs-devel@gnu.org
> From: Clément Pit-Claudel <cpitclaudel@gmail.com>
> Date: Fri, 27 Mar 2020 10:37:38 -0400
>
> >> Assuming you use the web UI, you can typically attach comments to code regions.
> >
> > And how does one point to such past discussions, or more generally
> > make sure they end up in some centralized place we could later
> > revisit?
>
> These comments survive even after the pull request is merged, so the tracker that hosted the discussion and the code comments acts as that centralized place.
So we are supposed to keep pointers to those sites, and use them? How
do we know which site holds what relevant discussions? who will
remember that several years after the discussion took place? And what
if the tracker that hosted the discussion goes dark (e.g., because the
person who submitted the patch is no longer keeping the branch, or
simply because the hosting service is discontinued?
I really don't see how a project that is 30-something years old, and
intends to live for several more decades, can possibly rely on such
infrastructure for discussions that might prove important years from
now. We must have all these archives in a single place, which we can
control and which we can ensure continues to be available for years to
come.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 15:21 ` Eli Zaretskii
@ 2020-03-27 15:41 ` Dmitry Gutov
2020-03-27 19:16 ` Eli Zaretskii
` (2 more replies)
2020-03-27 16:39 ` Clément Pit-Claudel
1 sibling, 3 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-27 15:41 UTC (permalink / raw)
To: Eli Zaretskii, Clément Pit-Claudel; +Cc: emacs-devel
On 27.03.2020 17:21, Eli Zaretskii wrote:
> So we are supposed to keep pointers to those sites, and use them? How
> do we know which site holds what relevant discussions? who will
> remember that several years after the discussion took place?
"The site" is the forge we would be using. E.g. a local installation of
Gitlab, known to all. Or some other forge software.
> And what
> if the tracker that hosted the discussion goes dark (e.g., because the
> person who submitted the patch is no longer keeping the branch, or
> simply because the hosting service is discontinued?
One more reason to host PRs on the official forge installation, not on
some faraway mirrors.
Nobody mistakes submitted patches on the mailing list for the official
GNU code. There is no reason for anyone to mistake the submitted PRs for
that either.
That section is literally "contributions under consideration", why would
anyone think it's the project code already?
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 15:41 ` Dmitry Gutov
@ 2020-03-27 19:16 ` Eli Zaretskii
2020-03-27 19:24 ` Dmitry Gutov
2020-03-27 19:34 ` 조성빈
2020-03-27 19:28 ` Eli Zaretskii
2020-03-28 2:46 ` Richard Stallman
2 siblings, 2 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-27 19:16 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: cpitclaudel, emacs-devel
> Cc: emacs-devel@gnu.org
> From: Dmitry Gutov <dgutov@yandex.ru>
> Date: Fri, 27 Mar 2020 17:41:00 +0200
>
> On 27.03.2020 17:21, Eli Zaretskii wrote:
> > So we are supposed to keep pointers to those sites, and use them? How
> > do we know which site holds what relevant discussions? who will
> > remember that several years after the discussion took place?
>
> "The site" is the forge we would be using. E.g. a local installation of
> Gitlab, known to all. Or some other forge software.
That's not the proposal that prompted Clément's comments and my
response. It was a proposal to have us review patches on remote
branches that people push to their own repositories. See
https://lists.gnu.org/archive/html/emacs-devel/2020-03/msg00617.html
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 19:16 ` Eli Zaretskii
@ 2020-03-27 19:24 ` Dmitry Gutov
2020-03-27 19:34 ` 조성빈
1 sibling, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-27 19:24 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, emacs-devel
On 27.03.2020 21:16, Eli Zaretskii wrote:
> That's not the proposal that prompted Clément's comments and my
> response. It was a proposal to have us review patches on remote
> branches that people push to their own repositories. See
>
> https://lists.gnu.org/archive/html/emacs-devel/2020-03/msg00617.html
OK, in that case I agree it's not a great choice.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 19:16 ` Eli Zaretskii
2020-03-27 19:24 ` Dmitry Gutov
@ 2020-03-27 19:34 ` 조성빈
1 sibling, 0 replies; 53+ messages in thread
From: 조성빈 @ 2020-03-27 19:34 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Dmitry Gutov, cpitclaudel, Emacs-devel
> 2020. 3. 28. 오전 4:17, Eli Zaretskii <eliz@gnu.org> 작성:
>
>
>>
>> Cc: emacs-devel@gnu.org
>> From: Dmitry Gutov <dgutov@yandex.ru>
>> Date: Fri, 27 Mar 2020 17:41:00 +0200
>>
>>> On 27.03.2020 17:21, Eli Zaretskii wrote:
>>> So we are supposed to keep pointers to those sites, and use them? How
>>> do we know which site holds what relevant discussions? who will
>>> remember that several years after the discussion took place?
>>
>> "The site" is the forge we would be using. E.g. a local installation of
>> Gitlab, known to all. Or some other forge software.
>
> That's not the proposal that prompted Clément's comments and my
> response. It was a proposal to have us review patches on remote
> branches that people push to their own repositories. See
>
> https://lists.gnu.org/archive/html/emacs-devel/2020-03/msg00617.html
>
My understanding was that the contributor wanted push access to a branch because one didn’t like the convoluted email-patch workflow, but getting push access to ELPA is hard so one wanted to point another beach firm an external repo(which he has push access to).
Which would mean if there can be a (nongnu) forge that people can ‘fork’ the Emacs/ELPA repo, commit/push and open a PR to the main repo, one wouldn’t need to point to an external repo. One could just point to a fork of repo on the nongnu forge in this case.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 15:41 ` Dmitry Gutov
2020-03-27 19:16 ` Eli Zaretskii
@ 2020-03-27 19:28 ` Eli Zaretskii
2020-03-27 20:39 ` Dmitry Gutov
2020-03-28 2:46 ` Richard Stallman
2 siblings, 1 reply; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-27 19:28 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: cpitclaudel, emacs-devel
> From: Dmitry Gutov <dgutov@yandex.ru>
> Date: Fri, 27 Mar 2020 17:41:00 +0200
> Cc: emacs-devel@gnu.org
>
> One more reason to host PRs on the official forge installation, not on
> some faraway mirrors.
>
> Nobody mistakes submitted patches on the mailing list for the official
> GNU code. There is no reason for anyone to mistake the submitted PRs for
> that either.
>
> That section is literally "contributions under consideration", why would
> anyone think it's the project code already?
This is a different discussion. We had that at least twice in the
past, we identified the issues that need to be resolved for us to
start the migration, and from my POV we are waiting for volunteers to
work on resolving those issues.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 19:28 ` Eli Zaretskii
@ 2020-03-27 20:39 ` Dmitry Gutov
0 siblings, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-27 20:39 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, emacs-devel
On 27.03.2020 21:28, Eli Zaretskii wrote:
>> That section is literally "contributions under consideration", why would
>> anyone think it's the project code already?
>
> This is a different discussion. We had that at least twice in the
> past, we identified the issues that need to be resolved for us to
> start the migration, and from my POV we are waiting for volunteers to
> work on resolving those issues.
Ah, very good. Thanks for confirming that.
Because the recent sentiments expressed by fellow developers about Web
UIs, etc, looked kind of discouraging. Richard's conclusion that PRs
can't be publicly-accessible would also be a complication, and also
something of a missed opportunity WRT making the development process
more accessible and visible to the public.
Reading the news about FSF evaluating forge softwares, I figured that's
the best change for us to get something similar in Emacs development.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 15:41 ` Dmitry Gutov
2020-03-27 19:16 ` Eli Zaretskii
2020-03-27 19:28 ` Eli Zaretskii
@ 2020-03-28 2:46 ` Richard Stallman
2020-03-28 17:14 ` Dmitry Gutov
2 siblings, 1 reply; 53+ messages in thread
From: Richard Stallman @ 2020-03-28 2:46 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: eliz, cpitclaudel, emacs-devel
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
> That section is literally "contributions under consideration",
That is a statement of intentions, not facts. Emacs developers
would know those intentions, but other Emacs users might have no
idea about them.
why would
> anyone think it's the project code already?
Why wouldn't anyone thing so? Are you proposing to display a message
of explanation whenever someone tries to view the code in a pull request?
Suppose A sends B a URL pointing to a branch with non-installed
patches. If A doesn't warn B; if A is too terse and does not make the
point clear, B will not know it is non-installed. B will only see
that it is in the standard GNU Emacs repo.
This is asking for big trouble. Versions of Emacs that by policy
we should not be distributing could start being distributed in that way,
and no responsible person would ever be asked whether to do this.
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-28 2:46 ` Richard Stallman
@ 2020-03-28 17:14 ` Dmitry Gutov
2020-03-30 3:38 ` Richard Stallman
0 siblings, 1 reply; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-28 17:14 UTC (permalink / raw)
To: rms; +Cc: eliz, cpitclaudel, emacs-devel
On 28.03.2020 04:46, Richard Stallman wrote:
> [[[ To any NSA and FBI agents reading my email: please consider ]]]
> [[[ whether defending the US Constitution against all enemies, ]]]
> [[[ foreign or domestic, requires you to follow Snowden's example. ]]]
>
> > That section is literally "contributions under consideration",
>
> That is a statement of intentions, not facts. Emacs developers
> would know those intentions, but other Emacs users might have no
> idea about them.
That's why we have forges, with self-explanatory web interfaces and even
integrated help for new users.
> why would
> > anyone think it's the project code already?
>
> Why wouldn't anyone thing so? Are you proposing to display a message
> of explanation whenever someone tries to view the code in a pull request?
99% of the users who would be looking at them, would be doing so through
the web interface of the force software. And at that web page it would
be made apparent that the user is looking at a pull request.
> Suppose A sends B a URL pointing to a branch with non-installed
> patches. If A doesn't warn B; if A is too terse and does not make the
> point clear, B will not know it is non-installed. B will only see
> that it is in the standard GNU Emacs repo.
When you were talking about hiding PRs from non-developers, you meant
hiding in the web interface, right? Because it would be hard to hide
them in the mailing lists, for example, considering they're all public.
Anyway, if the branch is not called master or emacs-xx, then it's
relatively obvious that it contains some code that is yet to incorporated.
> This is asking for big trouble. Versions of Emacs that by policy
> we should not be distributing could start being distributed in that way,
> and no responsible person would ever be asked whether to do this.
As per above, I think it would be hard to mistake a non-official branch
for an official one. But that brings us to the question of whether we
would allow unauthenticated users to create new branches in our forge.
The previous discussion concluded on "probably not", and then the
situation is not different from the current one: pull requests (or
"merge requests") would be created only by the current developers who
have commit access.
But if we manage to support merge requests from contributors without
commit access, and do it without external repositories, we could just as
well mandate that all such branches have names prefixed with
"merge-request/", and that will avoid any confusion.
Also, if any branches in our repo end up containing really problematic
code, I'm sure that can be dealt with on a case-by-case basis.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-28 17:14 ` Dmitry Gutov
@ 2020-03-30 3:38 ` Richard Stallman
2020-03-30 4:09 ` Stefan Monnier
` (2 more replies)
0 siblings, 3 replies; 53+ messages in thread
From: Richard Stallman @ 2020-03-30 3:38 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: eliz, cpitclaudel, emacs-devel
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
> > That is a statement of intentions, not facts. Emacs developers
> > would know those intentions, but other Emacs users might have no
> > idea about them.
> That's why we have forges, with self-explanatory web interfaces and even
> integrated help for new users.
That would inform some users, those who do certain things. But in the
scenario I pointed at, the users would not do those things, so they
would not get the information.
This is the scenario I pointed at:
Suppose A sends B a URL pointing to a branch with non-installed
patches. If A doesn't warn B, or if A is too terse and does not make the
point clear, B will not know it is non-installed. B will only see
that it is in the standard GNU Emacs repo.
> 99% of the users who would be looking at them, would be doing so through
> the web interface of the force software.
In that scenario, large numbers of users might not go through that interface.
They might not even know there is a web interface.
> When you were talking about hiding PRs from non-developers, you meant
> hiding in the web interface, right?
I mean blocking access to them _in the repo_, for all interfaces. If
you're not logged in as a member of the project, you would not be
allowed to check out that branch by running git.
Because it would be hard to hide
> them in the mailing lists,
The mailing list is a different kind issue. If you abstract away
the practical differences, you might think it is the same; but those
practicalities change everything, in this case.
I am not talking about adding security where we have done ok without
it. My aim is to limit the possible new danger from the change that
you are asking for.
I know that many other projects use pull requests and are happy with them.
But those projects do not share our nontechnical overriding goals:
* Do not distribute nonfree software.
* Do not publish text that recommends nonfree software.
* For some projects, do not include code without legal papers.
We have a system for avoiding this: the package maintainers decide
what to install, and they check these criteria before installing
anything. (See the GNU Coding Standards and GNU Maintainer's Guide.)
Keeping uninstalled code in the same repo as the installed code makes
it too easy to overlook the difference between them.
> But if we manage to support merge requests from contributors without
> commit access, and do it without external repositories, we could just as
> well mandate that all such branches have names prefixed with
> "merge-request/", and that will avoid any confusion.
I am not convinced it would work "just as well." But that idea is
worth thinking about. we need to think _not only_ about how we would
intend this facility to be used, but also how to make sure it is not
misused.
How, in practice, would we ensure that all installation proposals
have a name starting with 'merge-request/'?
How would we find out if many users begin accessing a branch whose
name begins with 'merge-request/'?
How would we find out if one is created with a name that doesn't
start with that prefix?
Could we arrange that those branches start out accessible only to
maintainers, then become generally accessible when a maintainer says
"Make this accessible"?
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 3:38 ` Richard Stallman
@ 2020-03-30 4:09 ` Stefan Monnier
2020-03-30 5:58 ` Eli Zaretskii
2020-03-30 8:25 ` 조성빈
2020-03-30 17:49 ` Dmitry Gutov
2 siblings, 1 reply; 53+ messages in thread
From: Stefan Monnier @ 2020-03-30 4:09 UTC (permalink / raw)
To: Richard Stallman; +Cc: eliz, emacs-devel, cpitclaudel, Dmitry Gutov
> Suppose A sends B a URL pointing to a branch with non-installed
> patches. If A doesn't warn B, or if A is too terse and does not make the
> point clear, B will not know it is non-installed. B will only see
> that it is in the standard GNU Emacs repo.
[...]
> In that scenario, large numbers of users might not go through that interface.
> They might not even know there is a web interface.
I don't follow: in all likelihood, that URL that A sends to B points to
the web interface (at least, that's what I saw in 100% of the cases
with github and gitlab).
Stefan
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 4:09 ` Stefan Monnier
@ 2020-03-30 5:58 ` Eli Zaretskii
2020-03-30 12:03 ` Dmitry Gutov
2020-03-30 13:43 ` Stefan Monnier
0 siblings, 2 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-30 5:58 UTC (permalink / raw)
To: emacs-devel, Stefan Monnier, Richard Stallman; +Cc: cpitclaudel, Dmitry Gutov
On March 30, 2020 7:09:55 AM GMT+03:00, Stefan Monnier <monnier@iro.umontreal.ca> wrote:
>
> I don't follow: in all likelihood, that URL that A sends to B points
> to
> the web interface (at least, that's what I saw in 100% of the cases
> with github and gitlab).
>
IME, that URL is both for the Web interface and for accessing the repository. If you point a browser there, you get the Web interface; if you clone from that URL, you get the code.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 5:58 ` Eli Zaretskii
@ 2020-03-30 12:03 ` Dmitry Gutov
2020-03-30 12:55 ` Yuri Khan
2020-03-30 13:12 ` Eli Zaretskii
2020-03-30 13:43 ` Stefan Monnier
1 sibling, 2 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 12:03 UTC (permalink / raw)
To: Eli Zaretskii, emacs-devel, Stefan Monnier, Richard Stallman; +Cc: cpitclaudel
On 30.03.2020 08:58, Eli Zaretskii wrote:
> IME, that URL is both for the Web interface and for accessing the repository. If you point a browser there, you get the Web interface; if you clone from that URL, you get the code.
Is that right?
I wasn't able to 'git clone'
https://emba.gnu.org/emacs/emacs/-/merge_requests/1
or
https://gitlab.com/eufs/eufs_sim/-/merge_requests/38
(the second one is definitely publicly available).
And anyway, it's a URL with the words "merge request" in it. So nobody
should mistake it for an official distribution of any sort.
The only possibility of a mistake I was discussing was somebody linking
for the branch directly (which is not something people do often), or
basically intentional abuse of our code hosting platform.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 12:03 ` Dmitry Gutov
@ 2020-03-30 12:55 ` Yuri Khan
2020-03-30 13:12 ` Eli Zaretskii
1 sibling, 0 replies; 53+ messages in thread
From: Yuri Khan @ 2020-03-30 12:55 UTC (permalink / raw)
To: Dmitry Gutov
Cc: Eli Zaretskii, Clément Pit-Claudel, Stefan Monnier,
Richard Stallman, Emacs developers
On Mon, 30 Mar 2020 at 19:04, Dmitry Gutov <dgutov@yandex.ru> wrote:
> I wasn't able to 'git clone'
>
> https://gitlab.com/eufs/eufs_sim/-/merge_requests/38
You do not clone a branch. You clone a repository and check out a
merge request branch from it. And that branch is in a namespace that
does not get fetched by default, you have to do some [non-trivial
dance][1] to fetch it.
[1]: https://docs.gitlab.com/ee/user/project/merge_requests/reviewing_and_managing_merge_requests.html#checkout-merge-requests-locally
$ git clone https://gitlab.com/eufs/eufs_sim
$ git fetch origin merge-requests/38/head:mr-38
$ git checkout mr-38
There is no possibility that somebody will do that by mistake and
assume an official distribution.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 12:03 ` Dmitry Gutov
2020-03-30 12:55 ` Yuri Khan
@ 2020-03-30 13:12 ` Eli Zaretskii
2020-03-30 13:50 ` Dmitry Gutov
1 sibling, 1 reply; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-30 13:12 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: cpitclaudel, monnier, rms, emacs-devel
> Cc: cpitclaudel@gmail.com
> From: Dmitry Gutov <dgutov@yandex.ru>
> Date: Mon, 30 Mar 2020 15:03:36 +0300
>
> On 30.03.2020 08:58, Eli Zaretskii wrote:
> > IME, that URL is both for the Web interface and for accessing the repository. If you point a browser there, you get the Web interface; if you clone from that URL, you get the code.
>
> Is that right?
>
> I wasn't able to 'git clone'
>
> https://emba.gnu.org/emacs/emacs/-/merge_requests/1
>
> or
>
> https://gitlab.com/eufs/eufs_sim/-/merge_requests/38
Try the repo URL, not the merge-request URL. People point to the repo
very frequently, you can find such references even in this list.
> The only possibility of a mistake I was discussing was somebody linking
> for the branch directly (which is not something people do often), or
> basically intentional abuse of our code hosting platform.
That is what happens, yes.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 13:12 ` Eli Zaretskii
@ 2020-03-30 13:50 ` Dmitry Gutov
2020-03-30 14:12 ` Eli Zaretskii
0 siblings, 1 reply; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 13:50 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, monnier, rms, emacs-devel
On 30.03.2020 16:12, Eli Zaretskii wrote:
> Try the repo URL, not the merge-request URL. People point to the repo
> very frequently, you can find such references even in this list.
That seems irrelevant to the question of showing or hiding merge
requests. It's orthogonal.
It's an issue of whether to co-host several repositories, which I agree
is pertinent, but since GitLab doesn't support fast forking, is too
early to discuss.
And in the approach we've been discussing (AFAIU) there will be only one
repo, and as such only one repo URL.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 13:50 ` Dmitry Gutov
@ 2020-03-30 14:12 ` Eli Zaretskii
2020-03-30 14:34 ` Dmitry Gutov
0 siblings, 1 reply; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-30 14:12 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: cpitclaudel, monnier, rms, emacs-devel
> Cc: emacs-devel@gnu.org, monnier@iro.umontreal.ca, rms@gnu.org,
> cpitclaudel@gmail.com
> From: Dmitry Gutov <dgutov@yandex.ru>
> Date: Mon, 30 Mar 2020 16:50:59 +0300
>
> On 30.03.2020 16:12, Eli Zaretskii wrote:
> > Try the repo URL, not the merge-request URL. People point to the repo
> > very frequently, you can find such references even in this list.
>
> That seems irrelevant to the question of showing or hiding merge
> requests. It's orthogonal.
It is relevant because I've seen people pointing to the repository,
not to a specific branch or merge request.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 14:12 ` Eli Zaretskii
@ 2020-03-30 14:34 ` Dmitry Gutov
2020-03-30 15:36 ` Eli Zaretskii
0 siblings, 1 reply; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 14:34 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, monnier, rms, emacs-devel
On 30.03.2020 17:12, Eli Zaretskii wrote:
> It is relevant because I've seen people pointing to the repository,
> not to a specific branch or merge request.
You can't point to the wrong repository when there's just one
(canonical) repository.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 14:34 ` Dmitry Gutov
@ 2020-03-30 15:36 ` Eli Zaretskii
2020-03-30 15:50 ` Dmitry Gutov
0 siblings, 1 reply; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-30 15:36 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: cpitclaudel, monnier, rms, emacs-devel
> Cc: emacs-devel@gnu.org, monnier@iro.umontreal.ca, rms@gnu.org,
> cpitclaudel@gmail.com
> From: Dmitry Gutov <dgutov@yandex.ru>
> Date: Mon, 30 Mar 2020 17:34:05 +0300
>
> On 30.03.2020 17:12, Eli Zaretskii wrote:
> > It is relevant because I've seen people pointing to the repository,
> > not to a specific branch or merge request.
>
> You can't point to the wrong repository when there's just one
> (canonical) repository.
Which is exactly the problem: that people will think what they get is
canonical codebase, all of it.
Anyway, I don't understand why we are still arguing. The basic
guidelines to go by were agreed upon many moons ago, what's left is
for motivated individuals who have enough time on their hands to make
this happen.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 15:36 ` Eli Zaretskii
@ 2020-03-30 15:50 ` Dmitry Gutov
2020-03-30 16:09 ` Eli Zaretskii
0 siblings, 1 reply; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 15:50 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, monnier, rms, emacs-devel
On 30.03.2020 18:36, Eli Zaretskii wrote:
> Which is exactly the problem: that people will think what they get is
> canonical codebase, all of it.
I don't think so: anyone who's ever worked with branches knows that the
code in there only gets into the final product once merged into one of
the "main" ones. After which the branches are normally deleted.
> Anyway, I don't understand why we are still arguing. The basic
guidelines to go by were agreed upon many moons ago, what's left is
for motivated individuals who have enough time on their hands to make
this happen.
This discussion was revived when Richard said that pull requests should
be "hidden". Which is a novel request.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 15:50 ` Dmitry Gutov
@ 2020-03-30 16:09 ` Eli Zaretskii
2020-03-30 17:06 ` Dmitry Gutov
2020-04-02 2:39 ` Richard Stallman
0 siblings, 2 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-30 16:09 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: cpitclaudel, emacs-devel, monnier, rms
> From: Dmitry Gutov <dgutov@yandex.ru>
> Date: Mon, 30 Mar 2020 18:50:35 +0300
> Cc: cpitclaudel@gmail.com, monnier@iro.umontreal.ca, rms@gnu.org,
> emacs-devel@gnu.org
>
> This discussion was revived when Richard said that pull requests should
> be "hidden". Which is a novel request.
AFIU, that won't be necessary for hosting the repository used for pull
requests on nongnu.org.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 16:09 ` Eli Zaretskii
@ 2020-03-30 17:06 ` Dmitry Gutov
2020-03-30 17:13 ` Eli Zaretskii
2020-04-02 2:39 ` Richard Stallman
1 sibling, 1 reply; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 17:06 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, emacs-devel, monnier, rms
On 30.03.2020 19:09, Eli Zaretskii wrote:
>> This discussion was revived when Richard said that pull requests should
>> be "hidden". Which is a novel request.
> AFIU, that won't be necessary for hosting the repository used for pull
> requests on nongnu.org.
That only brings further questions.
How would that even work? AFAIK none of Github clones (Gitlab, etc)
support pull requests between separate installations. And it's
non-trivial to implement (and possibly harder to justify to Gitlab's
developers).
And without the "standard" PR automation we're back to the current state
of affairs: either send patches over email, or, okay, links to external
repositories and branches (you can recall yourself how often that happens).
More importantly: suppose we have a separate Gitlab installation in
nongnu.org. Who's going to be able to create new branches there? There
same current pool of Emacs developers? A separate list of people who ask
for access afterwards? Everyone? If it's the first option, I don't see
why we'd go to such great lengths at all: anyone who wanted to create
"bad" branches, can do so now in the current repo.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 17:06 ` Dmitry Gutov
@ 2020-03-30 17:13 ` Eli Zaretskii
0 siblings, 0 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-30 17:13 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: cpitclaudel, monnier, rms, emacs-devel
> From: Dmitry Gutov <dgutov@yandex.ru>
> Date: Mon, 30 Mar 2020 20:06:27 +0300
> Cc: cpitclaudel@gmail.com, emacs-devel@gnu.org, monnier@iro.umontreal.ca,
> rms@gnu.org
>
> That only brings further questions.
>
> How would that even work?
I don't know. Part of the job is to figure this out and set up
whatever is necessary for it to work. The FSF personnel who oversee
Savannah should be able to help some.
> More importantly: suppose we have a separate Gitlab installation in
> nongnu.org. Who's going to be able to create new branches there?
Should be possible for anyone, once this is separate from the official
GNU repository and on a separate server.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 16:09 ` Eli Zaretskii
2020-03-30 17:06 ` Dmitry Gutov
@ 2020-04-02 2:39 ` Richard Stallman
2020-04-17 3:54 ` Dmitry Gutov
1 sibling, 1 reply; 53+ messages in thread
From: Richard Stallman @ 2020-04-02 2:39 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, emacs-devel, monnier, dgutov
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
I have never seen what a pull request is like to use. I do not use
the systems which support them. In trying to think about their
implications, I have to go by the descriptions people have sent me
in this discussion.
Unfortunately, the descriptions I've reaceived seen to conflict.
Perhaps people were describing different ways that different projects
or different platforms handle pull requests, but I did not know that
when I read them.
Also, they are written to be read by people who have used pull
requests and basically understand them, which I do not. As a result,
I have trouble making sense of them.
I want to make sure we avoid results that would undermine the GNU
Project's moral and political position. For instance, the result of
distributing something that we say is an injustice and should not
exist at all.
Just what is required for this, in practical terms, depends on how we
would implement the pull requests. Some methods don't have a
problem; some do.
Could people figure out which different approaches they
are considering, then tell me how those approaches work?
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-04-02 2:39 ` Richard Stallman
@ 2020-04-17 3:54 ` Dmitry Gutov
0 siblings, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-04-17 3:54 UTC (permalink / raw)
To: rms, Eli Zaretskii; +Cc: cpitclaudel, monnier, emacs-devel
Hi Richard,
Sorry for the late reply. I'll try to make a good description.
On 02.04.2020 05:39, Richard Stallman wrote:
> [[[ To any NSA and FBI agents reading my email: please consider ]]]
> [[[ whether defending the US Constitution against all enemies, ]]]
> [[[ foreign or domestic, requires you to follow Snowden's example. ]]]
>
> I have never seen what a pull request is like to use. I do not use
> the systems which support them. In trying to think about their
> implications, I have to go by the descriptions people have sent me
> in this discussion.
>
> Unfortunately, the descriptions I've reaceived seen to conflict.
> Perhaps people were describing different ways that different projects
> or different platforms handle pull requests, but I did not know that
> when I read them.
AFAIK, there are basically two different things that are called a "pull
request".
The first is basically an email with details about the repository and
the branch you want code "pulled" from. There are more details here:
https://www.kernel.org/doc/html/latest/maintainer/pull-requests.html,
but this is largely irrelevant to this discussion because a) we can do
this already (and don't need any help with that), b) our developers and
contributors don't use this approach. So it's not what we've been
discussing.
The second one (which is what we're considering) has been popularized by
the proprietary code forge called GitHub. In there, users can make
'forks' of the original repository, where a fork is basically a copy of
the original repository that belongs to the user's account (and its URL
has the user's username in it). The said user can create a new branch,
push some changesets into it, and then propose the said branch to the
original repository and its developers for merging. By creating a "pull
request".
It's a "thing": Github, as well as similar forges such as Gitlab, have a
dedicated type of issue (*) that's called a "pull request". It has all
the features of an "issue" (which generally means people can leave
comments in it), as well as extra features: it shows the author, the
source branch, a multi-line description that the author usually has to
fill, the proposed commits, it can show the combined diff of those
commits, users can leave comments associated with individual lines of
that diff (and the UI displays that neatly), they can lead threaded
discussions on said commits (which get semi-hidden as soon as the
related code has changed), and the PR tracks the source branch closely,
so as soon as the user pushes some new changes to the branch, the
information in the PR updates automatically. The PR web page can show
the status of the CI build for the proposed branch. The main
repository's maintainers can merge the PR with just a couple of clicks
with the mouse (this works best with small contributions). There are
other features.
Overall, a lot of developers are used to this workflow and would never
choose patch submission over email. Of course, not everybody. Some
people just don't like web interfaces, for example.
(*) Issues are basically bug reports, but people can use them for
discussions, support questions, and so on.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 5:58 ` Eli Zaretskii
2020-03-30 12:03 ` Dmitry Gutov
@ 2020-03-30 13:43 ` Stefan Monnier
2020-03-30 16:59 ` Dmitry Gutov
1 sibling, 1 reply; 53+ messages in thread
From: Stefan Monnier @ 2020-03-30 13:43 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: cpitclaudel, Dmitry Gutov, Richard Stallman, emacs-devel
>> I don't follow: in all likelihood, that URL that A sends to B points
>> to the web interface (at least, that's what I saw in 100% of the
>> cases with github and gitlab).
> IME, that URL is both for the Web interface and for accessing the
> repository. If you point a browser there, you get the Web interface; if you
> clone from that URL, you get the code.
This dual-use only applies to the URL of a whole Git repository.
Not for branches or pull requests.
If using "nongnu.org" is considered sufficient, then we could also have
a similar marker in the URL of non-official repositories
(i.e. personal repositories used to upload pull requests, I guess).
Of course, the need to have your own fork of a repository on github.com
in order to submit a pull request on some other repository on github.com
is a serious deficiency, IMO, and if we could use a system that does not
impose such a constraint it would be much better (both for me as a user
and for the FSF in terms of the resources they'd need to host that
system).
Stefan
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 13:43 ` Stefan Monnier
@ 2020-03-30 16:59 ` Dmitry Gutov
2020-03-30 17:20 ` Stefan Monnier
0 siblings, 1 reply; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 16:59 UTC (permalink / raw)
To: Stefan Monnier, Eli Zaretskii; +Cc: cpitclaudel, Richard Stallman, emacs-devel
On 30.03.2020 16:43, Stefan Monnier wrote:
> Of course, the need to have your own fork of a repository on github.com
> in order to submit a pull request on some other repository on github.com
> is a serious deficiency
How else would you do/implement that? Without having push access to the
target repository, of course.
I think Github's solution is pretty elegant. Of course, it works as well
as it does because forks are copy-on-write under the covers. Unlike in
Gitlab currently.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 16:59 ` Dmitry Gutov
@ 2020-03-30 17:20 ` Stefan Monnier
2020-03-30 17:28 ` Dmitry Gutov
0 siblings, 1 reply; 53+ messages in thread
From: Stefan Monnier @ 2020-03-30 17:20 UTC (permalink / raw)
To: Dmitry Gutov; +Cc: Eli Zaretskii, cpitclaudel, Richard Stallman, emacs-devel
>> Of course, the need to have your own fork of a repository on github.com
>> in order to submit a pull request on some other repository on github.com
>> is a serious deficiency
> How else would you do/implement that?
I'd have the pull-request-submitter provide a URL to a Git branch.
That branch would then be fetched and added to the repository as
`refs/pull/<NB>` or something like that.
> Without having push access to the target repository, of course.
That would provide push access but not to the whole repository: only to
`refs/pull/<NB>`.
Stefan
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 17:20 ` Stefan Monnier
@ 2020-03-30 17:28 ` Dmitry Gutov
0 siblings, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 17:28 UTC (permalink / raw)
To: Stefan Monnier; +Cc: Eli Zaretskii, cpitclaudel, Richard Stallman, emacs-devel
On 30.03.2020 20:20, Stefan Monnier wrote:
> I'd have the pull-request-submitter provide a URL to a Git branch.
> That branch would then be fetched and added to the repository as
> `refs/pull/<NB>` or something like that.
That might work. Along with a "Refresh" button to update the PR contents
after the external branch has received some changes.
I've never seen this implemented anywhere, though.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 3:38 ` Richard Stallman
2020-03-30 4:09 ` Stefan Monnier
@ 2020-03-30 8:25 ` 조성빈
2020-03-30 11:51 ` Dmitry Gutov
2020-03-30 13:04 ` Eli Zaretskii
2020-03-30 17:49 ` Dmitry Gutov
2 siblings, 2 replies; 53+ messages in thread
From: 조성빈 @ 2020-03-30 8:25 UTC (permalink / raw)
To: rms; +Cc: Dmitry Gutov, eliz, cpitclaudel, Emacs-devel
> 2020. 3. 30. 오후 12:39, Richard Stallman <rms@gnu.org> 작성:
>
> [[[ To any NSA and FBI agents reading my email: please consider ]]]
> [[[ whether defending the US Constitution against all enemies, ]]]
> [[[ foreign or domestic, requires you to follow Snowden's example. ]]]
>
>>> That is a statement of intentions, not facts. Emacs developers
>>> would know those intentions, but other Emacs users might have no
>>> idea about them.
>
>> That's why we have forges, with self-explanatory web interfaces and even
>> integrated help for new users.
>
> That would inform some users, those who do certain things. But in the
> scenario I pointed at, the users would not do those things, so they
> would not get the information.
>
> This is the scenario I pointed at:
>
> Suppose A sends B a URL pointing to a branch with non-installed
> patches. If A doesn't warn B, or if A is too terse and does not make the
> point clear, B will not know it is non-installed. B will only see
> that it is in the standard GNU Emacs repo.
If GNU hosts a forge with PR support working similar to GitHub or GitLab, the URL won’t point to the standard GNU Emacs repo, it will point to a custom fork (which IMHO nobody can really confuse).
For example, let’s say that a Git Forge with a PR model is running on nongnu.org (for instance). The canonical Emacs repo (running by an organization account named ‘gnu’) will be accessible from the URL nongnu.org/gnu/emacs.git. If one wants to make a change on Emacs, one can make an account on nongnu.org (let’s say ‘pcr910303’), press the Fork button from the gnu/emacs repo, and the fork will be accessible from the URL nongnu.org/pcr910303/emacs.git. If I want to merge some code into the canonical emacs repo (with using the web UI), I can push some commits to pcr910303/emacs, go to nongnu.org/gnu/emacs and make a PR across repos. If one wants to check out the change, one can pull from ‘nongnu.org/pcr910303/emacs.git’. The URL clearly indicates that it’s not the official repo, hence it won’t be a problem.
Also, currently non-installed patches can be downloaded from the GNU Emacs mailing list from the URL lists.gnu.org. If the user uses something like curl to download the patch, one will not know whether it’s installed or not. I think it won’t be that different.
>> 99% of the users who would be looking at them, would be doing so through
>> the web interface of the force software.
>
> In that scenario, large numbers of users might not go through that interface.
> They might not even know there is a web interface.
>
>> When you were talking about hiding PRs from non-developers, you meant
>> hiding in the web interface, right?
>
> I mean blocking access to them _in the repo_, for all interfaces. If
> you're not logged in as a member of the project, you would not be
> allowed to check out that branch by running git.
>
>> Because it would be hard to hide
>> them in the mailing lists,
>
> The mailing list is a different kind issue. If you abstract away
> the practical differences, you might think it is the same; but those
> practicalities change everything, in this case.
>
> I am not talking about adding security where we have done ok without
> it. My aim is to limit the possible new danger from the change that
> you are asking for.
>
> I know that many other projects use pull requests and are happy with them.
> But those projects do not share our nontechnical overriding goals:
>
> * Do not distribute nonfree software.
> * Do not publish text that recommends nonfree software.
> * For some projects, do not include code without legal papers.
>
> We have a system for avoiding this: the package maintainers decide
> what to install, and they check these criteria before installing
> anything. (See the GNU Coding Standards and GNU Maintainer's Guide.)
>
> Keeping uninstalled code in the same repo as the installed code makes
> it too easy to overlook the difference between them.
>
>> But if we manage to support merge requests from contributors without
>> commit access, and do it without external repositories, we could just as
>> well mandate that all such branches have names prefixed with
>> "merge-request/", and that will avoid any confusion.
>
> I am not convinced it would work "just as well." But that idea is
> worth thinking about. we need to think _not only_ about how we would
> intend this facility to be used, but also how to make sure it is not
> misused.
>
> How, in practice, would we ensure that all installation proposals
> have a name starting with 'merge-request/'?
>
> How would we find out if many users begin accessing a branch whose
> name begins with 'merge-request/'?
>
> How would we find out if one is created with a name that doesn't
> start with that prefix?
>
> Could we arrange that those branches start out accessible only to
> maintainers, then become generally accessible when a maintainer says
> "Make this accessible"?
>
>
>
> --
> Dr Richard Stallman
> Chief GNUisance of the GNU Project (https://gnu.org)
> Founder, Free Software Foundation (https://fsf.org)
> Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 8:25 ` 조성빈
@ 2020-03-30 11:51 ` Dmitry Gutov
2020-03-30 13:04 ` Eli Zaretskii
1 sibling, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 11:51 UTC (permalink / raw)
To: 조성빈, rms; +Cc: eliz, cpitclaudel, Emacs-devel
On 30.03.2020 11:25, 조성빈 wrote:
> If I want to merge some code into the canonical emacs repo (with using the web UI), I can push some commits to pcr910303/emacs, go to nongnu.org/gnu/emacs and make a PR across repos. If one wants to check out the change, one can pull from ‘nongnu.org/pcr910303/emacs.git’. The URL clearly indicates that it’s not the official repo, hence it won’t be a problem.
I don't think GitLab supports PRs across separate installations, does it?
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 8:25 ` 조성빈
2020-03-30 11:51 ` Dmitry Gutov
@ 2020-03-30 13:04 ` Eli Zaretskii
1 sibling, 0 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-30 13:04 UTC (permalink / raw)
To: 조성빈; +Cc: cpitclaudel, Emacs-devel, rms, dgutov
> From: 조성빈 <pcr910303@icloud.com>
> Date: Mon, 30 Mar 2020 17:25:26 +0900
> Cc: Dmitry Gutov <dgutov@yandex.ru>, eliz@gnu.org, cpitclaudel@gmail.com,
> Emacs-devel@gnu.org
>
> > Suppose A sends B a URL pointing to a branch with non-installed
> > patches. If A doesn't warn B, or if A is too terse and does not make the
> > point clear, B will not know it is non-installed. B will only see
> > that it is in the standard GNU Emacs repo.
>
> If GNU hosts a forge with PR support working similar to GitHub or GitLab, the URL won’t point to the standard GNU Emacs repo, it will point to a custom fork (which IMHO nobody can really confuse).
I think Dmitry was arguing for having this in the Emacs repository.
Having a separate hosting server, especially one that is on
SOMETHING.nongnu.org, was already agreed to, so no reason to argue
about that.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-30 3:38 ` Richard Stallman
2020-03-30 4:09 ` Stefan Monnier
2020-03-30 8:25 ` 조성빈
@ 2020-03-30 17:49 ` Dmitry Gutov
2 siblings, 0 replies; 53+ messages in thread
From: Dmitry Gutov @ 2020-03-30 17:49 UTC (permalink / raw)
To: rms; +Cc: eliz, cpitclaudel, emacs-devel
On 30.03.2020 06:38, Richard Stallman wrote:
> This is the scenario I pointed at:
>
> Suppose A sends B a URL pointing to a branch with non-installed
> patches. If A doesn't warn B, or if A is too terse and does not make the
> point clear, B will not know it is non-installed. B will only see
> that it is in the standard GNU Emacs repo.
It's hard to optimize for people willing to misunderstand things. At
some point we have to just draw the line.
> > 99% of the users who would be looking at them, would be doing so through
> > the web interface of the force software.
>
> In that scenario, large numbers of users might not go through that interface.
> They might not even know there is a web interface.
>
> > When you were talking about hiding PRs from non-developers, you meant
> > hiding in the web interface, right?
>
> I mean blocking access to them _in the repo_, for all interfaces. If
> you're not logged in as a member of the project, you would not be
> allowed to check out that branch by running git.
I mean... if it's not too hard to implement, that would be okay with me,
as long as the web UI shows the PRs even to unauthenticated users.
The latter is not a hard necessity, of course, but I believe that more
transparency in Emacs's development process, the ongoing discussions,
etc, via the "forge" interface would benefit it a lot. Users will
comment more, follow the development of new features more, and will thus
be encouraged to submit more patches themselves.
> Because it would be hard to hide
> > them in the mailing lists,
>
> The mailing list is a different kind issue. If you abstract away
> the practical differences, you might think it is the same; but those
> practicalities change everything, in this case.
>
> I am not talking about adding security where we have done ok without
> it. My aim is to limit the possible new danger from the change that
> you are asking for.
To be clear, we already have branches in the repo which 200+ people can
push to. If we're not worried about them, are we worried only about
branches created by "unauthenticated" users?
Being able to facilitate that is a challenge in itself (+).
> Keeping uninstalled code in the same repo as the installed code makes
> it too easy to overlook the difference between them.
One way to solve that would be to use a forge software that makes it
easy to have multiple repositories (one per user, even), with fast
"forking" action. Gitlab is not there, alas.
> > But if we manage to support merge requests from contributors without
> > commit access, and do it without external repositories, we could just as
> > well mandate that all such branches have names prefixed with
> > "merge-request/", and that will avoid any confusion.
>
> I am not convinced it would work "just as well." But that idea is
> worth thinking about. we need to think _not only_ about how we would
> intend this facility to be used, but also how to make sure it is not
> misused.
>
> How, in practice, would we ensure that all installation proposals
> have a name starting with 'merge-request/'?
If we manage to solve the problem (+) above, we can include that as a
part of the solution. Maybe the unauthenticated users would send
patchsets over email, and whatever code will be set up to handle that,
could enforce whatever branch naming scheme that we choose.
> How would we find out if many users begin accessing a branch whose
> name begins with 'merge-request/'?
Savannah admins might help with that. Some HTTPS proxy, maybe.
> How would we find out if one is created with a name that doesn't
> start with that prefix?
Is that question different from the previous-previous one?
> Could we arrange that those branches start out accessible only to
> maintainers, then become generally accessible when a maintainer says
> "Make this accessible"?
You seem to be trying to combine the two requirements together now, to
make an even more difficult requirement.
But to answer that question: the forge software, or the Git server
software, or a combination of them, have to support that.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 15:21 ` Eli Zaretskii
2020-03-27 15:41 ` Dmitry Gutov
@ 2020-03-27 16:39 ` Clément Pit-Claudel
2020-03-27 19:21 ` Eli Zaretskii
1 sibling, 1 reply; 53+ messages in thread
From: Clément Pit-Claudel @ 2020-03-27 16:39 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
On 27/03/2020 11.21, Eli Zaretskii wrote:
> So we are supposed to keep pointers to those sites, and use them?
> How do we know which site holds what relevant discussions? who will
> remember that several years after the discussion took place?
Don't we have the same issue with debbugs and mailing lists? At the moment we put links to bugs.gnu.org, emacs-devel, help-gnu-emacs, as well as the bug trackers and mailing lists of various other projets, when relevant). Here we would put links to pull request numbers, likely prefixed with some identifier; maybe something like gitlab:57?
> And what if the tracker that hosted the discussion goes dark (e.g.,
> because the person who submitted the patch is no longer keeping the
> branch,
That's not how it works: comments are attached to code fragments, like in a patch, so they don't go away if the branch is deleted. Just like patches sent by email.
> or simply because the hosting service is discontinued?
I expect we would self-host, like debian and gnome do with gitlab, right? So if we decided to discontinue the service (i.e. migrate to another platform) we would need to migrate our issues as well.
> We must have all these archives in a single place, which we can
> control and which we can ensure continues to be available for years
> to come.
Definitely: that's why we imported old history when we migrated to git. Same for bug tracking or pull requests: if we move to a different service, we'd want to export them.
Clément.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 16:39 ` Clément Pit-Claudel
@ 2020-03-27 19:21 ` Eli Zaretskii
0 siblings, 0 replies; 53+ messages in thread
From: Eli Zaretskii @ 2020-03-27 19:21 UTC (permalink / raw)
To: Clément Pit-Claudel; +Cc: emacs-devel
> Cc: emacs-devel@gnu.org
> From: Clément Pit-Claudel <cpitclaudel@gmail.com>
> Date: Fri, 27 Mar 2020 12:39:36 -0400
>
> On 27/03/2020 11.21, Eli Zaretskii wrote:
> > So we are supposed to keep pointers to those sites, and use them?
> > How do we know which site holds what relevant discussions? who will
> > remember that several years after the discussion took place?
>
> Don't we have the same issue with debbugs and mailing lists? At the moment we put links to bugs.gnu.org, emacs-devel, help-gnu-emacs, as well as the bug trackers and mailing lists of various other projets, when relevant). Here we would put links to pull request numbers, likely prefixed with some identifier; maybe something like gitlab:57?
We now have the bug tracker and a couple of mailing lists (which are
really a minority, as most bugs are reported to debbugs). The
proposal to which I was responding was to put the patches on random
remote branches out there, not on a single server. That would make
the problem unmanageable.
> I expect we would self-host, like debian and gnome do with gitlab, right? So if we decided to discontinue the service (i.e. migrate to another platform) we would need to migrate our issues as well.
Like Dmitry, you are responding to a proposal different from what was
made, to which I posted my comments. The proposal was NOT to have a
single server.
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 13:00 ` Clément Pit-Claudel
2020-03-27 13:30 ` Eli Zaretskii
@ 2020-03-27 14:05 ` Stefan Monnier
1 sibling, 0 replies; 53+ messages in thread
From: Stefan Monnier @ 2020-03-27 14:05 UTC (permalink / raw)
To: Clément Pit-Claudel; +Cc: emacs-devel
>> More importantly, given that I did a review
>> of such a remote branch, how do I communicate my comments so that they
>> are recorded for posterity? Probably by email, so that doesn't seem
>> to solve the main problem of avoiding email in the patch submission
>> and review workflow.
>
> Assuming you use the web UI, you can typically attach comments to code regions.
I never use those web UIs when reviewing Git branches.
Instead, I fetch those branches with Git and then review them locally
(thank god!).
> Pros over email reviews include the fact that the comments remain attached
> to the code even after the patch is updated (so if the original author
> updates an unrelated section of the patch the comments don't disappear) and
> the fact that you get to see the full code, rather than just the patch.
>
> Cons include inferior text-editing capabilities, and inferior code browsing
> capabilities compared to applying the patch and browsing around in Emacs
> (but you can always checkout the branch, which I find nicer than applying
> patches by hand anyway).
My foggy memory says there was tool (developed by Google, maybe?) that
standardized a representation of annotations to store inside the Git
repository, so you could get both benefits (i.e. write your annotations
locally with the tool you like and then store them for posterity
attached to the code).
I can't remember its name any more (and I never used it).
Stefan
^ permalink raw reply [flat|nested] 53+ messages in thread
* Re: pull requests
2020-03-27 7:54 ` Eli Zaretskii
2020-03-27 13:00 ` Clément Pit-Claudel
@ 2020-03-28 2:46 ` Richard Stallman
1 sibling, 0 replies; 53+ messages in thread
From: Richard Stallman @ 2020-03-28 2:46 UTC (permalink / raw)
To: Eli Zaretskii
Cc: mlang, philippe.vaucher, emacs-devel, jackhill, dick.r.chiang
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
> > I don't remember the precise conclusions last year, but ISTR I
> > concluded that any pull requests on a GNU forge must be visible _only_
> > to the developers of the package.
> IIRC, the most important, at least IMO, conclusion was that we should
> host such services on savannah.nongnu.org, so that any code in those
> pull requests is not considered to "belong to GNU".
Yes, that is right. We could put those pull requests somewhere other
than the Emacs repo (for instance, savannah.nongnu.org, or we could
put them in the Emacs repo but make them accessible only to the Emacs
developers.
--
Dr Richard Stallman
Chief GNUisance of the GNU Project (https://gnu.org)
Founder, Free Software Foundation (https://fsf.org)
Internet Hall-of-Famer (https://internethalloffame.org)
^ permalink raw reply [flat|nested] 53+ messages in thread
end of thread, other threads:[~2020-04-23 3:15 UTC | newest]
Thread overview: 53+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-04-17 4:24 pull requests Zach Pearson
2020-04-17 8:11 ` Alex Ott
2020-04-17 16:36 ` Dmitry Gutov
2020-04-21 1:47 ` Richard Stallman
2020-04-21 2:12 ` Po Lu
2020-04-22 3:19 ` Richard Stallman
2020-04-23 3:15 ` Po Lu
2020-04-17 16:38 ` Dmitry Gutov
-- strict thread matches above, loose matches on Subject: below --
2020-03-22 22:35 ELPA: where is chess developed? Jack Hill
2020-03-23 4:26 ` John Wiegley
2020-03-23 13:50 ` dick.r.chiang
2020-03-23 14:27 ` Mario Lang
2020-03-23 15:12 ` dick.r.chiang
2020-03-24 8:10 ` Philippe Vaucher
2020-03-24 11:38 ` dick.r.chiang
2020-03-24 11:54 ` Philippe Vaucher
2020-03-27 2:59 ` pull requests Richard Stallman
2020-03-27 3:49 ` Stefan Monnier
2020-03-28 2:45 ` Richard Stallman
2020-03-28 3:03 ` Stefan Monnier
2020-03-27 7:54 ` Eli Zaretskii
2020-03-27 13:00 ` Clément Pit-Claudel
2020-03-27 13:30 ` Eli Zaretskii
2020-03-27 14:37 ` Clément Pit-Claudel
2020-03-27 15:21 ` Eli Zaretskii
2020-03-27 15:41 ` Dmitry Gutov
2020-03-27 19:16 ` Eli Zaretskii
2020-03-27 19:24 ` Dmitry Gutov
2020-03-27 19:34 ` 조성빈
2020-03-27 19:28 ` Eli Zaretskii
2020-03-27 20:39 ` Dmitry Gutov
2020-03-28 2:46 ` Richard Stallman
2020-03-28 17:14 ` Dmitry Gutov
2020-03-30 3:38 ` Richard Stallman
2020-03-30 4:09 ` Stefan Monnier
2020-03-30 5:58 ` Eli Zaretskii
2020-03-30 12:03 ` Dmitry Gutov
2020-03-30 12:55 ` Yuri Khan
2020-03-30 13:12 ` Eli Zaretskii
2020-03-30 13:50 ` Dmitry Gutov
2020-03-30 14:12 ` Eli Zaretskii
2020-03-30 14:34 ` Dmitry Gutov
2020-03-30 15:36 ` Eli Zaretskii
2020-03-30 15:50 ` Dmitry Gutov
2020-03-30 16:09 ` Eli Zaretskii
2020-03-30 17:06 ` Dmitry Gutov
2020-03-30 17:13 ` Eli Zaretskii
2020-04-02 2:39 ` Richard Stallman
2020-04-17 3:54 ` Dmitry Gutov
2020-03-30 13:43 ` Stefan Monnier
2020-03-30 16:59 ` Dmitry Gutov
2020-03-30 17:20 ` Stefan Monnier
2020-03-30 17:28 ` Dmitry Gutov
2020-03-30 8:25 ` 조성빈
2020-03-30 11:51 ` Dmitry Gutov
2020-03-30 13:04 ` Eli Zaretskii
2020-03-30 17:49 ` Dmitry Gutov
2020-03-27 16:39 ` Clément Pit-Claudel
2020-03-27 19:21 ` Eli Zaretskii
2020-03-27 14:05 ` Stefan Monnier
2020-03-28 2:46 ` Richard Stallman
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).