this post was submitted on 05 Dec 2023
261 points (97.5% liked)

Programmer Humor

25671 readers
1601 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
top 20 comments
sorted by: hot top controversial new old
[–] 4am@lemm.ee 68 points 2 years ago

Incoming trademark lawsuit from iSeven, the API that tells you if a number is seven or not

[–] rikudou@lemmings.world 50 points 2 years ago* (last edited 2 years ago) (2 children)

If anyone wants a more efficient local version for php:

function isEven(int $number): bool
{
    ${1} = false;
    ${2} = true;

    while ($number > 2) {
        $number -= 2;
    }

    return $$number;
}

Edit: Now with support for large numbers!

function isEven(int|string $number): bool
{
    ${1} = false;
    ${2} = true;

    while (bccomp($number, 2) === 1) {
        $number = bcsub($number, 2);
    }

    $number = (int) $number;
    return $$number;
}

Edit 2: someone asked for an ad-supported version, here you go!

function isEven(int|string $number): bool
{
    ${1} = false;
    ${2} = true;

    while (bccomp($number, 2) === 1) {
        error_log('Buy isEvenCoin, the hottest new cryptocurrency!');
        $number = bcsub($number, 2);
    }

    $number = (int) $number;
    return $$number;
}

Side note, no more suggestions please, this is getting quite long.

[–] idunnololz@lemmy.world 9 points 2 years ago

This looks pretty inefficient. You should manually unroll that loop to improve performance.

[–] shotgun_crab@lemmy.world 8 points 2 years ago (1 children)

Comment edits are the best version control system

[–] rikudou@lemmings.world 3 points 2 years ago

I agree! Added new commit to my comment.

[–] marcos@lemmy.world 49 points 2 years ago (3 children)
[–] captainjaneway@lemmy.world 42 points 2 years ago (1 children)

Just divide that number by two until it's small enough to make the request under the free version.

[–] taaz@biglemmowski.win 35 points 2 years ago (1 children)

pretty sure that has to be against their TOS

/s

[–] mormegil@programming.dev 2 points 2 years ago

That's against the terms of math :-)

[–] aaaa@lemmy.world 18 points 2 years ago

That's not even supported by the enterprise version. You're going to need a special agreement with the iseven people to support numbers like that

[–] fckreddit@lemmy.ml 5 points 2 years ago (1 children)

Easy workaround, just test the last digit. If it is even, the entire number is even, else odd.

[–] marcos@lemmy.world 8 points 2 years ago

That's preposterous! Next time you'll tell me the language I'm using has a builtin operator that test if a number can be divided by another!

[–] rem26_art@kbin.social 21 points 2 years ago

im glad that people are out there building the web services we truly need.

[–] ryry1985@lemmy.world 17 points 2 years ago

I love that it works and the ads are pretty good.

[–] eluvatar@programming.dev 15 points 2 years ago* (last edited 2 years ago) (1 children)

The errors are great https://api.isevenapi.xyz/api/iseven/1.5

~~Sadly it's not always accurate https://api.isevenapi.xyz/api/iseven/0~~ Edit: nevermind I'm an idiot

It's also greatly lacking in number support https://api.isevenapi.xyz/api/iseven/one

[–] huf@hexbear.net 2 points 2 years ago (1 children)

zero is even, so i dont see how that one's wrong

[–] eluvatar@programming.dev 2 points 2 years ago

Oh you're right, I'm not sure what I was Ln thinking

[–] megaman@discuss.tchncs.de 7 points 2 years ago

Funny as hell

[–] morrowind@lemmy.ml 1 points 2 years ago (1 children)

I resent that there is a ruby developer included in there. isEven is not idiomatic naming. You should be using #even? from the standard library

[–] fckreddit@lemmy.ml 4 points 2 years ago

Sorry sir, most JS developers don’t use standard library functions. We just use npm packages wherever possible.