Settings

Theme

Programmer's Nightmare – Ruby Prank

github.com

14 points by ace_33 10 years ago · 10 comments

Reader

TheDong 10 years ago

Critique:

1) no LICENSE file

2) not configurable

3) not idiomatic ruby (e.g. camelCase not snake_case)

4) overtly complicated. A better, and shorter version, is:

    bad_whitespace = " "
    ARGF.inplace_mode = ""
    ARGF.each_line do |line|
      print line.gsub(" ", bad_whitespace)
    end
5) bad commenting. The style of commenting each line for what it does is often silly. Something like "fileModified.close # Close file" tells me exactly nothing more than reading the code. Having "noisy" comments makes important comments less obvious, and thus actually makes the overall commenting worse.

This is a sign of a college coder who had some class where the teacher said "you're required to have at least this much commenting", or a beginner programmer.

And finally, this is obviously a dumb toy program.

This isn't useful to show-hn. This isn't anything novel, or even interesting. It's not hard to do. It's poorly implemented and not portable (really, why require the user to edit the filename? ARGF exists for a reason).

This was also submitted by a new hn account mere hours after it was created (clearly by the author). I have no problem with showing off your own work, but at least let it cool down to see if it's a good idea; see that other people think it's interesting or useful in its own right.

I consider presenting an essentially 5-line program that is not generally useable or insightful as being basically spam.

I do recommend keeping on programming and, once you've got a project you're proud of that has seen some use besides yourself, seen at least one other happy user, and relates to HN's interests, post away!

  • volent 10 years ago

    If he's a beginner your comment might be a bit harsh.

    If it's not interesting to you don't upvote the post but saying it's "dumb" and "ARGF exists for a reason" is just being rude.

  • kyberias 10 years ago

    Out of curiosity (haven't done ruby for awhile): is your line-by-line implementation safe? Is it guaranteed that the lines are identical in the output file besides the character you're replacing? I'm thinking different CR+LR combinations. What if the final line is not terminated by newline? Doesn't print always add it?

    • TheDong 10 years ago

      You're thinking of 'puts' which appends a newline.

      'print' does not

      The code does handle/preserve all the cases you mentioned (\r\n, final or no final terminating newline, etc).

kzar 10 years ago

Even worse, we actually had a regression at work caused by a zero width space sneaking into some code. Most editors won't even display anything for that character, even the code review tool we used didn't!

In the end I configured Emacs to highlight all unicode characters, trailing whitespace and tabs bright red. I also had it render zero width characters as normal spaces, otherwise they were still invisible. https://github.com/kzar/emacs.d/blob/master/init.el#L181-L19...

  • BraveKenny 10 years ago

    Sounds like some evil plan StackOverflow could use: inserting those characters randomly in the answers' codes to deter copy-pasting.

illektr1k 10 years ago

Along the same vein: Things to commit just before leaving your job - https://gist.github.com/aras-p/6224951

wmt 10 years ago

Why would you want to do that with ruby script instead of your favorite editor, or tr/sed on the commandline? And why would you write a "Close file" comment before file.close?

pmlnr 10 years ago

https://news.ycombinator.com/item?id=10437619

akerro 10 years ago

git checkout - uf

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection