আপনি যদি CMake বা ndk-build ব্যবহার না করেন তবে Android Gradle প্লাগইন (AGP) C/C++ বিল্ড এবং অ্যান্ড্রয়েড স্টুডিওর সম্পূর্ণ ইন্টিগ্রেশন চান, তাহলে আপনি একটি শেল স্ক্রিপ্ট তৈরি করে একটি কাস্টম C/C++ বিল্ড সিস্টেম তৈরি করতে পারেন যা বিল্ড তথ্য লিখতে পারে নিনজা বিল্ড ফাইল ফরম্যাট।
অ্যান্ড্রয়েড স্টুডিও এবং এজিপি-তে কাস্টম C/C++ বিল্ড সিস্টেমের জন্য পরীক্ষামূলক সমর্থন যোগ করা হয়েছে। এই বৈশিষ্ট্যটি অ্যান্ড্রয়েড স্টুডিও ডলফিন থেকে শুরু করে উপলব্ধ 2021.3.1 ক্যানারি 4.
ওভারভিউ
C/C++ প্রকল্পগুলির জন্য একটি সাধারণ প্যাটার্ন, বিশেষ করে যেগুলি একাধিক প্ল্যাটফর্মকে লক্ষ্য করে, সেই সমস্ত প্ল্যাটফর্মগুলির জন্য কিছু অন্তর্নিহিত উপস্থাপনা থেকে প্রকল্প তৈরি করা। এই প্যাটার্নের একটি বিশিষ্ট উদাহরণ হল CMake । CMake একটি একক অন্তর্নিহিত উপস্থাপনা থেকে Android, iOS এবং অন্যান্য প্ল্যাটফর্মের জন্য প্রকল্প তৈরি করতে পারে, CMakeLists.txt
ফাইলে সংরক্ষিত।
যদিও CMake সরাসরি AGP দ্বারা সমর্থিত, সেখানে অন্যান্য প্রজেক্ট জেনারেটর উপলব্ধ রয়েছে যা সরাসরি সমর্থিত নয়:
এই ধরনের প্রজেক্ট জেনারেটরগুলি হয় নিনজাকে C/C++ বিল্ডের ব্যাকএন্ড উপস্থাপনা হিসাবে সমর্থন করে বা ব্যাকএন্ড উপস্থাপনা হিসাবে নিনজা তৈরি করতে অভিযোজিত হতে পারে।
সঠিকভাবে কনফিগার করা হলে, একটি সমন্বিত C/C++ প্রজেক্ট সিস্টেম জেনারেটর সহ একটি AGP প্রকল্প ব্যবহারকারীদের সক্ষম করে:
কমান্ড-লাইন এবং অ্যান্ড্রয়েড স্টুডিও থেকে তৈরি করুন।
অ্যান্ড্রয়েড স্টুডিওতে সম্পূর্ণ ভাষা পরিষেবা সমর্থন সহ উত্সগুলি সম্পাদনা করুন (উদাহরণস্বরূপ, সংজ্ঞায় যান)।
নেটিভ এবং মিশ্র প্রসেস ডিবাগ করতে অ্যান্ড্রয়েড স্টুডিও ডিবাগার ব্যবহার করুন।
একটি কাস্টম C/C++ বিল্ড কনফিগারেশন স্ক্রিপ্ট ব্যবহার করতে কীভাবে আপনার বিল্ড পরিবর্তন করবেন
এই বিভাগটি এজিপি থেকে একটি কাস্টম C/C++ বিল্ড কনফিগারেশন স্ক্রিপ্ট ব্যবহার করার ধাপগুলি দিয়ে চলে।
ধাপ 1: একটি কনফিগারেশন স্ক্রিপ্ট উল্লেখ করতে মডিউল-স্তরের build.gradle
ফাইলটি পরিবর্তন করুন
AGP-তে নিনজা সমর্থন সক্ষম করতে, মডিউল-স্তরের build.gradle
ফাইলে experimentalProperties
কনফিগার করুন:
android {
defaultConfig {
externalNativeBuild {
experimentalProperties["ninja.abiFilters"] = [ "x86", "arm64-v8a" ]
experimentalProperties["ninja.path"] = "source-file-list.txt"
experimentalProperties["ninja.configure"] = "configure-ninja"
experimentalProperties["ninja.arguments"] = [
"\${ndk.moduleMakeFile}",
"--variant=\${ndk.variantName}",
"--abi=Android-\${ndk.abi}",
"--configuration-dir=\${ndk.configurationDir}",
"--ndk-version=\${ndk.moduleNdkVersion}",
"--min-sdk-version=\${ndk.minSdkVersion}"
]
}
}
বৈশিষ্ট্যগুলি এজিপি দ্বারা নিম্নরূপ ব্যাখ্যা করা হয়:
ninja.abiFilters
হল ABI-এর একটি তালিকা যা তৈরি করতে হবে। বৈধ মানগুলি হল:x86
,x86-64
,armeabi-v7a
, এবংarm64-v8a
।ninja.path
হল একটি C/C++ প্রজেক্ট ফাইলের পাথ। এই ফাইলের বিন্যাস আপনি চান কিছু হতে পারে. এই ফাইলের পরিবর্তনগুলি অ্যান্ড্রয়েড স্টুডিওতে গ্রেডল সিঙ্কের জন্য একটি প্রম্পট ট্রিগার করবে।ninja.configure
হল একটি স্ক্রিপ্ট ফাইলের পাথ যা C/C++ প্রজেক্ট কনফিগার করার প্রয়োজন হলে Gradle দ্বারা নির্বাহ করা হবে। অ্যান্ড্রয়েড স্টুডিওতে গ্র্যাডল সিঙ্কের সময় বা কনফিগার স্ক্রিপ্ট ইনপুটগুলির মধ্যে একটি পরিবর্তন হলে একটি প্রকল্প প্রথম বিল্ডে কনফিগার করা হয়।ninja.arguments
হল আর্গুমেন্টের একটি তালিকা যা ninja.configure দ্বারা সংজ্ঞায়িত স্ক্রিপ্টে পাঠানো হবে। এই তালিকার উপাদানগুলি ম্যাক্রোগুলির একটি সেট উল্লেখ করতে পারে যার মানগুলি AGP-এর বর্তমান কনফিগারেশন প্রসঙ্গে নির্ভর করে:${ndk.moduleMakeFile}
হলninja.configure
ফাইলের সম্পূর্ণ পথ। সুতরাং উদাহরণে, এটি হবেC:\path\to\configure-ninja.bat
।${ndk.variantName}
হল বর্তমান AGP ভেরিয়েন্টের নাম যা তৈরি করা হচ্ছে। উদাহরণস্বরূপ, ডিবাগ বা মুক্তি।${ndk.abi}
হল বর্তমান AGP ABI এর নাম যা নির্মিত হচ্ছে। উদাহরণস্বরূপ,x86
বাarm64-v8a
।
${ndk.buildRoot}
হল একটি ফোল্ডারের নাম, AGP দ্বারা উত্পন্ন, যেখানে স্ক্রিপ্ট তার আউটপুট লেখে। এর বিশদ বিবরণ ধাপ 2 এ ব্যাখ্যা করা হবে: কনফিগার স্ক্রিপ্ট তৈরি করুন ।${ndk.ndkVersion}
হল NDK-এর যে সংস্করণ ব্যবহার করা হবে। এটি সাধারণতbuild.gradle
ফাইলে android.ndkVersion-এ পাস করা মান অথবা কোনোটি উপস্থিত না থাকলে একটি ডিফল্ট মান।${ndk.minPlatform}
হল ন্যূনতম টার্গেট Android প্ল্যাটফর্ম যা AGP দ্বারা অনুরোধ করা হয়েছে৷
ninja.targets
হল নির্দিষ্ট নিনজা লক্ষ্যগুলির একটি তালিকা যা তৈরি করা উচিত।
ধাপ 2: কনফিগার স্ক্রিপ্ট তৈরি করুন
কনফিগার স্ক্রিপ্টের ন্যূনতম দায়িত্ব (আগের উদাহরণে configure-ninja.bat
) হল একটি build.ninja
ফাইল তৈরি করা যা, Ninja দিয়ে তৈরি করা হলে, প্রকল্পের সমস্ত নেটিভ আউটপুট কম্পাইল এবং লিঙ্ক করবে। সাধারণত এগুলি হল .o
(অবজেক্ট), .a
(আর্কাইভ), এবং .so
(শেয়ারড অবজেক্ট) ফাইল।
কনফিগার স্ক্রিপ্ট আপনার প্রয়োজনের উপর নির্ভর করে build.ninja
ফাইলটিকে দুটি ভিন্ন জায়গায় লিখতে পারে।
যদি AGP-এর জন্য একটি অবস্থান বেছে নেওয়া ঠিক হয়, তাহলে কনফিগার স্ক্রিপ্ট
${ndk.buildRoot}
ম্যাক্রোতে সেট করা অবস্থানেbuild.ninja
লিখে।যদি কনফিগার স্ক্রিপ্টটিকে
build.ninja
ফাইলের অবস্থান নির্বাচন করতে হয় তবে এটি${ndk.buildRoot}
ম্যাক্রোতে সেট করা অবস্থানেbuild.ninja.txt
নামে একটি ফাইলও লিখে। এই ফাইলটিতেbuild.ninja
ফাইলের সম্পূর্ণ পাথ রয়েছে যা কনফিগার স্ক্রিপ্ট লিখেছে।
build.ninja
ফাইলের স্ট্রাকচার
সাধারণত, বেশিরভাগ কাঠামো যা সঠিকভাবে একটি Android C/C++ বিল্ডকে উপস্থাপন করে তা কাজ করবে। এজিপি এবং অ্যান্ড্রয়েড স্টুডিওর জন্য প্রয়োজনীয় মূল উপাদানগুলি হল:
C/C++ সোর্স ফাইলের তালিকা এবং ফ্ল্যাগগুলিকে কম্পাইল করার জন্য ক্ল্যাং-এর প্রয়োজন।
আউটপুট লাইব্রেরির তালিকা। এগুলি সাধারণত
.so
(শেয়ারড অবজেক্ট) ফাইল তবে.a
(আর্কাইভ) বা এক্সিকিউটেবল (কোন এক্সটেনশন) হতে পারে।
আপনার যদি একটি build.ninja
ফাইল তৈরি করার উদাহরণের প্রয়োজন হয়, আপনি যখন build.ninja
জেনারেটর ব্যবহার করা হয় তখন আপনি CMake এর আউটপুট দেখতে পারেন।
এখানে একটি ন্যূনতম build.ninja
টেমপ্লেটের উদাহরণ।
rule COMPILE
command = /path/to/ndk/clang -c $in -o $out {other flags}
rule LINK
command = /path/to/ndk/clang $in -o $out {other flags}
build source.o : COMPILE source.cpp
build lib.so : LINK source.o
সর্বোত্তম অনুশীলন
প্রয়োজনীয়তাগুলি ছাড়াও (উৎস ফাইল এবং আউটপুট লাইব্রেরির তালিকা), এখানে কিছু প্রস্তাবিত সেরা অনুশীলন রয়েছে।
phony
নিয়ম সহ নামযুক্ত আউটপুট ঘোষণা করুন
সম্ভব হলে, বিল্ড আউটপুটকে মানব-পাঠযোগ্য নাম দেওয়ার জন্য build.ninja
কাঠামোটি phony
নিয়ম ব্যবহার করার পরামর্শ দেওয়া হয়। সুতরাং উদাহরণস্বরূপ, আপনার যদি c:/path/to/lib.so
নামে একটি আউটপুট থাকে তবে আপনি এটিকে নিম্নরূপ একটি মানব-পাঠযোগ্য নাম দিতে পারেন।
build curl: phony /path/to/lib.so
এটি করার সুবিধা হল যে আপনি তারপর build.gradle
ফাইলে একটি বিল্ড টার্গেট হিসাবে এই নামটি নির্দিষ্ট করতে পারেন। যেমন,
android {
defaultConfig {
externalNativeBuild {
...
experimentalProperties["ninja.targets"] = [ "curl" ]
একটি 'সমস্ত' লক্ষ্য নির্দিষ্ট করুন
আপনি যখন একটি all
লক্ষ্য নির্দিষ্ট করেন তখন এটি হবে AGP দ্বারা নির্মিত লাইব্রেরির ডিফল্ট সেট যখন build.gradle
ফাইলে কোনো লক্ষ্য স্পষ্টভাবে উল্লেখ করা হয় না।
rule COMPILE
command = /path/to/ndk/clang $in -o $out {other flags}
rule LINK
command = /path/to/ndk/clang $in -o $out {other flags}
build foo.o : COMPILE foo.cpp
build bar.o : COMPILE bar.cpp
build libfoo.so : LINK foo.o
build libbar.so : LINK bar.o
build all: phony libfoo.so libbar.so
একটি বিকল্প নির্মাণ পদ্ধতি নির্দিষ্ট করুন (ঐচ্ছিক)
একটি আরও উন্নত ব্যবহারের ক্ষেত্রে একটি বিদ্যমান বিল্ড সিস্টেম মোড়ানো যা নিনজা ভিত্তিক নয়। এই ক্ষেত্রে, আপনাকে এখনও আউটপুট লাইব্রেরির সাথে তাদের পতাকা সহ সমস্ত উত্সগুলিকে উপস্থাপন করতে হবে যাতে Android স্টুডিও স্বয়ংসম্পূর্ণ এবং গো-টু সংজ্ঞার মতো সঠিক ভাষা পরিষেবা বৈশিষ্ট্যগুলি উপস্থাপন করতে পারে। যাইহোক, আপনি এজিপি প্রকৃত নির্মাণের সময় অন্তর্নিহিত বিল্ড সিস্টেমে পিছিয়ে দিতে চান।
এটি সম্পন্ন করার জন্য, আপনি একটি নির্দিষ্ট এক্সটেনশন .passthrough
সহ একটি নিনজা বিল্ড আউটপুট ব্যবহার করতে পারেন।
একটি আরও সুনির্দিষ্ট উদাহরণ হিসাবে, ধরা যাক আপনি একটি MSBuild মোড়ানো করতে চান। আপনার কনফিগার স্ক্রিপ্ট স্বাভাবিক হিসাবে build.ninja
তৈরি করবে, কিন্তু এটি একটি পাসথ্রু লক্ষ্যও যোগ করবে যা নির্ধারণ করে যে AGP কীভাবে MSBuild চালু করবে।
rule COMPILE
command = /path/to/ndk/clang $in -o $out {other flags}
rule LINK
command = /path/to/ndk/clang $in -o $out {other flags}
rule MBSUILD_CURL
command = /path/to/msbuild {flags to build curl with MSBuild}
build source.o : COMPILE source.cpp
build lib.so : LINK source.o
build curl : phony lib.so
build curl.passthrough : MBSUILD_CURL
মতামত দিন
এই বৈশিষ্ট্যটি পরীক্ষামূলক, তাই প্রতিক্রিয়া ব্যাপকভাবে প্রশংসা করা হয়। আপনি নিম্নলিখিত চ্যানেলগুলির মাধ্যমে প্রতিক্রিয়া জানাতে পারেন:
সাধারণ প্রতিক্রিয়ার জন্য, এই বাগটিতে একটি মন্তব্য যোগ করুন।
একটি বাগ রিপোর্ট করতে, অ্যান্ড্রয়েড স্টুডিও খুলুন এবং সহায়তা > প্রতিক্রিয়া জমা দিন ক্লিক করুন। বাগ নির্দেশ করতে সাহায্য করার জন্য "কাস্টম C/C++ বিল্ড সিস্টেম" উল্লেখ করতে ভুলবেন না।
আপনার Android স্টুডিও ইনস্টল না থাকলে একটি বাগ রিপোর্ট করতে, এই টেমপ্লেটটি ব্যবহার করে একটি বাগ ফাইল করুন৷