फोर्क (सॉफ्टवेयर विकास)

सॉफ्टवेयर इंजीनियरिंग में, एक प्रोजेक्ट फोर्क तब होता है जब डेवलपर्स एक कंप्यूटर सॉफ्टवेयर से स्रोत कोड की एक प्रति लेते हैं और उस पर स्वतंत्र विकास शुरू करते हैं, सॉफ्टवेयर का एक अलग और अलग टुकड़ा बनाते हैं। शब्द का अर्थ अक्सर न केवल एक शाखाकरण (संशोधन नियंत्रण) होता है, बल्कि डेवलपर समुदाय में एक विभाजन भी होता है; जैसे, यह विद्वता का एक रूप है। फोर्किंग के लिए आधार अलग-अलग उपयोगकर्ता प्राथमिकताएं हैं और मूल सॉफ़्टवेयर का स्थिर या बंद विकास है।

नि: शुल्क फ्री और ओपन-सोर्स सॉफ्टवेयर है, जो परिभाषा के अनुसार, मूल विकास टीम से पूर्व अनुमति के बिना, और कॉपीराइट कानून का उल्लंघन किए बिना अलग किया जा सकता है। हालाँकि, मालिकाना सॉफ़्टवेयर (जैसे यूनिक्स) के लाइसेंस प्राप्त कांटे भी होते हैं।

व्युत्पत्ति
फोर्क शब्द का उपयोग शाखाओं में विभाजित करने के लिए किया गया है, 14 वीं शताब्दी की शुरुआत में अलग-अलग तरीके से जाना। सॉफ्टवेयर वातावरण में, शब्द कांटा (सिस्टम कॉल) सिस्टम कॉल को उद्घाटित करता है, जो एक चल रही प्रक्रिया को दो (लगभग) समान प्रतियों में विभाजित करने का कारण बनता है जो (आमतौर पर) अलग-अलग कार्यों को करने के लिए अलग हो जाते हैं। सॉफ्टवेयर विकास के संदर्भ में, स्रोत कोड नियंत्रण प्रणाली के संदर्भ में, 1980 की शुरुआत में एरिक एलमैन द्वारा संशोधन नियंत्रण शाखा (संशोधन नियंत्रण) बनाने के अर्थ में कांटा का उपयोग किया गया था:

चर्चा के विषयों को स्थानांतरित करने के लिए एक उपसमूह बनाने की प्रक्रिया के लिए 1983 तक यूज़नेट पर शब्द का उपयोग किया गया था। ल्यूसिड एमाक्स (अब XEmacs) (1991) या बर्कले सॉफ्टवेयर वितरण (1993-1994) की उत्पत्ति के दौरान फोर्क का उपयोग सामुदायिक विद्वता के अर्थ में नहीं किया गया है; रस नेल्सन ने 1993 में इस तरह के कांटे के लिए बिखरने वाले शब्द का इस्तेमाल किया, जिसका श्रेय जॉन गिलमोर (कार्यकर्ता) को दिया गया। हालाँकि, XEmacs विभाजन का वर्णन करने के लिए 1995 तक fork वर्तमान अर्थों में उपयोग में था, और 1996 तक GNU प्रोजेक्ट में एक समझा जाने वाला उपयोग था।

फ्री और खुला स्रोत सॉफ्टवेयर का फोर्किंग
नि: शुल्क सॉफ्टवेयर परिभाषा और मुक्त स्रोत परिभाषा दोनों के अनुसार वर्तमान में विकसित, प्रबंधन, या सॉफ्टवेयर का वितरण करने वालों की पूर्व स्वीकृति के बिना मुफ्त और ओपन-सोर्स सॉफ़्टवेयर को कानूनी रूप से फोर्क किया जा सकता है:

