0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-10 00:40:30 -05:00
penpot/docs/04-Common-Developer-Guide.md

62 lines
1.5 KiB
Markdown
Raw Normal View History

2020-01-21 18:15:57 -05:00
# Common's guide #
This section intends to have articles that related to both frontend
and backend, such as: code style hints, architecture dicisions, etc...
## Assertions ##
2020-10-28 03:34:47 -05:00
Penpot source code has this types of assertions:
2020-01-21 18:15:57 -05:00
2020-03-08 07:13:32 -05:00
**assert**: just using the clojure builtin `assert` macro.
2020-01-21 18:15:57 -05:00
Example:
```clojure
(assert (number? 3) "optional message")
```
2020-03-08 07:13:32 -05:00
This asserts are only executed on development mode. On production
environment all assets like this will be ignored by runtime.
2020-08-18 12:40:49 -05:00
**spec/assert**: using the `app.common.spec/assert` macro.
2020-03-08 07:13:32 -05:00
2020-01-21 18:15:57 -05:00
Also, if you are using clojure.spec, you have the spec based
`clojure.spec.alpha/assert` macro. In the same way as the
`clojure.core/assert`, on production environment this asserts will be
removed by the compiler/runtime.
Example:
````clojure
2020-03-08 07:13:32 -05:00
(require '[clojure.spec.alpha :as s]
2020-08-18 12:40:49 -05:00
'[app.common.spec :as us])
2020-01-21 18:15:57 -05:00
(s/def ::number number?)
2020-03-08 07:13:32 -05:00
(us/assert ::number 3)
2020-01-21 18:15:57 -05:00
```
2020-03-08 07:13:32 -05:00
In the same way as the `assert` macro, this performs the spec
assertion only on development build. On production this code will
completely removed.
**spec/verify**: An assertion type that is executed always.
2020-01-21 18:15:57 -05:00
Example:
```clojure
2020-08-18 12:40:49 -05:00
(require '[app.common.spec :as us])
2020-01-21 18:15:57 -05:00
2020-03-08 07:13:32 -05:00
(us/verify ::number 3)
2020-01-21 18:15:57 -05:00
```
This macro enables you have assetions on production code.
2020-08-18 12:40:49 -05:00
**Why don't use the `clojure.spec.alpha/assert` instead of the `app.common.spec/assert`?**
2020-03-08 07:13:32 -05:00
2020-10-28 03:34:47 -05:00
The Penpot variant does not peforms additional runtime checks for know
2020-03-08 07:13:32 -05:00
if asserts are disabled in "runtime". As a result it generates much
simplier code at development and production builds.
2020-01-21 18:15:57 -05:00