লেবেল

সমস্ত লক্ষ্য ঠিক একটি প্যাকেজের অন্তর্গত। একটি লক্ষ্যের নাম তার লেবেল বলা হয়। প্রতিটি লেবেল অনন্যভাবে একটি লক্ষ্য চিহ্নিত করে। ক্যানোনিকাল আকারে একটি সাধারণ লেবেল এর মতো দেখায়:

@myrepo//my/app/main:app_binary

লেবেলের প্রথম অংশটি হল সংগ্রহস্থলের নাম, @myrepo// । সাধারণ ক্ষেত্রে যে একটি লেবেল একই সংগ্রহস্থলকে বোঝায় যেখান থেকে এটি ব্যবহার করা হয়, সংগ্রহস্থল শনাক্তকারীকে সংক্ষেপে // হিসাবে বলা যেতে পারে। সুতরাং, @myrepo এর ভিতরে এই লেবেলটি সাধারণত লেখা হয়

//my/app/main:app_binary

লেবেলের দ্বিতীয় অংশটি হল অ-যোগ্য প্যাকেজের নাম my/app/main , রিপোজিটরি রুটের সাথে সম্পর্কিত প্যাকেজের পথ। একত্রে, সংগ্রহস্থলের নাম এবং অ-যোগ্য প্যাকেজ নামটি সম্পূর্ণরূপে-যোগ্য প্যাকেজ নাম গঠন করে @myrepo//my/app/main । যখন লেবেলটি একই প্যাকেজকে বোঝায় যেখানে এটি ব্যবহৃত হয়, প্যাকেজের নাম (এবং ঐচ্ছিকভাবে, কোলন) বাদ দেওয়া হতে পারে। সুতরাং, @myrepo//my/app/main ভিতরে, এই লেবেলটি নিম্নলিখিত যে কোনও উপায়ে লেখা হতে পারে:

app_binary
:app_binary

এটি একটি প্রচলিত বিষয় যে কোলন ফাইলের জন্য বাদ দেওয়া হয়, তবে নিয়মের জন্য ধরে রাখা হয়, তবে এটি অন্যথায় তাৎপর্যপূর্ণ নয়।

কোলনের পরে লেবেলের অংশ, app_binary হল অ-যোগ্য লক্ষ্যের নাম। যখন এটি প্যাকেজ পথের শেষ উপাদানের সাথে মেলে, তখন এটি এবং কোলন বাদ দেওয়া যেতে পারে। সুতরাং, এই দুটি লেবেল সমতুল্য:

//my/app/lib
//my/app/lib:lib

প্যাকেজের একটি সাবডিরেক্টরিতে একটি ফাইল টার্গেটের নাম হল প্যাকেজ রুটের সাথে সম্পর্কিত ফাইলের পাথ ( BUILD ফাইল ধারণকারী ডিরেক্টরি)। সুতরাং, এই ফাইলটি সংগ্রহস্থলের my/app/main/testdata সাবডিরেক্টরিতে রয়েছে:

//my/app/main:testdata/input.txt

//my/app এবং @some_repo//my/app app এর মতো স্ট্রিংগুলির দুটি অর্থ রয়েছে যে প্রেক্ষাপটে সেগুলি ব্যবহার করা হয় তার উপর নির্ভর করে: যখন Bazel একটি লেবেল আশা করে, তখন তাদের অর্থ //my/app:app এবং @some_repo//my/app:app , যথাক্রমে। কিন্তু, যখন Bazel একটি প্যাকেজ আশা করে (যেমন package_group স্পেসিফিকেশনে), তারা সেই প্যাকেজটিকে উল্লেখ করে যেটিতে সেই লেবেল রয়েছে।

BUILD ফাইলে একটি সাধারণ ভুল হল //my/app ব্যবহার করা একটি প্যাকেজ উল্লেখ করতে, অথবা একটি প্যাকেজের সমস্ত লক্ষ্য-এটি করে না। মনে রাখবেন, এটি //my/app:app এর সমতুল্য, তাই এটি বর্তমান সংগ্রহস্থলের my/app প্যাকেজে app টার্গেটের নাম দেয়।

