this post was submitted on 16 May 2024
367 points (97.9% liked)

Technology

60239 readers
4819 users here now

This is a most excellent place for technology news and articles.


Our Rules


  1. Follow the lemmy.world rules.
  2. Only tech related content.
  3. Be excellent to each another!
  4. Mod approved content bots can post up to 10 articles per day.
  5. Threads asking for personal tech support may be deleted.
  6. Politics threads may be removed.
  7. No memes allowed as posts, OK to post as comments.
  8. Only approved bots from the list below, to ask if your bot can be added please contact us.
  9. Check for duplicates before posting, duplicates may be removed

Approved Bots


founded 2 years ago
MODERATORS
 

New development policy: code generated by a large language model or similar technology (e.g. ChatGPT, GitHub Copilot) is presumed to be tainted (i.e. of unclear copyright, not fitting NetBSD's licensing goals) and cannot be committed to NetBSD.

https://www.NetBSD.org/developers/commit-guidelines.html

all 39 comments
sorted by: hot top controversial new old
[–] [email protected] 92 points 7 months ago (6 children)

Ok but how is anyone meant to know if you generated your docstrings using copilot?

[–] Terces 112 points 7 months ago (1 children)

How do they know that you wrote it yourself and didn't just steal it?

This is a rule to protect themselves. If there is ever a case around this, they can push the blame to the person that committed the code for breaking that rule.

[–] [email protected] 34 points 7 months ago (1 children)

This is the only reason rules exist, not to stop people doing a thing but to be able to enforce or defect responsibility when they do.

[–] ripcord 7 points 7 months ago

I mean, generally rules at least are to strongly discourage people from doing a thing, or to lead to things that WOULD prevent people from doing a thing.

A purely conceptual rule by itself would not magically stop someone from doing a thing, but that's kind of a weird way to think about it.

[–] [email protected] 38 points 7 months ago

They'll use AI to detect it.... obviously. ☺️

[–] [email protected] 25 points 7 months ago (2 children)

I'm saddened to use this phrase but it is literally virtue signalling. They have no way of knowing lmao

[–] [email protected] 12 points 7 months ago (2 children)

It’s actually simple to detect: if the code sucks or is written by a bad programmer, and the docstrings are perfect, it’s AI. I’ve seen this more than once and it never fails.

[–] [email protected] 4 points 7 months ago (3 children)

I'm confused, do people really use copilot to write the whole thing and ship it without re reading?

[–] [email protected] 7 points 7 months ago

I literally did an interview that went like this:

  1. Applicant used copilot to generate nontrivial amounts of the code
  2. Copilot generated the wrong code for a key part of the algorithm; applicant didn't notice
  3. We pointed it out, they fixed it
  4. They had to refactor the code a bit, and ended up making the same exact mistake again
  5. We pointed out the error again...

And that's in an interview, where you should be extra careful to make a good impression...

[–] neclimdul 4 points 7 months ago

Not specific to AI but someone flat out told me they didn't even run the code to see it work. They didn't understand why I would or expect that before accepting code. This was someone submitting code to a widely deployed open source project.

So, I would expect the answer is yes or very soon to be yes.

[–] [email protected] 1 points 7 months ago* (last edited 7 months ago) (1 children)

Around me, most beginners who use that don't have the skills to understand or even test what they get. They don't want to learn I guess, ChatGPT is easier.

I recently suspected a new guy was using ChatGPT because everything seemed perfect (grammar, code formatting, classes made with design patterns, etc.) but the code was very wrong. So I did some pair programming with him and asked if we could debug his simple application. He didn't know where the debug button was.

[–] [email protected] 2 points 7 months ago (1 children)

Guilty as charged, ten years into the job and I never learned to use a debugger lol.

Seriously though that's amazing to me I never met one of those... I guess 95% of them will churn out of the industry in less than five years...

[–] [email protected] 1 points 7 months ago* (last edited 7 months ago)

Debug button? There is a button that inserts 'printf("%s:%s boop! \n" , __FUNCTION__, __LINE__) ;'?

[–] [email protected] 1 points 7 months ago* (last edited 7 months ago) (1 children)

So your results are biased, because you're not going to see the decent programmers who are just using it to take mundane tasks off their back (like generating boilerplate functions) while staying in control of the logic. You're only ever going to catch the noobs trying to cheat without fully understanding what it is they're doing.

[–] [email protected] 8 points 7 months ago

You're only ever going to catch the noobs.

That’s the fucking point. Juniors must learn, not copy paste random stuff. I don’t care what seniors do.

[–] [email protected] 9 points 7 months ago (1 children)

It's also probably to make things slightly simpler from a legal perspective.

[–] [email protected] 1 points 7 months ago

That makes sense yes

[–] SMillerNL 11 points 7 months ago

Are they long, super verbose and often incorrect?

[–] [email protected] 6 points 7 months ago

Magic, I guess ?

[–] [email protected] 6 points 7 months ago (1 children)

Because they'll be shit?

Docstrings based on the method signature and literal contents of a method or class are completely pointless, and that's all copilot can do. It can't Intuit anything that docstrings are actually there for.

[–] [email protected] 3 points 7 months ago (1 children)

Definitely not my experience. With a well structured code base it can be pretty uncanny. I think it's context is limited to files that are currently opened in the editor, so that may be your issue if you're coding with just one file open?

[–] [email protected] 4 points 7 months ago* (last edited 7 months ago)

GitHub Copilot introduced a new keyword a little while ago, "@workspace", where it can see everything in your project. The code it generates uses all your own functions and variables in your libraries and it figures out how to use them correctly.

There was one time where I totally went "WTF", because it spat out Python. In a C++ project. But those kind of hallucinations are getting more and more rare. The more code you write, the better it gets. It really does become sort of like a "Copilot", sitting there coding alongside you. The mistake people make is assuming it's going to come up with ideas and algorithms for them without spending any mental energy at all.

I'm not trying to shill. I'm not a programmer by trade. Just a hobbyist who started on QBasic in the ancient times. But I've been trying to learn it off and on for the past 30 years, and I've never learned so much and had so much fun as in the last 1.5 with AI help. I can just think of stuff to do, and shit will just flow out now.

[–] [email protected] 35 points 7 months ago (2 children)

This is a good move for international open source projects, with multiple lawsuits in multiple countries around the globe currently ongoing, the intellectual property nature of code made using AI isn't really secure enough to open yourself up to the liability.

I've done the same internally at our company. You're free to use whatever tool you want but if the tool you use spits out copyrighted code, and the law eventually has decided that model users instead of model trainers are liable for model output, then that's on you buddy.

[–] [email protected] 11 points 7 months ago

Yup. We don't allow AI tools on our codebase, but I allow it for interviews. I honestly haven't been impressed by it at all, it just encourages not understanding the code.

[–] [email protected] 1 points 7 months ago

Does this mean you have indicated to your employees and/or contractors that you intend to hold them legally liable in the case someone launches litigation against you?

[–] elias_griffin 20 points 7 months ago* (last edited 7 months ago) (1 children)

So proud of you NetBSD, this is why I sponsor you, slam dunk for the future. I'm working on a NetBSD hardening script and Rice as we speak, great OS with some fantastically valuable niche applications and I think, a new broad approach I'm cooking up, a University Edition. I did hardening for all the other BSD, I saved the best for last!

[EDIT 5/16/2024 15:04 GMT -7] NetBSD got Odin lang support yesterday. That totally seals the NetBSD deal for me if I can come up with something cool for my workstation with Odin.

If you would like to vote on whether, or by what year, AI will be in the Linux Kernel on Infosec.space:

https://infosec.space/@wravoc/112441828127082611

[–] ripcord 2 points 7 months ago

Thanks for your efforts Elias!

[–] jaybone 17 points 7 months ago

I was hoping they ban it because it’s shit, but banning it for copyright reasons is fine too.

[–] [email protected] 8 points 7 months ago (2 children)

I can understand why a project might want to do this until the law is fully implemented and testing in court, but I can tell most of the people in this thread haven’t actually figured out how to effectively use LLMs productively. They’re not about to replace software engineers, but as a software engineer, tools like GitHub copilot and ChatGPT are excellent at speeding up a workflow. ChatGPT for example is an excellent search engine that can give you a quick understanding of a topic. It’ll generate small amounts of code more quickly than I could write it by hand. Of course I’m still going to review that code to ensure it is to the same quality that hand written code would be, but overall this is still a much faster problem.

The luddites who hate on LLMs would have complained about the first compilers too, because they could write marginally faster assembly by hand.

[–] [email protected] 4 points 7 months ago

Same for intellisense, IDEs, Debuggers, linters, static analyzers, dynamic languages, garbage collection, NoSQL databases...

[–] Anti_Iridium 2 points 7 months ago* (last edited 7 months ago)

Why use a computer to do the work when I could do myself? /s

[–] diffusive 7 points 7 months ago

I never felt so close to try NetBSD as after reading this 😃

[–] hperrin 3 points 7 months ago* (last edited 7 months ago)

Hell yeah! Get that shit… OUTTA HERE!!!

Ok but seriously, that is a very good reason to ban it. Who knows what would happen if the AI just fully ripped someone else’s code off that’s supposed to be like GPL licensed or something. If humans can plagiarize, than AIs can plagiarize.

But also, how are they still using CVS? CVS is so slow and so bad. Even Subversion would be an upgrade.

[–] [email protected] 3 points 7 months ago

We need to see more of this

[–] [email protected] -4 points 7 months ago (1 children)

I get banning for quality, but for potential copyright is pretty stupid.

[–] Spedwell 7 points 7 months ago

It's not really stupid at all. See the matrix code example from this article: https://spectrum.ieee.org/ai-code-generation-ownership

You can't really know when the genAI is synthesizing from thousands of inputs or just outright reciting copyrighted code. Not kosher if it's the latter.