Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

new input filter : nibble_swap #62

Merged
merged 2 commits into from
May 9, 2023

Conversation

fenugrec
Copy link
Contributor

Simple, exchange upper and lower halves of each byte, e.g. "A6" -> "6A".

Includes a simple test script.

@fenugrec
Copy link
Contributor Author

(force-pushed because of some whitespace issues I just noticed - nothing else changed)

Copy link
Owner

@sierrafoxtrot sierrafoxtrot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is looking great @fenugrec! A few minor(I hope) comments and some small line length items from the CI lint tests.

Would you please also update doc/etc/README.man (around line 318) to add the filter

srecord/input/filter/nibble_swap.h Outdated Show resolved Hide resolved
srecord/input/filter/nibble_swap.h Outdated Show resolved Hide resolved
srecord/input/filter/nibble_swap.cc Outdated Show resolved Hide resolved
test/02/t0269a.sh Show resolved Hide resolved
doc/man1/srec_input.1 Outdated Show resolved Hide resolved
@fenugrec
Copy link
Contributor Author

fenugrec commented May 1, 2023

Thanks for reviewing. Will update this list as I go

  • line length items from the CI lint tests.
  • doc/etc/README.man (around line 318) to add the filter
  • copyright
  • other inline fixes

@fenugrec
Copy link
Contributor Author

fenugrec commented May 1, 2023

Ok, the megalint long-line errors should be fixed.

About the copyright notice : if I cannot use my handle there, I assigned it to "srecord project". If that is not satisfactory then I will copy the notice from the bit_reverse (or byte_swap) filters which I mostly duplicated except for one line.

Note : there's already a // Copyright (C) 2019 fenugrec line in input/file/hp64.* ...

@sierrafoxtrot
Copy link
Owner

sierrafoxtrot commented May 1, 2023

Ok, the megalint long-line errors should be fixed.

About the copyright notice : if I cannot use my handle there, I assigned it to "srecord project". If that is not satisfactory then I will copy the notice from the bit_reverse (or byte_swap) filters which I mostly duplicated except for one line.

Note : there's already a // Copyright (C) 2019 fenugrec line in input/file/hp64.* ...

Ok, the megalint long-line errors should be fixed.

Fantastic. Looks good.

About the copyright notice : if I cannot use my handle there, I assigned it to "srecord project". If that is not satisfactory then I will copy the notice from the bit_reverse (or byte_swap) filters which I mostly duplicated except for one line.

That is probably a solid approach although people may get a little confused about files with circa 2010 copyright being created in 2023. If they are different, we could have an issue as Peter can no longer assert copyright and his estate has no legal entity. But if this is your preferred approach, I think on balance, we can go with it.

Note : there's already a // Copyright (C) 2019 fenugrec line in input/file/hp64.* ...

I spotted the existing one too and that was entirely my fault for letting it through. We will need to address this one similarly too unfortunately.

The problem is that the GPL relies on assertion/defence of copyright which in many if not all jurisdictions can only be made by a legal entity ie a person or business. While I appreciate the intent with "srecord project", it isn't a legal entity either.

I completely support your preference to keep your legal name out of the code base so the best I can offer is if you assign it to me. I don't like the idea of claiming credit for your work (history still shows it comes from you) but unless you have a corporate entity that could hold the copyright, it's the best we have available. Perhaps something like the following?
// Copyright (C) 2019 Scott Finneran (authored by fenugrec & copyright assigned)

Now I remember why I chose engineering over law :-)

srecord/input/filter/nibble_swap.cc Outdated Show resolved Hide resolved
srecord/input/filter/nibble_swap.h Outdated Show resolved Hide resolved
test/02/t0269a.sh Outdated Show resolved Hide resolved
@fenugrec
Copy link
Contributor Author

fenugrec commented May 1, 2023

we could have an issue as Peter can no longer assert copyright and his estate has no legal entity

Good point.

The problem is that the GPL relies on assertion/defence of copyright which in many if not all jurisdictions can only be made by a legal entity

Yeah, getting fast into uncharted waters for me, and of course varies according to local law, but there is definitely some precedent for asserting copyright under a pseudonym (not a new thing in the publishing world). What few references I've found all recommend consulting lawyers , obviously :

I think using "srecord project' would probably be valid in many jurisdictions, I've seen various wording like "works produced in collaboration / in a group or team", but that's another story.

As I understand since I published this PR (and the hp64k one) under GPL under a pseudonym, the copyright enforceability is my problem - it says GPL and nothing else, so you are free to include it in srecord under the GPL terms. You don't inherit the responsibility of protecting my copyright, since it's mine ?

