Skip to content

Latest commit

 

History

History
144 lines (95 loc) · 3.6 KB

README.md

File metadata and controls

144 lines (95 loc) · 3.6 KB

timesorted: A Time-Sorted Sequence Library for Nim

timesorted is a Nim library that provides an implementation of a sequence of items sorted by time. It is designed to efficiently manage collections of timestamped data, ensuring that items are always maintained in chronological order.

Features

  • Automatic Sorting
  • Generic Type Support
  • Efficient
  • No Dependencies

Installation

Make sure you have Nim installed. You can download it from the official Nim website.

Using Nimble

If the package is available on Nimble, you can install it using:

nimble install timesorted

Manual Installation

Clone the repository:

git clone https://github.com/lilkeet/timesorted

Include the src directory in your project path or adjust the import statements accordingly.

Getting Started

Importing the Library

import timesortedseq
import timesortedseq/timestamp

Creating a TimeSortedSeq

Create a TimeSortedSeq instance parameterized with the type you wish to store. Included is a TimeStamp container type that adds a time to any Nim type.

var x = TimeSortedSeq[TimeStamp[int]]()

Adding Items

Add items to the sequence using the add proc. Each TimeStamp[T] has a value and a time field.

x.add TimeStamp[int](value: 10, time: initDateTime(2024, mFeb, 15))
x.add TimeStamp[int](value: 9, time: initDateTime(2024, mFeb, 16))
x.add TimeStamp[int](value: 8, time: initDateTime(2024, mFeb, 17))
x.add TimeStamp[int](value: 7, time: initDateTime(2024, mFeb, 14))

Accessing Items

Access items using standard indexing. The items are sorted chronologically.

echo x[0].value  # Outputs: 7
echo x[1].value  # Outputs: 10
echo x[2].value  # Outputs: 9
echo x[3].value  # Outputs: 8

Finding Insertion Index

Use insertIndexFor to find the index where a new item should be inserted to maintain chronological order. This is useful for finding items that are near each other in time.

let index = x.insertIndexFor(TimeStamp[int](value: 99, time: initDateTime(2024, mFeb, 15)))
echo index  # Outputs: 1

Finding Items

Use find to locate the index of an item in the sequence.

let idx = x.find(TimeStamp[int](value: 10, time: initDateTime(2024, mFeb, 15)))
echo idx  # Outputs: 1

Iterating Over the Sequence

Iterate over the sequence to access items in chronological order.

for item in x:
  echo item.value

Outputs:

7
10
9
8

You can also iterate with index:

for index, item in x:
  echo "Index ", index, ": ", item.value

Custom Types

This library relies on the existance of a symbol called timeGetter for any type that may be used with it. Here is a simple example of what this may look like:

import std/[times]

type MyCustomType = object
  myRecordedData: seq[uint8]
  timeOfRecording: DateTime

template timeGetter(x: MyCustomType): DateTime =
  x.timeOfRecording

timeGetter informs the library as to how decipher what time an object should be read as.

This library is agnostic to the implementation of a time type, so you can use the standard library's or some other one! All it needs is are < and ==.

License

This project is licensed under the WTFPL License. See the LICENSE file for details. This is free software. It comes without any warranty, to the extent permitted by applicable law.

Contributing

Contributions are welcome! Please open a pull request when you've completed your changes and I will review them.

Contact

For questions or suggestions, please open an issue on GitHub.