[lib][vmo_store] Add OwnedVmoStore

- Add OwnedVmoStore, which only allows VMO registration through
`RegistrationAgent`s.
- Cleaned up some existing tests to use the predicates testing library.
- Added a test proving that move-only metadata is allowed.
- Added example usage documentation to VmoStore and OwnedVmoStore.
- Protected store instantiation with static assertions to emit better
errors.

Test: Added unit tests. `fx run-test vmo-store-test`
Change-Id: Ic05bde306ab72f2830237b596aac89db08d549ea
Reviewed-on: https://fuchsia-review.googlesource.com/c/fuchsia/+/376765
Commit-Queue: Bruno Dal Bo <brunodalbo@google.com>
Reviewed-by: Suraj Malhotra <surajmalhotra@google.com>
Testability-Review: Suraj Malhotra <surajmalhotra@google.com>
8 files changed
tree: f96bce42e8fb65935c47ad6b03ca379d0c9394f1
  1. boards/
  2. build/
  3. bundles/
  4. docs/
  5. examples/
  6. garnet/
  7. products/
  8. scripts/
  9. sdk/
  10. src/
  11. third_party/
  12. tools/
  13. zircon/
  14. .clang-format
  15. .clang-tidy
  16. .dir-locals.el
  17. .gitattributes
  18. .gitignore
  19. .gn
  20. .style.yapf
  21. AUTHORS
  22. BUILD.gn
  23. CODE_OF_CONDUCT.md
  24. CONTRIBUTING.md
  25. LICENSE
  26. OWNERS
  27. PATENTS
  28. README.md
  29. rustfmt.toml
README.md

Fuchsia

Pink + Purple == Fuchsia (a new operating system)

What is Fuchsia?

Fuchsia is a modular, capability-based operating system. Fuchsia runs on modern 64-bit Intel and ARM processors.

Fuchsia is an open source project with a code of conduct that we expect everyone who interacts with the project to respect.

How can I build and run Fuchsia?

See Getting Started.

Where can I learn more about Fuchsia?

See fuchsia.dev.