JJ.Framework.Existence.Core
2.8.4205
Prefix Reserved
dotnet add package JJ.Framework.Existence.Core --version 2.8.4205
NuGet\Install-Package JJ.Framework.Existence.Core -Version 2.8.4205
<PackageReference Include="JJ.Framework.Existence.Core" Version="2.8.4205" />
<PackageVersion Include="JJ.Framework.Existence.Core" Version="2.8.4205" />
<PackageReference Include="JJ.Framework.Existence.Core" />
paket add JJ.Framework.Existence.Core --version 2.8.4205
#r "nuget: JJ.Framework.Existence.Core, 2.8.4205"
#:package JJ.Framework.Existence.Core@2.8.4205
#addin nuget:?package=JJ.Framework.Existence.Core&version=2.8.4205
#tool nuget:?package=JJ.Framework.Existence.Core&version=2.8.4205
Existence.Core
Ever find yourself trying to decide on IsNullOrEmpty
, IsNullOrWhiteSpace
, a null
check, empty list check or whether you should check at all?
Well, no more. Now you just type Has(text)
or Has(collection)
and be done with it.
Background
Nothing isn't one thing in .NET
. It's null
, default
, white space, 0
, NaN
, Empty
, Length = 0
, !Equals(x, default(T?)) && !Equals(x, default(T))
. It gets quite absurd with the many states of nothingness in .NET
.
Here we coin the term nully. Don't blame us; the concept already existed, just nobody dared give it a name yet.
Features
Grab these methods instead of wrestling with these checks. Your code (and your brain) will thank you:
Has
/FilledIn
/IsNully
- One step beyond
null
treating emptystrings
/ white space /0
/ empty lists asnully
.
- One step beyond
Coalesce
- Pick the first non-
nully
value (??
on steroids).
- Pick the first non-
In
/Contains
- "Is this in that?" tests for collections.
Is
- Loose equality (case/trim-insensitive, etc.) when you don't care about exact matches.
Flags for special occasions:
spaceMatters
spaceMatters
flags everywhere – because sometimes you really care if yourstring
is just a single space.
caseMatters
- To keep us sane as long as possible, the default is to not trip over case mismatches: GREEN = green. The caseMatters flag can make things stricter and case-sensitive again.
Examples
list = list.Where(FilledIn);
if (number.IsNully()) return;
if (Has(name)) sb.Append($" {name} ");
Coalesce(" ", null, "Hi!") == "Hi!"
"\r\n GREEN\t ".Is("Green")
"GREEN".In("Red", "Green","Blue") == true!
Coming Soon
zeroMatters
– flip the switch if you consider0
meaningful.flex
mode – force a full runtime type lookup on values when you're feeling adventurous.char
quirks – treat lone' '
as nully by default (no more sneaky space bugs).float
drama –NaN
,∞
,+0
/–0
all count as empty.enum
safety net – invalid enum values get flagged as nully instead of blowing up.- all-
null
collections – if every item isnull
, the whole collection is officially empty. - ultra-loose
Is
–10.Is("10")
regardless of type, because how will we stay sane if10
isn't10
?
Release Notes
2.5
Initial release
2.6
Flags
spaceMatters
flags everywherecaseMatters
replacedignoreCase
StringBulder
/string
more combos possiblex.In(a, b, c)
extension favored over staticIn(x, a, b, c)
2.7
Technical
- Improved separation of
Legacy
version lineages for a more stable package update.
2.8
Technical
- Compatibility with AOT "Ahead-Of-Time" native compilation, core trimming and single-executable, self-contained apps.
After Upgrading
Links to legacy dependencies may have changed. If you experience problems, these things might help:
Option 1
- Do nothing. Everything works.
Option 2
- Use the JJ.Framework.Common.Legacy namespace where you currently use JJ.Framework.Common.
Option 3
- Install JJ.Framework.Common explicitly. You may need a downgrade to a
0.*
version.
The same thing applies to JJ.Framework.PlatformCompatibility.Legacy vs JJ.Framework.PlatformCompatibility
🐨 Mr. Koala
Special thanks to Mr. Koala. Once you think of koalas when you read 🐨 Coalesce
, you can never unsee it. Mr. Koala eats your nullies. Nully nums
are his favorite!
💬 Feedback
Found an issue? Let me know.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- JetBrains.Annotations (>= 2024.3.0)
- JJ.Framework.Common.Core (>= 2.8.4205)
- JJ.Framework.Common.Legacy (>= 0.250.4205)
- System.Collections.Immutable (>= 1.5.0)
- System.Memory (>= 4.5.5)
-
.NETStandard 2.1
- JetBrains.Annotations (>= 2024.3.0)
- JJ.Framework.Common.Core (>= 2.8.4205)
- JJ.Framework.Common.Legacy (>= 0.250.4205)
- System.Collections.Immutable (>= 1.5.0)
- System.Memory (>= 4.5.5)
-
net6.0
- JetBrains.Annotations (>= 2024.3.0)
- JJ.Framework.Common.Core (>= 2.8.4205)
- JJ.Framework.Common.Legacy (>= 0.250.4205)
- System.Collections.Immutable (>= 1.5.0)
- System.Memory (>= 4.5.5)
-
net7.0
- JetBrains.Annotations (>= 2024.3.0)
- JJ.Framework.Common.Core (>= 2.8.4205)
- JJ.Framework.Common.Legacy (>= 0.250.4205)
- System.Collections.Immutable (>= 1.5.0)
- System.Memory (>= 4.5.5)
-
net8.0
- JetBrains.Annotations (>= 2024.3.0)
- JJ.Framework.Common.Core (>= 2.8.4205)
- JJ.Framework.Common.Legacy (>= 0.250.4205)
- System.Collections.Immutable (>= 1.5.0)
- System.Memory (>= 4.5.5)
-
net9.0
- JetBrains.Annotations (>= 2024.3.0)
- JJ.Framework.Common.Core (>= 2.8.4205)
- JJ.Framework.Common.Legacy (>= 0.250.4205)
- System.Collections.Immutable (>= 1.5.0)
- System.Memory (>= 4.5.5)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.