aaagain 1.1.0
Associative arrays with support for custom allocators.
To use this package, run the following command in your project's root directory:
						Manual usage
						
						Put the following dependency into your project's dependences section:
					
Associative Arrays Again?!
A copy of the associative array implementation from DRuntime, but with no reliance on runtime type information, and support for allocating using custom allocators!
The interface is almost identical to the built-in associative array, but with a few small differences:
import aaagain;
SomeAllocator alloc, alloc2;
SomeOtherAllocator alloc3;
/*
AA must be explicitly allocated.
You can specify different allocators for allocating the AA itself, its buckets, and its entries.
The allocator instance for buckets and entries can be the same if they are a global allocator.
*/
auto myAA = newAA!(string, int)(
	aaAllocator: alloc3,
	bucketAllocator: alloc,
	entryAllocator: alloc2,
);
myAA["twenty"] = 20;
assert("twenty" in myAA);
assert(*("twenty" in myAA) == 20);
assert(myAA["twenty"] == 20);
//`opApply` is not supported. Use `byKey`, `byValue`, or `byKeyValue` instead:
foreach(key; myAA.byKey)
	assert(key == 20);
foreach(value; myAA.byValue)
	assert(value == 20);
//`get` and `require` take a function/delegate instead of a `lazy` value:
assert(myAA.get("fourty", () => 40) == 40);
assert(myAA.require("twenty", () => 21) == 20);
myAA.update(
	key: "fifty",
	create: () => 50,
	update: (int _) => 51,
);
assert(myAA["fifty"] == 50);
//The `update` delegate can take its parameter by `ref` and return `void`:
myAA.update(
	key: "fifty",
	create: () => 50,
	update: (ref int i){ i = 51; },
);
assert(myAA["fifty"] == 51);
//Associative array literals are constructed with `aaLiteral`:
{
	auto aaCmp = aaLiteral(alloc, alloc2, "twenty",20, "fifty",51);
	assert(myAA == aaCmp);
	aaCmp.dispose(alloc);
}
myAA.remove("fifty");
import memterface.ctor: dispose;
//there is `.getKeys` instead of `.keys`, which uses manual memory management:
auto keyArray = myAA.getKeys(alloc3);
assert(keyArray == ["twenty"]);
alloc3.dispose(keyArray);
//Likewise for `.values`:
auto valueArray = myAA.getValues(alloc2);
assert(valueArray == [20]);
alloc2.dispose(valueArray);
//These ranges yield `ref const` item instead of `ref` for safety reasons:
foreach(key; myAA.byKey){
	assert(key == "twenty");
}
foreach(value; myAA.byValue){
	assert(value == 20);
}
foreach(item; myAA.byKeyValue){
	assert(item.key == "twenty");
	assert(item.value == 20);
}
//Must explicitly destroy AA with the same allocator that allocated it:
myAA.dispose(alloc3);
The AA type is just a container for a pointer, just like the built-in associative array:
AA!(string, int) aa;
static assert(aa.sizeof == int[string].sizeof);
auto aa2 = aa;
aa["one"] = 1;
assert("one" in aa2);
Advanced users can tinker with the parameters of the associative array by supplying the AAParams template parameter:
AA!(K, V, Allocator, AAParams(
	//numerator,denominator pairs for the grow/shrink thresholds:
	grow: 4, 5,
	shrink: 1, 8,
	//the growth factor:
	growFactor: 4,
));
- 1.1.0 released 8 months ago
- ichordev/aaagain
- BSL-1.0
- Copyright Digital Mars
- Authors:
- Dependencies:
- memterface
- Versions:
- 
						
 Show all 6 versions1.1.3 2025-Aug-30 1.1.2 2025-Aug-23 1.1.1 2025-Aug-20 1.1.0 2025-Feb-25 1.0.0 2025-Feb-23 
- Download Stats:
- 
						- 
								0 downloads today 
- 
								0 downloads this week 
- 
								0 downloads this month 
- 
								0 downloads total 
 
- 
								
- Score:
- 0.4
- Short URL:
- aaagain.dub.pm