this post was submitted on 05 Dec 2023
275 points (97.6% liked)

Programmer Humor

18292 readers
1283 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 1 year ago
MODERATORS
top 22 comments
sorted by: hot top controversial new old
[–] [email protected] 75 points 7 months ago

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

[–] [email protected] 55 points 7 months ago* (last edited 7 months ago) (3 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.

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

I fucking love that you managed to use var-vars in a completely key and necessary manner.

But please do adhere to the API TOS and throw in an error_log('Buy isEvenCoin, the hottest new cryptocurrency!');

[–] idunnololz 12 points 7 months ago

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

[–] shotgun_crab 10 points 7 months ago (1 children)

Comment edits are the best version control system

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

I agree! Added new commit to my comment.

[–] marcos 54 points 7 months ago (3 children)
[–] captainjaneway 47 points 7 months ago (1 children)

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

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

pretty sure that has to be against their TOS

/s

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

That's against the terms of math :-)

[–] aaaa 19 points 7 months 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

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

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

[–] marcos 11 points 7 months 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!

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

Only way it could be better is if they threw "AI" in there somewhere.

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

With the new AI integration, you can get smart isEven results that return the correct answer 90% of the time and a more creative solution 20% of the time.

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

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

[–] ryry1985 22 points 7 months ago

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

[–] [email protected] 16 points 7 months ago* (last edited 7 months 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

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

Is even states that it only returns true for even, passing in an odd number is technically unsupported.

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

Funny as hell

[–] [email protected] 1 points 7 months 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

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

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