元件解析器

元件管理員會在相關環境中尋找支援相符網址配置的解析器,並使用 fuchsia.component.resolution.Resolver 通訊協定傳送要求,藉此解析元件網址。

如果解析度成功,元件解析器會傳回 ComponentDecl,這是元件資訊清單的 FIDL 表示法。如果解析的元件有相關聯的套件,則元件解析器也會傳回套件目錄的 fuchsia.io.Directory 控制代碼。

提供解析器功能

resolverpathfuchsia.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