ResizeArray 0.18.0

dotnet add package ResizeArray --version 0.18.0
NuGet\Install-Package ResizeArray -Version 0.18.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ResizeArray" Version="0.18.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ResizeArray --version 0.18.0
#r "nuget: ResizeArray, 0.18.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ResizeArray as a Cake Addin
#addin nuget:?package=ResizeArray&version=0.18.0

// Install ResizeArray as a Cake Tool
#tool nuget:?package=ResizeArray&version=0.18.0

ResizeArray

code size license

ResizeArray is an F# extension and module library for ResizeArray<'T> ( = Collection.Generic.List<'T>)

It also works with Fable.

Logo

It Includes:

  • A ResizeArray module that has a corresponding functions for all functions in the Array module from FSharp.Core. Including those for parallel computing.

  • A Computational Expressions resizeArray that can be used like existing ones for seq.

  • Support for F# slicing operator and indexing from the end. e.g: items.[ 1 .. ^1]

  • Extension members on ResizeArray like .Get .Set .First .Last .SecondLast and more. With nicer IndexOutOfRangeExceptions that include the bad index and the actual size.

  • All Tests from the from FSharp.Core's Array module ported and adapted to run in both javascript and dotnet.

Usage

Just open the namespace

open ResizeArray

this namespace contains:

  • a module also called ResizeArray
  • a Computational Expressions called resizeArray
  • this will also auto open the extension members on ResizeArray<'T>

then you can do:

let evenNumbers =
    resizeArray {  // a Computational Expressions like seq
        for i = 0 t 99 do
            if i % 2 = 0 then
                i
    }

let oddNumbers = evenNumbers |> ResizeArray.map (fun x -> x + 1) // ResizeArray module

let hundred = oddNumbers.Last // Extension member to access the last item in list

Why ?

Yes, F# Arrays and (linked) Lists can do these kind of operations on collections too. But ResizeArray (being mutable) still offers the best performance for collections that expand or shrink and need random access.

In fact FSharp.Core uses a very similar module internally

License

MIT

Test

All Tests from the from FSharp.Core's Array module ported and adapted to run in both javascript and dotnet. go to the tests folder

cd Tests

For testing with .NET using Expecto run

dotnet run

for testing with Fable.Mocha run

npm test

Changelog

0.18.0

  • add mapToArray
  • add failIfEmpty

0.17.0

  • don't fail on LastIndex when empty

0.16.0

  • add null checks
  • add 'partitionBy' functions
  • add equality checks for nested ResizeArrays
  • flip arg order of 'sub' function

0.15.0

Product Compatible and additional computed target framework versions.
.NET 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 was computed.  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 was computed.  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. 
.NET Framework net472 is compatible.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.18.0 150 2/25/2024
0.17.0 94 2/17/2024
0.16.0 95 1/28/2024
0.15.0-a 74 1/22/2024

- add mapToArray
     - add failIfEmpty