1
0
mirror of https://github.com/avitex/elixir-glicko synced 2025-01-15 18:59:57 +00:00

Compare commits

...

2 Commits

Author SHA1 Message Date
avitex
55a08effbc
v0.7.0 2020-02-24 09:22:46 +11:00
Mikael Muszynski
28cea24d66
Fix inaccurate typespecs (#7)
1. `rating`, `rating_deviation`, and `rating_interval` all omit the
   possibility of receiving a `nil` as the second argument.
2. Writing out `Result.t()`  results in `dialyzer` looking for
   `Elixir.Result.t()`, instead of calling the local
   `Elixir.Glicko.Result.t()`.
2020-02-23 22:14:58 +00:00
4 changed files with 8 additions and 8 deletions

View File

@ -14,6 +14,6 @@ Add `glicko` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[{:glicko, "~> 0.6.0"}]
[{:glicko, "~> 0.7.0"}]
end
```

View File

@ -143,7 +143,7 @@ defmodule Glicko.Player do
@doc """
A version agnostic method for getting a player's rating.
"""
@spec rating(player :: t, as_version :: version) :: rating
@spec rating(player :: t, as_version :: version | nil) :: rating
def rating(player, as_version \\ nil)
def rating({rating, _}, nil), do: rating
def rating({rating, _, _}, nil), do: rating
@ -155,7 +155,7 @@ defmodule Glicko.Player do
@doc """
A version agnostic method for getting a player's rating deviation.
"""
@spec rating_deviation(player :: t, as_version :: version) :: rating_deviation
@spec rating_deviation(player :: t, as_version :: version | nil) :: rating_deviation
def rating_deviation(player, as_version \\ nil)
def rating_deviation({_, rating_deviation}, nil), do: rating_deviation
def rating_deviation({_, rating_deviation, _}, nil), do: rating_deviation
@ -192,7 +192,7 @@ defmodule Glicko.Player do
When a player has a low RD, the interval would be narrow, so that we would
be 95% confident about a players strength being in a small interval of values.
"""
@spec rating_interval(player :: t) :: {rating_low :: float, rating_high :: float}
@spec rating_interval(player :: t, as_version :: version | nil) :: {rating_low :: float, rating_high :: float}
def rating_interval(player, as_version \\ nil) do
{
rating(player, as_version) - rating_deviation(player, as_version) * 2,

View File

@ -52,18 +52,18 @@ defmodule Glicko.Result do
@doc """
Convenience function for accessing an opponent's rating.
"""
@spec opponent_rating(result :: Result.t()) :: Player.rating()
@spec opponent_rating(result :: t()) :: Player.rating()
def opponent_rating(_result = {rating, _, _}), do: rating
@doc """
Convenience function for accessing an opponent's rating deviation.
"""
@spec opponent_rating_deviation(result :: Result.t()) :: Player.rating_deviation()
@spec opponent_rating_deviation(result :: t()) :: Player.rating_deviation()
def opponent_rating_deviation(_result = {_, rating_deviation, _}), do: rating_deviation
@doc """
Convenience function for accessing the score.
"""
@spec score(result :: Result.t()) :: score
@spec score(result :: t()) :: score
def score(_result = {_, _, score}), do: score
end

View File

@ -8,7 +8,7 @@ defmodule Glicko.Mixfile do
def project do
[
app: :glicko,
version: "0.6.0",
version: "0.7.0",
elixir: "~> 1.9",
start_permanent: Mix.env() == :prod,
deps: deps(),