যাইহোক, প্যাকেজ উল্লেখ করার জন্য //my/app ব্যবহারকে .bzl package_group উৎসাহিত করা হয়, কারণ এটি স্পষ্টভাবে যোগাযোগ করে যে প্যাকেজের নামটি পরম এবং ওয়ার্কস্পেসের শীর্ষ-স্তরের ডিরেক্টরিতে রুট রয়েছে। .

আপেক্ষিক লেবেল অন্যান্য প্যাকেজের লক্ষ্য উল্লেখ করতে ব্যবহার করা যাবে না; এই ক্ষেত্রে সংগ্রহস্থল শনাক্তকারী এবং প্যাকেজের নাম সর্বদা নির্দিষ্ট করা আবশ্যক। উদাহরণস্বরূপ, যদি সোর্স ট্রিতে প্যাকেজ my/app এবং প্যাকেজ my/app/testdata থাকে (এই দুটি ডিরেক্টরির প্রত্যেকটির নিজস্ব BUILD ফাইল রয়েছে), পরবর্তী প্যাকেজে testdepot.zip নামে একটি ফাইল রয়েছে। এই ফাইলটি //my/app:BUILD মধ্যে উল্লেখ করার জন্য এখানে দুটি উপায় (একটি ভুল, একটি সঠিক) রয়েছে:

ভুলtestdata একটি ভিন্ন প্যাকেজ, তাই আপনি একটি আপেক্ষিক পথ ব্যবহার করতে পারবেন না

testdata/testdepot.zip

সঠিক — এর সম্পূর্ণ পাথ সহ testdata পড়ুন

//my/app/testdata:testdepot.zip

@// দিয়ে শুরু হওয়া লেবেলগুলি হল মূল সংগ্রহস্থলের রেফারেন্স, যা এখনও বহিরাগত সংগ্রহস্থল থেকেও কাজ করবে। তাই @//a/b/c একটি বহিরাগত সংগ্রহস্থল থেকে উল্লেখ করার সময় //a/b/c থেকে আলাদা। পূর্ববর্তীটি মূল সংগ্রহস্থলে ফিরে উল্লেখ করে, যখন পরবর্তীটি বাহ্যিক সংগ্রহস্থলেই //a/b/c সন্ধান করে। এটি বিশেষভাবে প্রাসঙ্গিক যখন প্রধান সংগ্রহস্থলে নিয়মগুলি লেখার সময় যা মূল সংগ্রহস্থলের লক্ষ্যগুলি উল্লেখ করে এবং বহিরাগত সংগ্রহস্থল থেকে ব্যবহার করা হবে।

আপনি লক্ষ্যগুলি উল্লেখ করতে পারেন বিভিন্ন উপায় সম্পর্কে তথ্যের জন্য, লক্ষ্য নিদর্শন দেখুন।

একটি লেবেলের আভিধানিক স্পেসিফিকেশন

লেবেল সিনট্যাক্স মেটাক্যারেক্টারের ব্যবহারকে নিরুৎসাহিত করে যেগুলির শেলের বিশেষ অর্থ রয়েছে। এটি অসাবধানতাবশত উদ্ধৃতি সমস্যা এড়াতে সাহায্য করে এবং ব্যাজেল কোয়েরি ল্যাঙ্গুয়েজের মতো লেবেলগুলিকে ম্যানিপুলেট করে এমন সরঞ্জাম এবং স্ক্রিপ্টগুলি তৈরি করা সহজ করে তোলে।

অনুমোদিত টার্গেট নামের সুনির্দিষ্ট বিশদ নীচে রয়েছে।

টার্গেট নাম — package-name :target-name

target-name হল প্যাকেজের মধ্যে লক্ষ্যের নাম। একটি নিয়মের নাম হল একটি BUILD ফাইলে নিয়মের ঘোষণায় name বৈশিষ্ট্যের মান; একটি ফাইলের নাম হল BUILD ফাইল ধারণকারী ডিরেক্টরির সাথে সম্পর্কিত এর পাথনাম।

