haskell - How to create instances for phantom types returning phantom type? -
इसमें निम्न डेटा प्रकार हैं:
डेटा Foo1 a = Foo1 डेटा Foo2 a = Foo2 (Foo3 ए) डेटा Foo3 a = C1 (Foo1 ए) | C2 Int और अब हम Foo1 या Int से Foo3 प्राप्त करने में सक्षम होना चाहते हैं। एक प्रकार एक वर्ग का उपयोग करने का समाधान हो सकता है:
वर्ग ToFoo3 a to tofoo3 :: a - & gt; Foo3 b - यहाँ इस प्रेत प्रकार b ... उदाहरण ToFoo3 (Foo1 b) के साथ समस्याएं शुरू करें जहां toFoo3 foo1 = C1 foo1 उदाहरण ToFoo3 Int जहां toFoo3 int = C2 int और यहां कंपाइलर शिकायत करता है (सही!) कि वह बी 1 के साथ बी मैच नहीं कर सकता क्योंकि क्लास की परिभाषा में "बी" की संख्या Foo1 में से एक के समान नहीं है।
क्या कोई तरीका है
{- # LANGUAGE MultiParamTypeClasses # -} {- # भाषा फ्लेक्सिबल इंस्टेंस # -} डेटा Foo1 a = Foo1 डेटा Foo2 a = Foo2 (Foo3 ए) डेटा Foo3 a = C1 (Foo1 ए) | सी 2 इट क्लास ToFoo3 a b जहां toFoo3 :: a - & gt; Foo3 b उदाहरण ToFoo3 (Foo1 b) b to tofoo3 foo1 = C1 foo1 उदाहरण ToFoo3 Int b जहां toFoo3 int = C2 int जिस तरह से मैं इसे समझता हूं, आप में कोई फ़ंक्शनल निर्भरता नहीं हो सकती किसी भी Foo3 a प्रकार, और Foo1 a भी की जरूरतों को परिवर्तित करने में सक्षम होने की आवश्यकता होने के कारण, Int एक ही Foo3 a प्रकार में परिवर्तित करने में सक्षम होने के लिए।
बेशक इसका मतलब है कि आप toFoo3 के किसी भी तर्क या परिणाम प्रकार की उम्मीद नहीं कर सकते दूसरे को अव्यवस्था करने में मदद करें, इसलिए आपको इसे इस्तेमाल करने के लिए कभी-कभी टाइपिंग एनोटेशन की परेशानी की आवश्यकता हो सकती है, लेकिन इसके अलावा यह काम करना चाहिए।
संपादित करें: मैं आपको मानता हूँ नहीं < Em> को Foo1 a से Foo3 b के साथ a और b अलग से परिवर्तित करने में सक्षम होना चाहते हैं। अगर मैं इसके बारे में गलत हूं, तो एक पैरामीटर वर्ग के साथ आपके ओपी कोड को काम करना चाहिए यदि आप एक उदाहरण को
उदाहरण ToFoo3 (Foo1b) में बदलते हैं जहां toFoo3 Foo1 = C1 Foo1
Comments
Post a Comment