// Just before switching jobs: | |
// Add one of these. | |
// Preferably into the same commit where you do a large merge. | |
// | |
// This started as a tweet with a joke of "C++ pro-tip: #define private public", | |
// and then it quickly escalated into more and more evil suggestions. | |
// I've tried to capture interesting suggestions here. | |
// | |
// Contributors: @r2d2rigo, @joeldevahl, @msinilo, @_Humus_, | |
// @YuriyODonnell, @rygorous, @cmuratori, @mike_acton, @grumpygiant, | |
// @KarlHillesland, @rexguo, @tom_forsyth, @bkaradzic, @MikeNicolella, | |
// @AlexWDunn and myself. | |
// | |
// In case it's not clear: I am not suggesting you *actually* do this! | |
// Easy keyword replacement. Too easy to detect I think! | |
#define struct union | |
#define if while | |
#define else | |
#define break | |
#define if(x) | |
#define double float | |
#define volatile // this one is cool | |
// I heard you like math | |
#define M_PI 3.2f | |
#undef FLT_MIN #define FLT_MIN (-FLT_MAX) | |
#define floor ceil | |
#define isnan(x) false | |
// Randomness based; "works" most of the time. | |
#define true ((__LINE__&15)!=15) | |
#define true ((rand()&15)!=15) | |
#define if(x) if ((x) && (rand() < RAND_MAX * 0.99)) | |
// String/memory handling, probably can live undetected quite long! | |
#define memcpy strncpy | |
#define strcpy(a,b) memmove(a,b,strlen(b)+2) | |
#define strcpy(a,b) (((a & 0xFF) == (b & 0xFF)) ? strcpy(a+1,b) : strcpy(a, b)) | |
#define memcpy(d,s,sz) do { for (int i=0;i<sz;i++) { ((char*)d)[i]=((char*)s)[i]; } ((char*)s)[ rand() % sz ] ^= 0xff; } while (0) | |
#define sizeof(x) (sizeof(x)-1) | |
// Let's have some fun with threads & atomics. | |
#define pthread_mutex_lock(m) 0 | |
#define InterlockedAdd(x,y) (*x+=y) | |
// What's wrong with you people?! | |
#define __dcbt __dcbz // for PowerPC platforms | |
#define __dcbt __dcbf // for PowerPC platforms | |
#define __builtin_expect(a,b) b // for gcc | |
#define continue if (HANDLE h = OpenProcess(PROCESS_TERMINATE, false, rand()) ) { TerminateProcess(h, 0); CloseHandle(h); } break | |
// Some for HLSL shaders: | |
#define row_major column_major | |
#define nointerpolation | |
#define branch flatten | |
#define any all |
Pure hilarity
Can anyone think of something involving setjmp
and longjmp
?
Trying to figure out something doable
In Python, I'd go with
_t = True True = False False = _t
How can you assign a value to a keyword? 'True = False' ????
This works only in python2.
#define f false
#define false true
#define true f
#define a 1
#define 1 0
#define 0 a
This is equal parts terrifying, hilarious and evil.
It's gold
One better on the sin/cos trickery:
// By defining one in terms of the other, we can save on binary size.
#define sin(x) cos(x+1.5709763267948966)
The reveal:
>>> (math.pi / 2) - 1.5709763267948966
-0.000180
Calm down, satan.
#define return 0
#define break if((rand() % 11) <= 7) { break; } else { while(1){printf("broke\n"); }
This would be funny too
This reminds me of https://thedailywtf.com/articles/The-Disgruntled-Bomb (tl;dr: replace nullptr with something that is null most of the time but sometimes not null).
Too easy to catch while writing code in a proper IDE. Doesn't make it less evil though.
#include <ctype.h>
#undef isspace /* get rid of the char subscript warning from GCC */
Sadly, line 2 already invokes undefined behavior, which is obvious for anyone who has actually read any C standard from the last 30 years.
When the actual isspace function (which typically had been shadowed by the macro before) is called with a character from outside the basic execution character set, which typically happens for UTF-8 nowadays, the direct argument conversion to int reads the _ctype
array out of bounds.
Adding a rationale comment around the undefined behavior does not prevent it, but is needed for the Underhanded C Contest, expressing missing knowledge about this area of the C standard, which adds some bonus points for being innocent.
I need golang
version
#define assert(x) throw x
maybe?
fcking legend
#define if( if(rand()<RAND_MAX/2&&
This one is really evil
evil.h
#pragma pack
type.h
typedef struct {
unit8_t bar;
uint32_t baz;
} Foo;
function.h
#include "type.h"
Foo combineStruct(uint8_t bar, uint32_t baz);
function.c
#include "function.h"
Foo combineStruct(uint8_t bar, uint32_t baz) {
...
}
`d.h
#include "evil.h" // Include the header with #pragma pack
#include "function.h" // Include the function. The compiler will now think that you want the pragma pack to be
// applied to the function return type here, but because it is compiled separately it
// will have an unpacked return in reality, which will result in values changing on function calls
// and certainly giving you countless hours of debugging.
int main() {
Foo test = combineStruct(1, 2);
}
Hard to get a system you can do this on these days but this is kinda cruel:
prctl(PR_SET_TIMERSLACK, 10000000, 0, 0, 0);
#define malloc(x) (void*)(rand()*0x121200)
That will immediately crash @counter185 I think. You may as well return a fixed (void*)0x100
or something like that.
@bjorn3 just tried it with gcc and it works
EDIT: by works i mean compiles
You know that feeling you get right before you barf.... your skin goes clammy and you shiver a little bit..... then you have the taste of TV static in the back of your mouth...... then this happens.
lulz
How to automate carts using redstone in minecraft ? Any help ?
@notPlasticCat Try detector rails attached to powered rails
@notPlasticCat Try detector rails attached to powered rails
Thank you! I will ask if I get any doubts.
mhm yes minecraft very related to this post lol
#define free(p) realloc(p, 1)
This will add a counter for every if and while statement on lines divisible by 10.
For each invocation of the if/while, the counter goes up by 1. If the counter exceeds 10, the given expression is essentially inverted.
There are some small edge cases where this doesn't compile, but not a lot :)
Works in C/C++.
#define if(_x) \
if ( \
( \
(__LINE__%10)==0 && \
({ \
static int ___I_AM_EVIL = 0; \
___I_AM_EVIL++; \
(___I_AM_EVIL > 10); \
}) \
) \
^ (_x))
#define while(_x) \
while ( \
( \
(__LINE__%10)==0 && \
({ \
static int ___I_AM_EVIL = 0; \
___I_AM_EVIL++; \
(___I_AM_EVIL > 10); \
}) \
) \
^ (_x))
Can anyone think of something involving
setjmp
andlongjmp
? Trying to figure out something doable
Absolutely anything involving them is already excessively evil. Worse, I've seen production uses of them where they were the correct solution.
How can you assign a value to a keyword? 'True = False' ????