Go to file
Christian Kamm 6f72cd27e8 Serum: Cancel order instruction 2022-03-19 12:19:16 +01:00
.cargo suppress known issues 2022-03-01 06:16:10 +01:00
.github/workflows CI: Fix test runs 2022-03-13 15:45:50 +01:00
lib/checked_math Add checked_math library for convenient overflow checking 2022-03-13 15:45:50 +01:00
migrations First commit 2022-01-21 19:21:46 +01:00
programs Serum: Cancel order instruction 2022-03-19 12:19:16 +01:00
py rename 2022-03-01 20:55:10 +01:00
ts change seeds literals to camelcase, camel case was how mango did in v3, also matches struct names 2022-03-11 20:10:15 +01:00
.gitignore margin trade test 2022-03-07 15:24:50 +01:00
Anchor.toml Enable anchor seeds extraction 2022-02-23 10:55:23 +01:00
Cargo.lock Serialization of new serum order instruction data 2022-03-14 15:28:06 +01:00
Cargo.toml Add checked_math library for convenient overflow checking 2022-03-13 15:45:50 +01:00
README.md extract health, flesh out margin trade, todo - test 2022-03-03 11:43:56 +01:00
package.json bump anchor ts lib 2022-02-23 11:10:50 +01:00
release.sh prepare for monorepo 2022-03-01 20:48:59 +01:00
tsconfig.json prepare for monorepo 2022-03-01 20:48:59 +01:00
yarn.lock bump anchor ts lib 2022-02-23 11:10:50 +01:00

README.md

Development

  • rustc 1.57.0 (f1edd0429 2021-11-29)
  • anchor-cli 0.22.0
  • npm 8.1.2
  • node v16.13.1

Module structure

As and when we move to a more complete project, we should think of having multiple modules e.g. core/shared, spot, perpetuals, etc., and then each would have its own instructions and state sub module. Goal is that new contributors find relevant code easily and can navigate easily.

programs
└── mango-v4
    ├── Cargo.toml
    ├── Xargo.toml
    └── src
    │    ├── error.rs
    │    ├── instructions # instructions go here, each instruction gets an individual file
    │    │   ├── initialiaze.rs
    │    │   └── mod.rs
    │    ├── lib.rs
    │    └── state # state goes here, each account state gets an individual file
    │       └── mod.rs
    └── tests # rust tests, TODO  

How to open and manage pull requests

  • when in doubt dont squash commits, specially when merge request is very large, specially if your branch contains unrelated commits
  • use the why along with what for commit messages, code comments, makes it easy to understand the context
  • add descriptions to your merge requests if they are non trivial, helps code reviewer watch out for things, understand the motivation for the merge request