xref: /aosp_15_r20/system/libvintf/include/vintf/ManifestInstance.h (revision 70a7ec852fcefd15a4fb57f8f183a8b1c3aacb08)
1*70a7ec85SAndroid Build Coastguard Worker /*
2*70a7ec85SAndroid Build Coastguard Worker  * Copyright (C) 2018 The Android Open Source Project
3*70a7ec85SAndroid Build Coastguard Worker  *
4*70a7ec85SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*70a7ec85SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*70a7ec85SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*70a7ec85SAndroid Build Coastguard Worker  *
8*70a7ec85SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*70a7ec85SAndroid Build Coastguard Worker  *
10*70a7ec85SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*70a7ec85SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*70a7ec85SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*70a7ec85SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*70a7ec85SAndroid Build Coastguard Worker  * limitations under the License.
15*70a7ec85SAndroid Build Coastguard Worker  */
16*70a7ec85SAndroid Build Coastguard Worker 
17*70a7ec85SAndroid Build Coastguard Worker #ifndef ANDROID_VINTF_MANIFEST_INSTANCE_H
18*70a7ec85SAndroid Build Coastguard Worker #define ANDROID_VINTF_MANIFEST_INSTANCE_H
19*70a7ec85SAndroid Build Coastguard Worker 
20*70a7ec85SAndroid Build Coastguard Worker #include <optional>
21*70a7ec85SAndroid Build Coastguard Worker #include <string>
22*70a7ec85SAndroid Build Coastguard Worker 
23*70a7ec85SAndroid Build Coastguard Worker #include <vintf/ExclusiveTo.h>
24*70a7ec85SAndroid Build Coastguard Worker #include <vintf/FqInstance.h>
25*70a7ec85SAndroid Build Coastguard Worker #include <vintf/HalFormat.h>
26*70a7ec85SAndroid Build Coastguard Worker #include <vintf/TransportArch.h>
27*70a7ec85SAndroid Build Coastguard Worker #include <vintf/Version.h>
28*70a7ec85SAndroid Build Coastguard Worker 
29*70a7ec85SAndroid Build Coastguard Worker namespace android {
30*70a7ec85SAndroid Build Coastguard Worker namespace vintf {
31*70a7ec85SAndroid Build Coastguard Worker 
32*70a7ec85SAndroid Build Coastguard Worker class ManifestInstance {
33*70a7ec85SAndroid Build Coastguard Worker    public:
34*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance();
35*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance(const ManifestInstance&);
36*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance(ManifestInstance&&) noexcept;
37*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance& operator=(const ManifestInstance&);
38*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance& operator=(ManifestInstance&&) noexcept;
39*70a7ec85SAndroid Build Coastguard Worker 
40*70a7ec85SAndroid Build Coastguard Worker     using VersionType = Version;
41*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance(FqInstance&& fqInstance, TransportArch&& ta, HalFormat fmt,
42*70a7ec85SAndroid Build Coastguard Worker                      std::optional<std::string>&& updatableViaApex, ExclusiveTo exclusiveTo,
43*70a7ec85SAndroid Build Coastguard Worker                      std::optional<std::string>&& accessor, bool updatableViaSystem);
44*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance(const FqInstance& fqInstance, const TransportArch& ta, HalFormat fmt,
45*70a7ec85SAndroid Build Coastguard Worker                      const std::optional<std::string>& updatableViaApex, ExclusiveTo exclusiveTo,
46*70a7ec85SAndroid Build Coastguard Worker                      const std::optional<std::string>& accessor, bool updatableViaSystem);
47*70a7ec85SAndroid Build Coastguard Worker     const std::string& package() const;
48*70a7ec85SAndroid Build Coastguard Worker     Version version() const;
49*70a7ec85SAndroid Build Coastguard Worker     std::string interface() const;
50*70a7ec85SAndroid Build Coastguard Worker     const std::string& instance() const;
51*70a7ec85SAndroid Build Coastguard Worker     Transport transport() const;
52*70a7ec85SAndroid Build Coastguard Worker     Arch arch() const;
53*70a7ec85SAndroid Build Coastguard Worker     HalFormat format() const;
54*70a7ec85SAndroid Build Coastguard Worker     ExclusiveTo exclusiveTo() const;
55*70a7ec85SAndroid Build Coastguard Worker     const std::optional<std::string>& accessor() const;
56*70a7ec85SAndroid Build Coastguard Worker     const std::optional<std::string>& updatableViaApex() const;
57*70a7ec85SAndroid Build Coastguard Worker     const std::optional<std::string> ip() const;
58*70a7ec85SAndroid Build Coastguard Worker     const std::optional<uint64_t> port() const;
59*70a7ec85SAndroid Build Coastguard Worker     bool updatableViaSystem() const;
60*70a7ec85SAndroid Build Coastguard Worker 
61*70a7ec85SAndroid Build Coastguard Worker     bool operator==(const ManifestInstance& other) const;
62*70a7ec85SAndroid Build Coastguard Worker     bool operator<(const ManifestInstance& other) const;
63*70a7ec85SAndroid Build Coastguard Worker 
64*70a7ec85SAndroid Build Coastguard Worker     // Convenience methods.
65*70a7ec85SAndroid Build Coastguard Worker     // return package@version::interface/instance
66*70a7ec85SAndroid Build Coastguard Worker     const FqInstance& getFqInstance() const;
67*70a7ec85SAndroid Build Coastguard Worker 
68*70a7ec85SAndroid Build Coastguard Worker     // This is for writing the XML <fqname> tag.
69*70a7ec85SAndroid Build Coastguard Worker     // For AIDL, return "interface/instance".
70*70a7ec85SAndroid Build Coastguard Worker     // For others, return "@version::interface/instance".
71*70a7ec85SAndroid Build Coastguard Worker     std::string getSimpleFqInstance() const;
72*70a7ec85SAndroid Build Coastguard Worker 
73*70a7ec85SAndroid Build Coastguard Worker     // For AIDL, return "package.interface/instance (@version)".
74*70a7ec85SAndroid Build Coastguard Worker     // For others, return "package@version::interface/instance".
75*70a7ec85SAndroid Build Coastguard Worker     std::string description() const;
76*70a7ec85SAndroid Build Coastguard Worker 
77*70a7ec85SAndroid Build Coastguard Worker     // Similar to description() but without package name.
78*70a7ec85SAndroid Build Coastguard Worker     // For AIDL, return "interface/instance (@version)".
79*70a7ec85SAndroid Build Coastguard Worker     // For others, return "@version::interface/instance".
80*70a7ec85SAndroid Build Coastguard Worker     std::string descriptionWithoutPackage() const;
81*70a7ec85SAndroid Build Coastguard Worker 
82*70a7ec85SAndroid Build Coastguard Worker     // Returns name with version. e.g. "android.hardware.camera.device@1"
83*70a7ec85SAndroid Build Coastguard Worker     std::string nameWithVersion() const;
84*70a7ec85SAndroid Build Coastguard Worker 
85*70a7ec85SAndroid Build Coastguard Worker     // Return a new ManifestInstance that's the same as this, but with the given version.
86*70a7ec85SAndroid Build Coastguard Worker     ManifestInstance withVersion(const Version& v) const;
87*70a7ec85SAndroid Build Coastguard Worker 
88*70a7ec85SAndroid Build Coastguard Worker    private:
89*70a7ec85SAndroid Build Coastguard Worker     FqInstance mFqInstance;
90*70a7ec85SAndroid Build Coastguard Worker     TransportArch mTransportArch;
91*70a7ec85SAndroid Build Coastguard Worker     HalFormat mHalFormat;
92*70a7ec85SAndroid Build Coastguard Worker     std::optional<std::string> mUpdatableViaApex;
93*70a7ec85SAndroid Build Coastguard Worker     ExclusiveTo mExclusiveTo;
94*70a7ec85SAndroid Build Coastguard Worker     std::optional<std::string> mAccessor;
95*70a7ec85SAndroid Build Coastguard Worker     bool mUpdatableViaSystem;
96*70a7ec85SAndroid Build Coastguard Worker };
97*70a7ec85SAndroid Build Coastguard Worker 
98*70a7ec85SAndroid Build Coastguard Worker }  // namespace vintf
99*70a7ec85SAndroid Build Coastguard Worker }  // namespace android
100*70a7ec85SAndroid Build Coastguard Worker 
101*70a7ec85SAndroid Build Coastguard Worker #endif  // ANDROID_VINTF_MANIFEST_INSTANCE_H
102