আপনি HAL ইন্টারফেস থেকে গতিশীলভাবে মানগুলি পড়ার জন্য শর্তসাপেক্ষে সংকলিত কোড রিফ্যাক্টর করতে পারেন। যেমন:
#ifdef TARGET_FORCE_HWC_FOR_VIRTUAL_DISPLAYS // some code fragment #endif
ফ্রেমওয়ার্ক কোড তার প্রকারের উপর নির্ভর করে <configstore/Utils.h>
-এ সংজ্ঞায়িত একটি উপযুক্ত ইউটিলিটি ফাংশন কল করতে পারে।
ConfigStore উদাহরণ
এই উদাহরণটি TARGET_FORCE_HWC_FOR_VIRTUAL_DISPLAYS
পড়া দেখায়, ConfigStore HAL-এ forceHwcForVirtualDisplays()
হিসাবে রিটার্ন টাইপ OptionalBool
সহ সংজ্ঞায়িত করা হয়েছে:
#include <configstore/Utils.h> using namespace android::hardware::configstore; using namespace android::hardware::configstore::V1_0; static bool vsyncPhaseOffsetNs = getBool<ISurfaceFlingerConfigs, ISurfaceFlingerConfigs::forceHwcForVirtualDisplays>(false);
ইউটিলিটি ফাংশন (উপরের উদাহরণে getBool
) ইন্টারফেস ফাংশনের প্রক্সির জন্য হ্যান্ডেল পেতে configstore
পরিষেবার সাথে যোগাযোগ করে, তারপর HIDL/hwbinder এর মাধ্যমে হ্যান্ডেলটি চালু করে মানটি পুনরুদ্ধার করে।
ইউটিলিটি ফাংশন
<configstore/Utils.h>
( configstore/1.0/include/configstore/Utils.h
) প্রতিটি আদিম রিটার্ন টাইপের জন্য ইউটিলিটি ফাংশন প্রদান করে, যার মধ্যে Optional[Bool|String|Int32|UInt32|Int64|UInt64]
সহ, নীচে তালিকাভুক্ত:
টাইপ | ফাংশন (টেমপ্লেট প্যারামিটার বাদ দেওয়া হয়েছে) |
---|---|
OptionalBool | bool getBool(const bool defValue) |
OptionalInt32 | int32_t getInt32(const int32_t defValue) |
OptionalUInt32 | uint32_t getUInt32(const uint32_t defValue) |
OptionalInt64 | int64_t getInt64(const int64_t defValue) |
OptionalUInt64 | uint64_t getUInt64(const uint64_t defValue) |
OptionalString | std::string getString(const std::string &defValue) |
defValue
হল একটি ডিফল্ট মান যখন HAL বাস্তবায়ন কনফিগারেশন আইটেমের জন্য একটি মান নির্দিষ্ট করে না। প্রতিটি ফাংশন দুটি টেমপ্লেট পরামিতি নেয়:
-
I
ইন্টারফেস ক্লাস নাম. -
Func
হল কনফিগারেশন আইটেম পাওয়ার জন্য সদস্য ফাংশন পয়েন্টার।
যেহেতু কনফিগারেশন মান শুধুমাত্র পঠনযোগ্য এবং পরিবর্তন হয় না, ইউটিলিটি ফাংশন অভ্যন্তরীণভাবে কনফিগারেশন মান ক্যাশে করে। পরবর্তী কলগুলি একই লিঙ্কিং ইউনিটে ক্যাশে করা মান ব্যবহার করে আরও দক্ষতার সাথে পরিষেবা দেওয়া হয়।
configstore-utils ব্যবহার করুন
ConfigStore HAL ছোট সংস্করণ আপগ্রেডের জন্য ফরওয়ার্ড সামঞ্জস্যপূর্ণ করার জন্য ডিজাইন করা হয়েছে, যার অর্থ হল যখন HAL সংশোধন করা হয় এবং কিছু ফ্রেমওয়ার্ক কোড নতুন প্রবর্তিত আইটেম ব্যবহার করে, তখনও /vendor
-এ একটি পুরানো ছোট সংস্করণ সহ ConfigStore পরিষেবা ব্যবহার করা যেতে পারে।
ফরওয়ার্ড সামঞ্জস্যের জন্য, নিশ্চিত করুন যে আপনার বাস্তবায়ন নিম্নলিখিত নির্দেশিকা মেনে চলে:
- নতুন আইটেমগুলি ডিফল্ট মান ব্যবহার করে যখন শুধুমাত্র পুরানো সংস্করণের পরিষেবা উপলব্ধ থাকে৷ উদাহরণ:
service = V1_1::IConfig::getService(); // null if V1_0 is installed value = DEFAULT_VALUE; if(service) { value = service->v1_1API(DEFAULT_VALUE); }
- ক্লায়েন্ট প্রথম ইন্টারফেস ব্যবহার করে যা ConfigStore আইটেম অন্তর্ভুক্ত করে। উদাহরণ:
V1_1::IConfig::getService()->v1_0API(); // NOT ALLOWED V1_0::IConfig::getService()->v1_0API(); // OK
- নতুন সংস্করণের পরিষেবাটি পুরানো সংস্করণের ইন্টারফেসের জন্য পুনরুদ্ধার করা যেতে পারে। নিম্নলিখিত উদাহরণে, ইনস্টল করা সংস্করণটি v1_1 হলে,
getService()
এর জন্য v1_1 পরিষেবাটি ফেরত দিতে হবে :V1_0::IConfig::getService()->v1_0API();
যখন কনফিগারস্টোর আইটেম অ্যাক্সেস করার জন্য configstore-utils
লাইব্রেরিতে অ্যাক্সেস ফাংশন ব্যবহার করা হয়, #1 বাস্তবায়ন দ্বারা নিশ্চিত করা হয় এবং #2 কম্পাইলার ত্রুটি দ্বারা নিশ্চিত করা হয়। এই কারণগুলির জন্য, আমরা দৃঢ়ভাবে configstore-utils
যেখানেই সম্ভব ব্যবহার করার পরামর্শ দিই।