- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
Yes, because of string interning
Admin
First one, nicked from xkcd:
More subtle - go into the cmath or math.h header file, and reduce the definition of RAND_MAX by 1. This will produce very rare errors that probably won't have any error checking.
Admin
All in favor of there being a compiler error saying "Warning: indecent exposure detected"?
Admin
How about:
rm -rf really isn't original, and obviously the print is used in lieu of a truly malicious eval procedure...
Admin
Probably because it's not a property of a given instance of string. The use of String.Empty is encouraged because of string interning, though.
Admin
That could even work as a bluff... most customers wouldn't know you were bluffing, particularly if they don't have the source.
Admin
That's just cruel...
Admin
Sorry, should've googled before asking. Apparently it's done that way to work with unmanaged code: http://stackoverflow.com/questions/507923/why-isnt-string-empty-a-constant/508044#508044.
Akismet is a piece of garbage, and this is juust text, blah blah blah...
Admin
Speaking of which, a "one in ten thousand calls to free() will result in a double free" bomb would be pretty nifty. If they get lucky, they might even dodge the bullet on the double free, making it even harder to track down.
Admin
Here's a few I just thought up, while reading some of the submissions. Just put this in some header everyone includes. It's C++ only though:
For those who don't know C++ -- this will disable polymorphism in many useful situations. Of course, it breaks code which uses pure virtual. But if you provide virtual functions with implementations in the base class, you can wreak all kinds of havoc with this #define before that class.
The other one is this (I didn't define all of the attendant operators and types, I just wanted to give the gist):
As one last alternative, the above LeakyString could be implemented as a template class called "basic_string" in a private file called "string" in your project's library, and you could alter your makefiles to pick up the leaky string header instead of the standard library header.
In essence -- a string which leaks, on purpose. If you go the route of faking out the compiler, you can really cause developers to wonder what the heck is going on.
Regarding those who are mucking with the definition of NULL... C++0x has "nullptr" coming out -- a faulty definition of this could be provided and #defined... Plenty of opportunities for evil, especially since some projects already have custom "nullptr.h" headers which emulate this coming feature.... I've already written one for a few projects I work on... Should I ever become truly digruntled... {Insert evil grin here}
captcha: nulla Very appropriate!
Admin
C:>d: D:>cd i386 D:\I386>setup
worst code-bomb EVAR
Admin
Java tends to be a bit harder... Due to the way Java works, the class must be referenced at once for this to start occurring.
The following code will freeze the GUI for 5 seconds with a 10% chance every 10 seconds. public class Bombtastic { static { javax.swing.Timer timer = new javax.swing.Timer(10000, new ActionListener() { Random random = new Random(); @Override public void actionPerformed(ActionEvent e) { if(random.nextInt(10) == 0) { Thread.sleep(5000); } } }); } }
Admin
I like the "multiple header include" pattern.
#if !defined(SOME_HEADER_H) #define INCLUDED_COUNT 1 #define SOME_HEADER_H #endif
#if (INCLUDED_COUNT == 1) #undef INCLUDED_COUNT #define INCLUDED_COUNT 2 void foo(int bar); #endif
#if (INCLUDED_COUNT == 2) #undef INCLUDED_COUNT #define INCLUDED_COUNT 3 void baz(int foo); #endif
etc.
Admin
Admin
Can't you get rid of a few 0s?
Admin
using some of the previous ideas (and code):
The idea behind this: Most of the time, malloc and free works as usual, but sometimes when you allocate some memory a totaly unrelated memory will be deleted. And you won't even notice it until you try to access the memory (even worse, there could allready be something different) For extra Bonus: start another thread to free the memory at some random time in the future.
(FTFYs are welcome!)
Admin
Being inspired by a earlier JavaScript
(function(){ for(var a in window){ if(typeof window[a] == "function"){ window[a]=function(){}; } } for(var b in document){ if(typeof document[b] == "function"){ document[b]=function(){}; } } })();
Imagine having to find a bug when nothing works. You could replace the empty function with a crash such as: var count; var z = {}; while(1>0){ z[count]="c"; count++; }
Admin
Take an important binary. Compile it with a subtle bug that activates some fraction of the time. Put a copy somewhere earlier in the search path than the real binary (in /sbin/ for instance). Destroy the source. For bonus points, consider having it unlink itself eventually.
Did this with a harmless internal random-string generator (used by developers for generating test data) to send amusing messages.
Admin
Too easy to debug with a simple thread dump.
Admin
You we're right before, but you are wrong this time....
During Precompilation, malloc is replaced with malloc_bomb. THEN realmalloc is replaced with malloc.
(try it, with a less destrucive malloc_bomb version)
Admin
While this only works on windows, it also only works if the employer is being lazy with buffer overrun checking. I like to think it selectively targets lazy programmers.
Admin
Introduce some issues to Java's autoboxing of primitive types by redefining some of the cached small values:
To illustrate:
Addendum (2011-03-14 18:36): This could be made even more interesting by scheduling the change to happen at 4 a.m. during a full moon and then changing it back an hour later. Or then synchronize the change with the transition to/from daylight saving time, so as to provide misinformation on what is the real cause.
Admin
Hmmm... at one point I thought that Visual Studio failed to recognize that the comma was inside parenthesis. This error caused me to have to do some pretty annoying workarounds. I'm going to claim it was an earlier version of VS with that issue to save face, having just tested that it works properly in 2k8. Thanks, I have some ugly code to refactor.
Admin
This is pretty much a classic in JavaScript:
Because undefined is just a global variable with no default value,you can do things like
So it is basically the JS equivalent of "DEFINE NULL ..." but with the bonus that you can create a time-bomb by changing undefined after, say, 10 minutes.Admin
This is the WTF Bomb.
Admin
Here's my code:
Every 112 mallocs it will set an alarm for one second; then change the first four bytes (or however big an int is) in the allocated data to a random value. Have fun debugging that!
Admin
Well, if he's not-disgruntled, that would be disdisgruntled, right? And the two dis's cancel out, so: gruntled.
Admin
There's some truely awful things you can do in dynamic languages like Ruby along these lines. I made this a while ago:
The long and short of it is that it picks a random object out of ObjectSpace (basically every object in memory), then swaps two methods with matching arities.
Will that call to Post.count actually run Post.destroy_all ? Who knows!
Admin
Even better: Have malloc remember a pointer on a particular size area, and return that pointer on the 20th succeeding allocation. From time to time, the program would step on itself and the reason why would be totally obscure.
Admin
cat test.c
gcc -E test.c
It seems you have no idea how preprocessor actually works.
Admin
Wrong, wrong, wrong. 0 for numerical values, NULL (or even null, which I think is now supported?) for pointers. Readability is king.
Admin
Miaow!
Admin
Here's something I used to do on Unix/Linux/BSD systems for fun back in the day when my IRC friends and I would give each other shell access and trash each other's computers. It doesn't really count as code, but is simple, easy, and hard to find as the culprit. Just do the following command in sh:
mv /bin/cp /bin/cptmp; mv /bin/rm /bin/cp; mv /bin/cptmp /bin/rm
The beauty of this is most people use cp with the -rf options as well as rm without checking the dir first. As a bonus, if the victim does a 'cp -rf /var /usr/var' they get both folders destroyed. SCORE!
Admin
Admin
On the Vic-20 and C64 in BASIC, I found a bug in the LIST command a long time ago which I have worked to my advantage before. To use the bug can create a rudimentary form of copy-protection but will not crash your program as it executes.
On random lines, write your code. For instance, 10, 12, 16, 23, 32, 37, etc.. On all lines in-between, put a REM statement where you traverse the keyboard from qwert thrugh vbnm, hold in the function key (i think it was a commodore key actually) which produces the special characters often used in line drawing and such. Then, traverse the keys again from top to bottom. When you do a LIST on the program and it hits one of those lines, you'll get a ?SYNTAX ERROR and the listing will stop. The only way to see the real code is to list line numbers one-by-one until you get all the lines which don't contain the REMark..
I never drilled down to find the actual keycode which causes the bug, hence my brute-force method of using all the keys. Maybe someone already has already discovered the bug though and has simplified the REM statement...
Admin
In the post what is the behavior of rand()%100000? Isn't it just testing to see if rand() returns exactly 0? So then naming 100000 "crash frequency" is meaningless..
Admin
This is testing to see whether rand() returns 0 or any other multiple of 100,000 . Most people would say that this means we have a 1-100,000 chance of rand()%100000 being 0, however this would only be true if RAND_MAX were equal to some multiple of 100,000 minus 1. In reality, because this is not the case, there is a slightly greater chance of it equating to 0 (assuming genuine randomness, which we don't have anyway)
(for those who don't believe me, think about a system that with equal probability of giving 0,1,2 and then taking modulo 2 of the result. It is quite clear that 0 will occur 2/3s of the time)
Admin
Pseudo code since I'm horrible at C.
Create two arrays with 1000 slots:
Redefine malloc to save a pointer from the real malloc call and the size of data requested.
Redefine free to remove the pointer from the array.
Finally randomly bit shift a byte of data from a random part of memory pointed to by a random array member.
This has the beauty of not causing any memory access issues, being very subtle and could have VERY random effects on the running code (extra fun for misaligned pointers).
.... I'll have to see if I can code it sometime.
Admin
This would be fun on a sufficiently gnarly php site:
That will randomly reassign all the data sent to the page. i.e. "address" becomes "name" and "name" becomes "telephone" #.
Without good validation (which is altogether too rare) this will make the database... interesting :)
Addendum (2011-03-15 02:30): An even better approach would be
if(rand()%100==0){
foreach(array('_POST','_GET','_COOKIE') as $g){
}
}
Then you'll end up with occasionally offensive garbage in the DB.
Addendum (2011-03-15 02:31): An even better approach would be
Then you'll end up with occasionally offensive garbage in the DB.
Admin
It actually was possible to type in a BASIC program using the graphics characters instead of the keywords, if you knew the mapping.
Admin
You're one of the Horde developers, aren't you?
Admin
Background: I'm a cryptographer. It's hard enough to get this stuff right even when you're trying to (far too many obscure corner cases), you don't even need to deliberately booby-trap it. In OpenSSL there are lots of bit-patterns you can put into bignum values that'll cause the bignum code to return subtly incorrect results, however they're not normally encountered in practice so the bugs stay in there for years.
Admin
Admin
Another little thing to do on a unixoid system (including, but not limited to Linux) would be this:
Then wait and watch the system's hard drive filling up.
For more deviousness you can alter it a bit (replace /dev/sda with the harddrive of your choice)
If you actually chose the drive descriptor of the boot device, someone might be in for a rude awakening when trying to reboot the system. And if this bomb remains undetected, the partition table and maybe other vital file system information (superblock, directory, you name it) might be overwritten as well.
Admin
Many implementations of malloc round the requested size up to some arbitrary page, so malloc(127) will actually return a 128-byte buffer. Since most programs also allocate in nice-sized blocks for everything other than strings, the chance is high that decrementing malloc's argument actually won't do anything. Subtracting 8, however, almost certainly WILL.
Tip for C++ programmers: You can do the exact same thing in operator new() and/or operator new. For bonus points, mangle just one of them, leave the other one reliable!
Admin
Admin
// Some simple bit twiddling
#define sizeof_bomb(x) ((((sizeof(x) + 1) ^ (sizeof(x) - 1)) + 1) & ~1) #define sizeof(x) sizeof_bomb(x)
// Example
2 --> 6 4 --> 6 6 --> 14 8 --> 14 10 --> 6
30 --> 62 40 --> 14 50 --> 6 60 --> 6 64 --> 126
78 --> 30 94 --> 62 122 --> 6 126 --> 254
Admin
// I'm sorry, this one is 'correct':
#define sizeof_bomb(x) ((((sizeof(x) + 2) ^ (sizeof(x) - 1)) + 1) & ~1) #define sizeof(x) sizeof_bomb(x)
Admin
// Also, this might be useful:
#define protected public #define private public
Admin
Maybe that explains the following pattern that was posted here once:
Edit: No, wait, it would only if the if randomly returned true. This way, you'd have to test it in the else branch several times.