টার্গেটের নামগুলি অবশ্যই az , AZ , 09 , এবং যতিচিহ্নের চিহ্নগুলি থেকে আঁকা অক্ষরগুলির সম্পূর্ণরূপে গঠিত হতে হবে !%-@^_"#$&'()*-+,;<=>?[]{|}~/.

ফাইলের নামগুলি অবশ্যই স্বাভাবিক আকারে আপেক্ষিক পাথনাম হতে হবে, যার মানে সেগুলি অবশ্যই স্ল্যাশ দিয়ে শুরু বা শেষ হবে না (উদাহরণস্বরূপ, /foo এবং foo/ নিষিদ্ধ) বা পাথ বিভাজক হিসাবে একাধিক ক্রমাগত স্ল্যাশ ধারণ করতে হবে না (উদাহরণস্বরূপ, foo//bar )। একইভাবে, আপ-লেভেল রেফারেন্স ( .. ) এবং বর্তমান-ডিরেক্টরি রেফারেন্স ( ./ ) নিষিদ্ধ।

ভুল — অন্য প্যাকেজে ফাইল উল্লেখ করতে `..` ব্যবহার করবেন না

সঠিক — `// package-name : filename নাম` ব্যবহার করুন

একটি ফাইল টার্গেটের নামে / ব্যবহার করা সাধারণ হলেও নিয়মের নামে / ব্যবহার এড়িয়ে চলুন। বিশেষ করে যখন একটি লেবেলের শর্টহ্যান্ড ফর্ম ব্যবহার করা হয়, তখন এটি পাঠককে বিভ্রান্ত করতে পারে। //foo/bar/wiz লেবেলটি সর্বদা //foo/bar/wiz:wiz এর জন্য একটি সংক্ষিপ্ত বিবরণ, এমনকি যদি এমন কোনো প্যাকেজ foo/bar/wiz না থাকে; এটি কখনই //foo:bar/wiz কে বোঝায় না, এমনকি যদি সেই লক্ষ্যটি বিদ্যমান থাকে।

যাইহোক, এমন কিছু পরিস্থিতিতে আছে যেখানে একটি স্ল্যাশ ব্যবহার সুবিধাজনক, বা কখনও কখনও এমনকি প্রয়োজনীয়। উদাহরণস্বরূপ, নির্দিষ্ট নিয়মের নাম অবশ্যই তাদের প্রধান উৎস ফাইলের সাথে মিলতে হবে, যা প্যাকেজের একটি সাবডিরেক্টরিতে থাকতে পারে।

প্যাকেজের নাম — //package-name: target-name

একটি প্যাকেজের নাম হল তার BUILD ফাইল ধারণকারী ডিরেক্টরির নাম, যা ধারণকারী সংগ্রহস্থলের শীর্ষ-স্তরের ডিরেক্টরির সাথে সম্পর্কিত। যেমন: my/app .

প্যাকেজের নামগুলি সম্পূর্ণরূপে A - Z , az , 09 , ' / ', ' - ', ' সেট থেকে আঁকা অক্ষরগুলির সমন্বয়ে তৈরি হতে হবে . ', ' @ ', এবং ' _ ', এবং একটি স্ল্যাশ দিয়ে শুরু করা যাবে না।

একটি ডিরেক্টরি কাঠামো সহ একটি ভাষার জন্য যা এর মডিউল সিস্টেমের জন্য তাৎপর্যপূর্ণ (উদাহরণস্বরূপ, জাভা), ভাষাতে বৈধ শনাক্তকারী ডিরেক্টরির নামগুলি বেছে নেওয়া গুরুত্বপূর্ণ।

যদিও Bazel ওয়ার্কস্পেসের রুট প্যাকেজে লক্ষ্যগুলিকে সমর্থন করে (উদাহরণস্বরূপ, //:foo ), সেই প্যাকেজটি খালি রাখাই উত্তম যাতে সমস্ত অর্থপূর্ণ প্যাকেজের বর্ণনামূলক নাম থাকে।

প্যাকেজের নামগুলিতে সাবস্ট্রিং নাও থাকতে পারে // , অথবা স্ল্যাশ দিয়ে শেষ নাও হতে পারে৷

নিয়ম

একটি নিয়ম ইনপুট এবং আউটপুটগুলির মধ্যে সম্পর্ক এবং আউটপুটগুলি তৈরি করার পদক্ষেপগুলি নির্দিষ্ট করে। নিয়মগুলি বিভিন্ন ধরণের হতে পারে (কখনও কখনও রুল ক্লাস বলা হয়), যা বিল্ড এনসাইক্লোপিডিয়াতে বর্ণিত হিসাবে সংকলিত এক্সিকিউটেবল এবং লাইব্রেরি, টেস্ট এক্সিকিউটেবল এবং অন্যান্য সমর্থিত আউটপুট তৈরি করে।

BUILD ফাইলগুলি নিয়ম চালু করে লক্ষ্য ঘোষণা করে।

নীচের উদাহরণে, আমরা cc_binary নিয়ম ব্যবহার করে লক্ষ্য my_app এর ঘোষণা দেখতে পাচ্ছি।

cc_binary(
    name = "my_app",
    srcs = ["my_app.cc"],
    deps = [
        "//absl/base",
        "//absl/strings",
    ],
)

প্রতিটি নিয়মের আমন্ত্রণের একটি name বৈশিষ্ট্য রয়েছে (যা অবশ্যই একটি বৈধ টার্গেট নাম হতে হবে), যা BUILD ফাইলের প্যাকেজের মধ্যে একটি লক্ষ্য ঘোষণা করে।

প্রতিটি নিয়মের বৈশিষ্ট্যের একটি সেট আছে; একটি প্রদত্ত নিয়মের জন্য প্রযোজ্য বৈশিষ্ট্য, এবং প্রতিটি বৈশিষ্ট্যের তাৎপর্য এবং শব্দার্থবিদ্যা হল নিয়মের ধরনের একটি ফাংশন; নিয়মের তালিকা এবং তাদের সংশ্লিষ্ট বৈশিষ্ট্যের জন্য বিল্ড এনসাইক্লোপিডিয়া দেখুন। প্রতিটি বৈশিষ্ট্যের একটি নাম এবং একটি প্রকার রয়েছে। অ্যাট্রিবিউটের কিছু সাধারণ ধরন হল পূর্ণসংখ্যা, লেবেল, লেবেলের তালিকা, স্ট্রিং, স্ট্রিংয়ের তালিকা, আউটপুট লেবেল, আউটপুট লেবেলের তালিকা। প্রতিটি নিয়মে সমস্ত বৈশিষ্ট্য নির্দিষ্ট করার প্রয়োজন নেই। এইভাবে বৈশিষ্ট্যগুলি কী (নাম) থেকে ঐচ্ছিক, টাইপ করা মান পর্যন্ত একটি অভিধান তৈরি করে।

অনেক নিয়মে উপস্থিত srcs অ্যাট্রিবিউটে "লেবেলের তালিকা" টাইপ আছে; এর মান, যদি উপস্থিত থাকে, তা হল লেবেলের একটি তালিকা, প্রতিটি একটি লক্ষ্যের নাম যা এই নিয়মের একটি ইনপুট।

কিছু ক্ষেত্রে, নিয়মের ধরণের নামটি কিছুটা স্বেচ্ছাচারী, এবং আরও আকর্ষণীয় হল নিয়ম দ্বারা তৈরি করা ফাইলগুলির নাম এবং এটি জেনরুলের ক্ষেত্রে সত্য। আরও তথ্যের জন্য, সাধারণ নিয়ম দেখুন: genrule

অন্যান্য ক্ষেত্রে, নামটি তাৎপর্যপূর্ণ: *_binary এবং *_test নিয়মের জন্য, উদাহরণস্বরূপ, নিয়মের নাম বিল্ড দ্বারা উত্পাদিত এক্সিকিউটেবলের নাম নির্ধারণ করে।

টার্গেটের উপর এই নির্দেশিত অ্যাসাইক্লিক গ্রাফটিকে টার্গেট গ্রাফ বা বিল্ড নির্ভরতা গ্রাফ বলা হয় এবং এটি সেই ডোমেন যার উপর Bazel Query টুল কাজ করে।

ফাইল