aboutsummaryrefslogtreecommitdiffstats
path: root/library/README.md
blob: fc418bef7bb76c2043b5a4c496593542644a40b6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
library
===
`library/` is a directory with reusable libraries. Common ideas (with [key words](https://tools.ietf.org/html/rfc2119)):

1. Libraries are categorized by the languages in which they will be used.
    Bindings **MUST** be put in `<language>` directory.

2. Grouping by any other criteria **SHOULD** be defined by the language committee in `<language>` directory.

3. The library **SHOULD** be in use in at least two projects.
    
    If you are not sure if you should put some library in `library/`, please contact `<language>` committee or arcadia-wg@yandex-team.ru.

4. The library **SHOULD** be portable.

    Please contact `<language>` committee if you cannot provide usage on all platforms: `linux`, `darwin`, `windows`.

5. The library **MUST** depend only on a limited list of external components
    (currently it is `util/`, `contrib/`, `vendor/`, `library/`).

6. Any code in Arcadia (except `contrib/`, `vendor/` and `util/`) **MAY** depend on the `library/`.

7. The library **MUST** be accompanied by `README.md` file and a brief description of the project.

8. The library **MUST** be accompanied by unit-tests.

9. CPU- or/and RAM-bound algorithms **SHOULD** provide benchmarks.

10. There **MUST** be no trade secrets of Yandex in `library/`: anything that can cause harm on publishing as OpenSource. For example:
    * spam filter rules;
    * coefficients for ML;
    * etc.

11. All OSS (OpenSource Software) ready code **MUST** be accompanied by macro [LICENCE](https://docs.yandex-team.ru/ya-make/manual/common/macros#licence(license...)) in `ya.make`.

12. All language specific aspects are defined by `<language>` committee: see `library/<language>/README.md`.

13. The library **MUST** satisfy `<language>` style-guide.

14. The existing library **SHOULD** be improved instead of creating a new one - if it is possible.

    Please do not create yet another library for the same thing: just improve existing one.

Contacts
===
If you have any language-specific questions, please contact `<language>` [committee](https://wiki.yandex-team.ru/devrules/#profilnyekomitety).

If you have any other question about `library/`, please contact arcadia-wg@yandex-team.ru.