# petrovic_elixir
[](https://github.com/petrovich/petrovich_elixir)
[](https://travis-ci.org/petrovich/petrovich_elixir) [](https://coveralls.io/github/petrovich/petrovich_elixir?branch=master) [](https://hex.pm/packages/petrovich_elixir) [](http://opensource.org/licenses/MIT)
Elixir library to inflect Russian first, last, and middle names.
## Installation
The package can be installed
by adding `petrovich_elixir` to your list of dependencies in `mix.exs`:
```elixir
def deps do
  [{:petrovich_elixir, "~> 0.1"}]
end
```
## Usage
### Do I need to know Russian to use it?
Yes, you will need some basic Russian knowledge to work with this library.
You need to understand how [grammatical cases](https://en.wikipedia.org/wiki/Grammatical_case) work in Russian language.
### Inflection
```elixir
Petrovich.firstname!("Александр", :accusative)
# => Александра
Petrovich.middlename!("Сергеевич", :accusative)
# => Сергеевича
Petrovich.lastname!("Пушкин", :accusative, :male)
# => Пушкина
```
### Gender detection
```elixir
alias Petrovich.Detector
Detector.detect_gender("Александр", :firstname)
# => {:ok, "male"}
```
## Configuration
You will need to add these lines into your `config.exs`:
```elixir
config :petrovich_elixir,
  rules_path: "rules/rules.json",
  gender_path: "rules/gender.json"
```
## Rules
This package uses [`petrovich-rules`](https://github.com/petrovich/petrovich-rules) as the source for all transformations. If you ever experience wrong result or other issues with the data itself, please open an issue [here](https://github.com/petrovich/petrovich-rules/issues).
## License
MIT. See [LICENSE](/LICENSE) for details.