Skip to content

TimsortCppEx implements the C++ library TimSort, which is an implementation of the TimSort context-aware sorting algorithm.

Notifications You must be signed in to change notification settings

ckoch-cars/timsort_cpp_ex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TimsortCppEx

TimsortCppEx implements the C++ library TimSort, which is an implementation of the TimSort context-aware sorting algorithm.

Requirements

TimsortCppEx requires cmake to compile.

See Installing CMake

In order to use the TimSort library from Elixir, you will need to compile timsort.cpp to run on your machine. mix.exs has some steps to make a best-effort to handle this.

TimSort (C++) is built with CMake. The command to run and build the library should be: cmake -H. -Ssrc/cpp-TimSort -DCMAKE_BUILD_TYPE=Release -Bpriv/cpp-TimSort

When compiling src/timsort.cpp to work for your local environment, you may need to update the g++ args specified in Mix.Tasks.Compile.TimSort.run/1 (mix.exs) The "-I" flag arg will need to reflect your local installation of Erlang "-I/Users/christiankoch/erlang/22.0/erts-10.4/include"

Installation

Timsort needs to be comiled for your system however you only need to CMake timsort once on the system (and any time there are changes to the timsort C++ code).

Run ./src/setup.sh to build (CMake) timsort for your system.

If available in Hex, the package can be installed by adding timsort_cpp_ex to your list of dependencies in mix.exs:

def deps do
  [
    {:timsort_cpp_ex, "~> 0.1.0"}
  ]
end

Documentation can be generated with ExDoc and published on HexDocs. Once published, the docs can be found at https://hexdocs.pm/timsort_cpp_ex.

About

TimsortCppEx implements the C++ library TimSort, which is an implementation of the TimSort context-aware sorting algorithm.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published