元件管理員會在相關環境中尋找支援相符網址配置的解析器,並使用 fuchsia.component.resolution.Resolver
通訊協定傳送要求,藉此解析元件網址。
如果解析度成功,元件解析器會傳回 ComponentDecl
,這是元件資訊清單的 FIDL 表示法。如果解析的元件有相關聯的套件,則元件解析器也會傳回套件目錄的 fuchsia.io.Directory
控制代碼。
提供解析器功能
resolver
path
fuchsia.component.resolution.Resolver
{
capabilities: [
{
resolver: "my_resolver",
path: "/svc/fuchsia.component.resolution.Resolver",
},
],
}
元件管理員會提出要求,將元件網址解析為這個通訊協定。
轉送解析器功能
元件會將解析器功能exposing給父項,並提供給其子項,藉此轉送解析器功能。
如要進一步瞭解架構路徑元件功能,請參閱「功能轉送」。
公開
公開解析器能力可讓元件的父項使用該能力:
{
expose: [
{
resolver: "my_resolver",
from: "self",
},
],
}
提供
提供解析器能力可讓子項元件存取該能力:
{
offer: [
{
resolver: "my_resolver",
from: "self",
to: [ "#child-a" ],
},
],
}
註冊元件解析器
元件解析器可透過其環境提供給元件。如要在環境中註冊新的解析器,請在 environments
宣告的 resolvers
區段新增項目:
environments: [
{
name: "my-environ",
extends: "realm",
resolvers: [
{
resolver: "my_resolver",
scheme: "my-scheme",
from: "parent",
}
],
},
]
已註冊的解析器可用來解析網址配置與提供的 scheme
相符的元件網址。
如要進一步瞭解如何將環境套用至元件,請參閱環境說明文件。
架構解析器
元件架構提供下列內建元件解析器,可支援標準 Fuchsia 網址配置:
解析器 | 網址配置 |
---|---|
boot_resolver |
fuchsia-boot |
base_resolver |
fuchsia-pkg |
full-resolver |
fuchsia-pkg |