[fidlc] Expose anonymous request/response structs in IR

These new structs (which represent request/response payloads)
will eventually be used as the source of truth for request/
response type/fieldshape info in fidlgen, which will allow us
to remove special handling of requests and responses.

In order to emit the request/response payloads as regular structs,
a temporary wire format kV1Header is added which is the same as
kV1NoEe except it does not treat request/response payloads specially
compared to regular structs (by ignoring the is_request_or_response field).

In addition, since both structs and requests/responses are generated
using the same Generate(flat::Struct) function in the json_generator,
this function now takes an extra bool to indicate whether its input
struct is a request or a response. This bool is set to true when called
from GenerateRequest in order to generate type info using the kV1NoEe
wire format. Otherwise, the kV1Header wire format is used.

Change-Id: I605fd790ef312e20842fc3574871d95276f1e68d
22 files changed
tree: 09a817662b884bfa4f3b7602ae0af9a865d89a6b
  1. boards/
  2. build/
  3. bundles/
  4. docs/
  5. examples/
  6. garnet/
  7. peridot/
  8. products/
  9. scripts/
  10. sdk/
  11. src/
  12. third_party/
  13. tools/
  14. zircon/
  15. .clang-format
  16. .clang-tidy
  17. .dir-locals.el
  18. .gitattributes
  19. .gitignore
  20. .gn
  21. .style.yapf
  22. AUTHORS
  23. BUILD.gn
  24. CODE_OF_CONDUCT.md
  25. CONTRIBUTING.md
  26. LICENSE
  27. OWNERS
  28. PATENTS
  29. README.md
  30. 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.