मुफ्त सॉफ्टवेयर में, कांटे अक्सर विभिन्न लक्ष्यों या व्यक्तित्व संघर्षों पर विवाद से उत्पन्न होते हैं। एक फोर्क में, दोनों पक्ष लगभग समान कोड आधार मानते हैं, लेकिन आम तौर पर केवल बड़ा समूह, या जो कोई भी वेब साइट को नियंत्रित करता है, वह पूर्ण मूल नाम और संबंधित उपयोगकर्ता समुदाय को बनाए रखेगा। इस प्रकार, फोर्किंग से जुड़ी एक प्रतिष्ठा दंड है। विभिन्न टीमों के बीच संबंध सौहार्दपूर्ण या बहुत कटु हो सकते हैं। दूसरी ओर, एक दोस्ताना कांटा या नरम कांटा एक कांटा है जो प्रतिस्पर्धा करने का इरादा नहीं रखता है, लेकिन अंततः मूल के साथ विलय करना चाहता है।

एरिक एस. रेमंड ने अपने निबंध होमस्टेडिंग द नोस्फियर में, कहा गया है कि कांटे की सबसे महत्वपूर्ण विशेषता यह है कि यह प्रतिस्पर्धी परियोजनाओं को जन्म देता है जो बाद में संभावित डेवलपर समुदाय को विभाजित करते हुए कोड का आदान-प्रदान नहीं कर सकते हैं। वह शब्दजाल फ़ाइल में नोट करता है:

डेविड ए। व्हीलर नोट्स फोर्क के चार संभावित परिणाम, उदाहरण के साथ:


 * 1) कांटे की मौत। यह अब तक का सबसे आम मामला है। कांटे की घोषणा करना आसान है, लेकिन स्वतंत्र विकास और समर्थन जारी रखने के लिए काफी प्रयास।
 * 2) फोर्क का फिर से विलय (उदाहरण के लिए, जीएनयू कंपाइलर संग्रह के नए संस्करण के रूप में धन्य हो रहा है।)
 * 3) मूल की मृत्यु (उदाहरण के लिए X.Org सर्वर सफल और XFree86 मर रहा है।)
 * 4) सफल ब्रांचिंग, आमतौर पर भेदभाव के साथ (जैसे, OpenBSD और NetBSD।)

वितरित पुनरीक्षण नियंत्रण (डीवीसीएस) उपकरण ने शाखा के साथ भेद को धुंधला करते हुए शब्द कांटा के कम भावनात्मक उपयोग को लोकप्रिय बना दिया है। Mercurial या Git (सॉफ़्टवेयर) जैसे DVCS के साथ, किसी प्रोजेक्ट में योगदान करने का सामान्य तरीका, पहले रिपॉजिटरी की एक व्यक्तिगत शाखा बनाना है, जो मुख्य रिपॉजिटरी से स्वतंत्र है, और बाद में आपके परिवर्तनों को इसके साथ एकीकृत करने का प्रयास करता है। गिटहब, बिट बकेट और लॉन्चपैड (वेबसाइट) जैसी साइटें मुफ्त डीवीसीएस होस्टिंग प्रदान करती हैं जो स्पष्ट रूप से स्वतंत्र शाखाओं का समर्थन करती हैं, जैसे कि स्रोत कोड रिपॉजिटरी को फोर्क करने के लिए तकनीकी, सामाजिक और वित्तीय बाधाएं बड़े पैमाने पर कम हो जाती हैं, और गिटहब इस पद्धति के लिए अपने शब्द के रूप में फोर्क का उपयोग करता है। एक परियोजना में योगदान।

फोर्क्स अक्सर 0.1 या 1.0 से संस्करण क्रमांकन को पुनरारंभ करते हैं, भले ही मूल सॉफ़्टवेयर संस्करण 3.0, 4.0 या 5.0 पर था। एक अपवाद तब होता है जब फोर्क्ड सॉफ़्टवेयर को मूल प्रोजेक्ट के लिए ड्रॉप-इन प्रतिस्थापन के रूप में डिज़ाइन किया जाता है, उदा। MySQL के लिए मारियाडीबी या OpenOffice.org के लिए लिब्रे ऑफिस।