Anyway, as maintainer, it's entirely up to you how to proceed; if it's a problem then for this PR at least I have no objection to you claiming copyright on it. It's trivial code that you could have produced in less time than it took me to write this reply -- I hardly even feel I deserve to have my own name there !

Now I remember why I chose engineering over law :-)

Yeah, no joke. The only laws I want to deal with are the laws of physics.

@sierrafoxtrot
Copy link
Owner

sierrafoxtrot commented May 2, 2023

* UK is weird, https://copyrightservice.co.uk/copyright/p03_copyright_notices "Although it may not be technically correct (it does not state the name of the legal entity that is the copyright owner), it is very common for an identifiable pseudonym or trading name to be used in the copyright notice"

Yep and we have some similar conventions here in Australia. Hence my move to keeping it simple.

Anyway, as maintainer, it's entirely up to you how to proceed; if it's a problem then for this PR at least I have no objection to you claiming copyright on it. It's trivial code that you could have produced in less time than it took me to write this reply -- I hardly even feel I deserve to have my own name there !

Mate, you took the time to contribute and even consider my comments above seriously which I greatly appreciate. In the interests of taking a simple approach that I can apply consistently, would you mind making the updates to something like the following?
// Copyright (C) 2023 Scott Finneran (authored by fenugrec & copyright assigned)

or perhaps
// Authored by fenugrec with copyright assigned to Scott Finneran
// Copyright (C) 2023 Scott Finneran

Now I remember why I chose engineering over law :-)

Yeah, no joke. The only laws I want to deal with are the laws of physics.

LOL, much more reasonable set of rules!

@fenugrec
Copy link
Contributor Author

fenugrec commented May 3, 2023

Yep and we have some similar conventions here in Australia. Hence my move to keeping it simple.

Right. Thought about it some more, and still, I can't see how this would ever be a problem. Even if you or some future maintainer wants to relicense everything, whether there's a real or fake name or an obvious pseudonym in the notice won't change much, as I would still need to be contacted for permission. If someone uses parts of my code and doesn't observe GPL requirements, that's not the project's problem to deal with but entirely mine. Can you think of a scenario where it would cause issues ?

@sierrafoxtrot

This comment was marked as outdated.

@sierrafoxtrot
Copy link
Owner

sierrafoxtrot commented May 4, 2023

Yep and we have some similar conventions here in Australia. Hence my move to keeping it simple.

Right. Thought about it some more, and still, I can't see how this would ever be a problem. Even if you or some future maintainer wants to relicense everything, whether there's a real or fake name or an obvious pseudonym in the notice won't change much, as I would still need to be contacted for permission. If someone uses parts of my code and doesn't observe GPL requirements, that's not the project's problem to deal with but entirely mine. Can you think of a scenario where it would cause issues ?

I gave it some more thought and sought some more advice.

Regarding copyright assertion, a handle is essentially a pseudonym (aka pen-name) and this doesn't undermine copyright assertion as long as we can trace it back to a real identity.

Your commits are attributed to an email address and possibly even signed giving traceability back to a contact point. It's an email redirect via Sourceforge but better than nothing. I may end up turning on "commits must be signed" at some point.

Bottom line is that on balance, I do think we'll be ok. Let's move forward as-is on the copyright assignment. Thanks for helping me think this through.

If you wouldn't mind changing the copyrights back to // Copyright (C) 2019 fenugrec, I'd appreciate it. Apologies for all the back and forth.

@fenugrec
Copy link
Contributor Author

fenugrec commented May 4, 2023

I may end up turning on "commits must be signed" at some point.

I'd be perfectly fine with that if you eventually go for that.

Bottom line is that on balance, I do think we'll be ok. Let's move forward as-is on the copyright assignment. Thanks for helping me think this through.

Glad to hear that; thank you for giving this honest thought. Will change back the notices in this PR in a few minutes.

fenugrec added 2 commits May 4, 2023 10:03
Simply exchanges upper and lower nibbles of each bytes.

This should only be a few opcodes per byte on most CPUs; probably faster
than a look-up table (e.g. like the bit-reverse filter).
@sierrafoxtrot
Copy link
Owner

When you get a moment to change the copyright assignments to fenugrec, I can merge this in.

@fenugrec
Copy link
Contributor Author

fenugrec commented May 9, 2023

When you get a moment to change the copyright assignments to fenugrec, I can merge this in.

Oh I thought I alread had, did I miss one ?

@sierrafoxtrot
Copy link
Owner

When you get a moment to change the copyright assignments to fenugrec, I can merge this in.

Oh I thought I alread had, did I miss one ?

Sorry, my mistake, I mucked something up pulling latest. All good!

@sierrafoxtrot sierrafoxtrot merged commit 6fa2523 into sierrafoxtrot:master May 9, 2023
@fenugrec
Copy link
Contributor Author

awesome. thanks

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants