यह एक खास तरह का डेटा स्ट्रक्चर होता है. इसमें डेटा को आसानी से मर्ज किया जा सकता है. साथ ही, इसमें डेटा को ट्रैवर्स करने का क्रम तय होता है. आम तौर पर, इसका इस्तेमाल नियमों और पहलुओं में ट्रांज़िटिव डिपेंडेंसी से डेटा इकट्ठा करने के लिए किया जाता है. ज़्यादा जानकारी के लिए, यहां जाएं.
किसी depset के एलिमेंट हैश किए जा सकने चाहिए और वे सभी एक ही टाइप के होने चाहिए. यह टाइप, बिल्ट-इन type(x) फ़ंक्शन से तय होता है. हालांकि, depsets सिर्फ़ हैश सेट नहीं होते और ये सदस्यता की जांच करने की सुविधा के साथ काम नहीं करते. अगर आपको सामान्य सेट डेटाटाइप की ज़रूरत है, तो कोर Starlark सेट टाइप का इस्तेमाल करें. यह Bazel 8.1 से उपलब्ध है. अगर आपकी .bzl फ़ाइल को Bazel के पुराने वर्शन के साथ काम करना है, तो डिक्शनरी का इस्तेमाल करके सेट को सिम्युलेट किया जा सकता है. इसमें सभी कुंजियां True पर मैप होती हैं.
जब किसी डीपसेट की जांच की जाती है, तब यह सिर्फ़ तब सही होता है, जब यह खाली न हो. जांच करने का यह तरीका O(1) ऑपरेशन है. जांच तब की जाती है, जब डीपसेट का इस्तेमाल बूलियन कॉन्टेक्स्ट में किया जाता है. जैसे, if d: जहां if d: एक डीपसेट है.d
डिपसेट में बदलाव नहीं किया जा सकता. इन्हें इनके कंस्ट्रक्टर फ़ंक्शन का इस्तेमाल करके बनाया जाना चाहिए. साथ ही, transitive आर्ग्युमेंट के ज़रिए, इन्हें अन्य depsets के साथ मर्ज या बढ़ाया जाना चाहिए.
order पैरामीटर यह तय करता है कि depset को iterable में बदलने के लिए किस तरह का ट्रैवर्सल किया जाता है. इन चार वैल्यू का इस्तेमाल किया जा सकता है:
-
"default"(पहले"stable"): ऑर्डर की जानकारी नहीं दी गई है (लेकिन तय है). -
"postorder"(पहले"compile"): यह बाएं से दाएं क्रम में पोस्ट-ऑर्डरिंग करता है. यह फ़ंक्शन, सभी चाइल्ड एलीमेंट को बाईं ओर से दाईं ओर ले जाता है. इसके बाद, डायरेक्ट एलीमेंट को बाईं ओर से दाईं ओर ले जाता है. -
"preorder"(पहले"naive_link"): इसमें बाएं से दाएं की ओर प्री-ऑर्डर किया जाता है. यह फ़ंक्शन, सबसे पहले सीधे तौर पर मौजूद एलीमेंट को बाईं ओर से दाईं ओर ले जाता है. इसके बाद, यह चाइल्ड एलीमेंट को बाईं ओर से दाईं ओर ले जाता है. -
"topological"(पहले"link"): यह रूट से लेकर लीफ़ तक के नोड को टोपोलॉजिकल क्रम में दिखाता है. इसमें बाएं से दाएं की ओर पढ़ने की गारंटी नहीं होती.
दो depsets को सिर्फ़ तब मर्ज किया जा सकता है, जब दोनों depsets का क्रम एक जैसा हो या उनमें से किसी एक का क्रम "default" हो. दूसरे मामले में, नतीजे के तौर पर मिले डिसेट का क्रम, दूसरे डिसेट के क्रम जैसा ही होगा.
डिपसेट में डुप्लीकेट वैल्यू हो सकती हैं, लेकिन इन्हें दोहराते समय (to_list() का इस्तेमाल करके) छिपा दिया जाएगा. डुप्लीकेट वैल्यू, क्रम से जुड़ी सिमैंटिक में रुकावट डाल सकती हैं.
सदस्य
to_list
list depset.to_list()
"default"-ऑर्डर किए गए depsets के लिए भी ऑर्डर तय नहीं किया गया है. साथ ही, उन चाइल्ड depsets के एलिमेंट के लिए भी ऑर्डर तय नहीं किया गया है जिनका ऑर्डर, पैरंट depset से अलग है. यह सूची एक कॉपी है. इसमें बदलाव करने से, depset पर कोई असर नहीं पड़ता. इसी तरह, depset में बदलाव करने से सूची पर कोई असर नहीं पड़ता.