बीएसडी लाइसेंस फोर्क्स को मालिकाना सॉफ्टवेयर बनने की अनुमति देता है, और कॉपीलेफ्ट समर्थकों का कहना है कि वाणिज्यिक प्रोत्साहन इस प्रकार स्वामित्व को लगभग अपरिहार्य बना देते हैं। (कॉपीलेफ्ट लाइसेंस, हालांकि, एक योगदानकर्ता लाइसेंस समझौते के रूप में एक मालिकाना अनुदान के साथ दोहरे लाइसेंसिंग के माध्यम से रोका जा सकता है।) उदाहरणों में शामिल हैं macOS (मालिकाना NeXTSTEP और ओपन सोर्स FreeBSD पर आधारित), Cedega (सॉफ्टवेयर) और विदेशी ( शराब (सॉफ्टवेयर) के मालिकाना कांटे, हालांकि क्रॉसओवर वाइन को ट्रैक करता है और काफी योगदान देता है), एंटरप्राइजडीबी (पोस्टग्रेएसक्यूएल का एक कांटा, ओरेकल संगतता सुविधाओं को जोड़ता है) ), उनके मालिकाना ESM भंडारण प्रणाली के साथ समर्थित PostgreSQL, और Netezza के PostgreSQL का मालिकाना अत्यधिक स्केलेबल व्युत्पन्न। इनमें से कुछ विक्रेता सामुदायिक परियोजना में परिवर्तनों का योगदान करते हैं, जबकि कुछ अपने परिवर्तनों को अपने प्रतिस्पर्धी लाभों के रूप में रखते हैं।

फोर्किंग मालिकाना सॉफ्टवेयर
मालिकाना सॉफ़्टवेयर में, कॉपीराइट आमतौर पर नियोक्ता संस्था के पास होता है, न कि व्यक्तिगत सॉफ़्टवेयर डेवलपर्स के पास। मालिकाना कोड इस प्रकार अधिक सामान्य रूप से फोर्क किया जाता है जब मालिक को दो या दो से अधिक संस्करण विकसित करने की आवश्यकता होती है, जैसे कि विंडो (कंप्यूटिंग) संस्करण और एक कमांड लाइन इंटरफेस संस्करण, या अलग-अलग ऑपरेटिंग सिस्टम के संस्करण, जैसे आईबीएम पीसी संगत मशीनों के लिए शब्द संसाधक और Apple Macintosh कंप्यूटर। आम तौर पर, इस तरह के आंतरिक कांटे प्लेटफार्मों के बीच समान रूप, अनुभव, डेटा प्रारूप और व्यवहार पर ध्यान केंद्रित करेंगे ताकि एक से परिचित उपयोगकर्ता भी उत्पादक हो या दूसरे पर उत्पन्न दस्तावेजों को साझा कर सके। यह लगभग हमेशा एक अधिक बाजार हिस्सेदारी उत्पन्न करने के लिए एक आर्थिक निर्णय है और इस प्रकार फोर्क द्वारा बनाई गई अतिरिक्त विकास लागतों का भुगतान करता है।

इस तरह का एक उल्लेखनीय स्वामित्व कांटा मालिकाना यूनिक्स की कई किस्में नहीं है - लगभग सभी लाइसेंस के तहत एटी एंड टी यूनिक्स से प्राप्त हुए हैं और सभी को यूनिक्स कहा जाता है, लेकिन तेजी से पारस्परिक रूप से असंगत है। यूनिक्स युद्ध देखें।

यह भी देखें

 * सॉफ्टवेयर कांटे की सूची
 * स्रोत पोर्ट
 * डाउनस्ट्रीम (सॉफ्टवेयर विकास)
 * समूह निर्णय लेना
 * मॉड्यूलर प्रोग्रामिंग
 * मॉडिंग
 * निर्देशित सॉफ्टवेयर
 * निजीकरण
 * टीम प्रभावशीलता
 * डुप्लीकेट कोड
 * रॉम हैकिंग

बाहरी संबंध

 * Right to Fork at Meatball Wiki
 * A PhD examining forking: (Nyman, 2015) "Understanding Code Forking in Open Source Software – An examination of code forking, its effect on open source software, and how it is viewed and practiced by developers"