هاسكل (لغة برمجة)
هاسكل Haskell /ˈhæskəl/[27] هي لغة برمجة للأغراض العامة، مكتوبة بشكل ثابت، وظيفية بحتة مع استدلال النوع وذات تقييم حسب الحاجة.[28][29] تم تطوير هاسكل لتكون مناسبة للتدريس والبحث والتطبيقات الصناعية، وقد كانت رائدة في عدد من ميزات لغة البرمجة المتقدمة مثل فئات النوع، والتي تتيح التحميل الزائد للمشغل من النوع الآمن. تطبيق هاسكل الرئيسي هو مترجم گلاسكو هاسكل (GHC). سميت على اسم عالم المنطق هاسكل كيري.[1]
تستند دلالات هاسكل تاريخياً إلى تلك الخاصة بلغة البرمجة ميراندا، والتي عملت على تركيز جهود مجموعة عمل هاسكل الأولية.[30] تم إجراء آخر مواصفات رسمية للغة في يوليو 2010، بينما استمر تطوير تطبيق GHC في توسيع هاسكل عبر ملحقات اللغة. المواصفات الرسمية التالية مخطط لها لعام 2020.[3]
تستخدم هاسكل في الأوساط الأكاديمية[31][32] والصناعة.[33][34] اعتباراً من سبتمبر 2020، احتلت هاسكل هي لغة البرمجة الأكثر شيوعاً ذات رقم 28 من حيث عمليات البحث على گوگل[35]للدروس التعليمية وشكلوا أقل من 1٪ من المستخدمين النشطين في مخزن شيفرة مصدر گيتهب.[36]
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
تاريخ
بعد إصدار ميراندا من قبل شركة ريسيرش سوفتوير المحدودة في عام 1985، ازداد الاهتمام بـ اللغات الوظيفية حسب الحاجة. بحلول عام 1987، كان هناك أكثر من اثنتي عشرة لغات برمجة وظيفية بحتة غير دقيقة. كانت ميراندا هي الأكثر استخداماً، لكنها كانت برمجيات احتكارية. في مؤتمر لغات البرمجة الوظيفية والبنى الحاسوبية (FPCA '87) في پورتلاند، أوريگون، كان هناك إجماع قوي على تشكيل لجنة لتحديد معيار مفتوح لهذه اللغات. كان الغرض من اللجنة هو دمج اللغات الوظيفية الموجودة في لغة شائعة لتكون بمثابة أساس للبحث في المستقبل في تصميم اللغة الوظيفية.[37]
هاسكل من 1.0 إلى 1.4
تم اقتراح فئات النوع، التي تمكّن التحميل الزائد للمشغل بشكل آمن، لأول مرة بواسطة فيليپ وادلر وستيفن بلوت لـ إمإل معيارية ولكن تم تنفيذها لأول مرة في هاسكل بين 1987 والإصدار 1.0.[38][39]
تم تحديد الإصدار الأول من هاسكل ("هاسكل 1.0") في عام 1990.[1] نتج عن جهود اللجنة سلسلة من تعريفات اللغة (1.0, 1.1, 1.2, 1.3, 1.4).
هاسكل 98
في أواخر عام 1997، بلغت السلسلة ذروتها في Haskell 98، الذي يهدف إلى تحديد نسخة مستقرة، ومحدودة، ومحمولة من اللغة و مكتبة قياسية مناسبة للتدريس، وكقاعدة للملحقات المستقبلية. وقد رحبت اللجنة صراحة بإنشاء ملحقات ومتغيرات لـ هاسكل 98 من خلال إضافة ودمج الميزات التجريبية.[37]
في فبراير 1999، تم نشر معيار لغة هاسكل 98 في الأصل باسم تقرير هاسكل 98.[37] في يناير 2003، تم نشر نسخة منقحة باسم هاسكل 98 اللغة والمكتبات: التقرير المنقح.[29] حيث تستمر اللغة في التطور بسرعة، مع تطبيق مترجم گلاسكو هاسكل (GHC) الذي يمثل المعيار الواقعي الحالي.[40]
هاسكل 2010
في أوائل عام 2006، بدأت عملية تحديد خليفة لمعيار هاسكل 98، المسمى بشكل غير رسمي هاسكل پرايم.[41] كان القصد من ذلك أن يكون عملية تدريجية مستمرة لمراجعة تعريف اللغة، وإنتاج مراجعة جديدة تصل إلى مرة واحدة في السنة. تم الإعلان عن المراجعة الأولى، المسماة هاسكل 2010، في نوفمبر 2009[2] وتم نشرها في يوليو 2010.
هاسكل 2010 هو تحديث تدريجي للغة، يشتمل في الغالب على العديد من الميزات المستخدمة جيداً وغير المثيرة للجدل والتي تم تمكينها مسبقاً عبر العلامات الخاصة بالمترجم.
- أسماء الوحدات الهرمية. يُسمح لأسماء الوحدات النمطية بأن تتكون من تسلسلات مفصولة بالنقاط لمعرفات بأحرف كبيرة، بدلاً من معرف واحد فقط. يتيح ذلك تسمية الوحدات بطريقة هرمية (على سبيل المثال،
Data.List
بدلاً منList
)، على الرغم من أن الوحدات النمطية من الناحية الفنية لا تزال في فضاء اسم واحد متجانس. تم تحديد هذه الإضافة في ملحق هاسكل 98 وقد تم استخدامه بشكل شامل. - تسمح واجهة الدوال الخارجية (FFI) بالربط بلغات البرمجة الأخرى. تم تحديد الارتباطات بـ سي فقط في التقرير، لكن التصميم يسمح بربط لغة أخرى. لدعم ذلك، تم السماح لإعلانات نوع البيانات بعدم احتواء أي مُنشئين، مما يتيح أنواعاً قوية مناسبة للبيانات الخارجية التي لا يمكن إنشاؤها في هاسكل. تم تحديد هذا الملحق مسبقاً في ملحق لتقرير هاسكل 98 وتم استخدامها على نطاق واسع.
- ما يسمى بأنماط n+k (تعريفات الشكل
fact (n+1) = (n+1) * fact n
) لم يعد مسموحاً بها. يحتوي هذا التجميل اللغوي على دلالات مضللة، حيث بدت الشفرة وكأنها تستخدم العامل(+)
، ولكنها في الواقع تم إلغاء وصفها باستخدام(-)
و(>=)
- تم تخفيف قواعد استدلال النوع للسماح لمزيد من البرامج بالقيام بتحقق النوع.
- تم إصلاح بعض مشكلات التركيب اللغوي (التغييرات في القواعد النحوية الرسمية): تمت إضافة حماية النمط، مما يسمح بمطابقة الأنماط داخل الحماية؛ تم تحديد قرار ثبات العوامل بطريقة أبسط تعكس الممارسة الفعلية؛ تمت معالجة حالة طرفية في تفاعل بناء اللغة معجمياً للعوامل والتعليقات، وتم تعديل تفاعل التدوين و if-then-else لإزالة الأخطاء التركيبية غير المتوقعة.
- تم تحديد توجيه
LANGUAGE
. بحلول عام 2010، لقد تم استخدام العشرات من ملحقات اللغة على نطاق واسع، وقدمت GHC (من بين المترجمين الآخرين)LANGUAGE
لتحديد الملحقات الفردية مع قائمة المعرفات. حيث يتم طلب مترجمي هاسكل 2010 لدعم الملحقHaskell2010
ويتم تشجيعهم على دعم العديد من الملحقات الأخرى، والتي تتوافق مع الملحقات المضافة في هاسكل 2010.
الميزات
تتميز هاسكل بالتقييم حسب الحاجة وتعبيرات لامدا و مطابقة النمط و قائمة الإدراك و فئة النوع و تعدد الأشكال. فهي لغة وظيفية بحتة، مما يعني أن الوظائف عموماً ليس لها آثار جانبية. توجد بنية مميزة لتمثيل الآثار الجانبية، متعامد مع نوع الدوال. يمكن أن تُرجع الدالة البحتة تأثيراً جانبياً يتم تنفيذه لاحقاً، بنمذجة دوال غير بحتة للغات أخرى.
تمتلك هاسكل نظاماً قوياً، ثابتاً يعتمد على استدلال نوع هندلي - ميلنر. ابتكاراتها الرئيسية في هذا المجال هي فئات النوع، التي تم تصورها في الأصل كطريقة مبدئية لإضافة التحميل الزائد إلى اللغة،[42]ولكن منذ العثور على العديد من الاستخدامات.[43]
التركيب الذي يمثل الآثار الجانبية هو مثال على موناد. موناد عبارة عن إطار عام يمكنه نمذجة أنواع مختلفة من الحسابات، بما في ذلك معالجة الأخطاء، عدم التحديد، تفسير الكلمة و ذاكرة معاملات البرمجيات. يتم تعريف موناد على أنها أنواع بيانات عادية، لكن هاسكل توفر بعض التجميل اللغوي لاستخدامها.
هاسكل لها مواصفات مفتوحة منشورة، [29] و توجد تطبيقات متعددة. تطبيقه الرئيسي، مصرِّف گلاسگو هاسكل (GHC)، هو مترجم و مترجم كود أصلي يعمل على معظم الأنظمة الأساسية. تمت ملاحظة GHC لنظامها الغني الذي يشتمل على الابتكارات الحديثة مثل نوع البيانات الجبرية المعمم ومجموعات النوع. تسلط لعبة معايير لغة الحاسب الضوء أيضاً على تنفيذها عالي الأداء لـ التزامن و التوازي.[44]
يتواجد مجتمع نشط ومتزايد حول اللغة، وتتوفر أكثر من 5400 مكتبة وأدوات مفتوحة المصدر تابعة لجهات خارجية في مستودع قرصنة الحزم عبر الإنترنت.[45]
أمثلة على الشيفرة
برنامج "Hello، World!" في هاسكل (السطر الأخير فقط هو الضروري للغاية):
module Main (main) where -- not needed in interpreter, is the default in a module file
main :: IO () -- the compiler can infer this type definition
main = putStrLn "Hello, World!"
تم تعريف الدالة العاملية في هاسكل، بعدة طرق مختلفة:
-- Type annotation (optional, same for each implementation)
factorial :: (Integral a) => a -> a
-- Using recursion (with the "ifthenelse" expression)
factorial n = if n < 2
then 1
else n * factorial (n - 1)
-- Using recursion (with pattern matching)
factorial 0 = 1
factorial n = n * factorial (n - 1)
-- Using recursion (with guards)
factorial n
| n < 2 = 1
| otherwise = n * factorial (n - 1)
-- Using a list and the "product" function
factorial n = product [1..n]
-- Using fold (implements "product")
factorial n = foldl (*) 1 [1..n]
-- Point-free style
factorial = foldr (*) 1 . enumFromTo 1
نظراً لأن النوع عدد صحيح يحتوي على دقة عشوائية، فإن هذا الرمز سيحسب قيماً مثل factorial 100000
(رقم مكون من 456،574 رقماً)، بدون فقدان الدقة.
تنفيذ خوارزمية مشابهة لـ الفرز السريع على القوائم، حيث يتم أخذ العنصر الأول كمحور:
-- Type annotation (optional, same for each implementation)
quickSort :: Ord a => [a] -> [a]
-- Using list comprehensions
quickSort [] = [] -- The empty list is already sorted
quickSort (x:xs) = quickSort [a | a <- xs, a < x] -- Sort the left part of the list
++ [x] ++ -- Insert pivot between two sorted parts
quickSort [a | a <- xs, a >= x] -- Sort the right part of the list
-- Using filter
quickSort [] = []
quickSort (x:xs) = quickSort (filter (<x) xs)
++ [x] ++
quickSort (filter (>=x) xs)
التطبيقات
يتم توزيع جميع التطبيقات المدرجة بموجب تراخيص مفتوحة المصدر.[46]
تشمل التطبيقات التي تتوافق تماماً أو تقريباً مع معيار هاسكل 98 ما يلي:
- يجمع مصرِّف گلاسگو هاسكل (GHC) إلى كود أصلي في العديد من بنى المعالجات المختلفة، وإلى آنسي سي، عبر واحد من لغتين وسيطتين: سي--، أو في الإصدارات الأحدث، LLVM (المعروف سابقاً باسم آلة افتراضية منخفضة المستوى).[47][48] أصبحت GHC هي اللغة القياسية الفعلية.[49]هناك مكتبات (على سبيل المثال، روابط لـ جيإل المفتوحة) التي تعمل فقط مع GHC. يتم توزيع GHC أيضاً مع منصة هاسكل.
- يؤكد Jhc، مترجم هاسكل الذي كتبه جون ميشام، على سرعة وكفاءة البرامج التي تم إنشاؤها واستكشاف تحولات البرامج الجديدة.
- Ajhc هو فرع Jhc.
- مترجم أوتريخت هاسكل (UHC) هو تطبيق هاسكل من جامعة أوتريخت.[50] الذي يدعم جميع ميزات هاسكل 98 تقريباً بالإضافة إلى العديد من الإضافات التجريبية. يتم تنفيذه باستخدام قواعد النحو ويستخدم حالياً في الغالب للبحث في أنظمة الكتابة المُولدة وملحقات اللغة.
تشمل التطبيقات التي لم تعد تتم صيانتها بشكل فعال ما يلي:
- نظام گوفر لمستخدم هاسكل (هگز) هو مترجم بايتكود. كانت إحدى التطبيقات الأكثر استخداماً على نطاق واسع، إلى جانب مترجم [51] ولكن تم استبدالها في الغالب بـ GHCi. كما يأتي مع مكتبة رسومات.
- HBC هو تطبيق أولي يدعم هاسكل 1.4. تم تنفيذه من قبل لنارت أوگستسن في إمإل حسب الحاجة والمستندة إليها. لم يتم تطويره بفعالية لبعض الوقت.
- nhc98 هو مترجم للبايتكود والذي يركز على تقليل استخدام الذاكرة.
- كان مترجم يورك هاسكل (Yhc) فرعاً لـ nhc98، بهدف أن يكون أبسط وأكثر قدرة على النقل والفعالية، ودمج الدعم لهات، متتبع هاسكل. كما أن لديها خلفية جاڤا سكرپت، مما يسمح للمستخدمين بتشغيل برامج هاسكل في متصفحات الوب.
تتضمن التطبيقات غير المتوافقة مع هاسكل 98 بشكل كامل، وتستخدم لغة هاسكل المتغيرة:
- إيتا و فريج هما لغات من هاسكل تستهدفان آلة جاڤا الافتراضية.
- گوفر كانت لغة تعليمية لهاسكل، مع ميزة تسمى فئات المنشئ، التي طورها مارك جونز. وقد حل محله هگز (نظام گوفر لمستخدم هاسكل).
- هليوم، وهي لغة أحدث من هاسكل. ينصب التركيز على تسهيل التعلم عبر رسائل خطأ أوضح. يفتقر حالياً إلى الدعم الكامل لفئات النوع، مما يجعله غير متوافق مع العديد من برامج هاسكل.
التطبيقات البارزة
- كابال هي أداة لـ بناء وتعبئة مكتبات وبرامج هاسكل.[52]
- داركس هو نظام مراقبة المراجعة مكتوب بلغة هاسكل، مع العديد من الميزات المبتكرة، مثل التحكم الأكثر دقة في التصحيحات المراد تطبيقها.
- GHC غالباً ما يكون أيضاً اختباراً لميزات البرمجة الوظيفية المتقدمة والتحسينات في لغات البرمجة الأخرى.
- گت-آنكس هي أداة لإدارة ملفات البيانات (الكبيرة) تحت التحكم في الإصدار گت. كما يوفر نظام مزامنة الملفات الموزعة (مساعد گت-آنكس).
- اختار لينسپاير GNU / لينكس هاسكل لتطوير أدوات النظام.[53]
- پاندوك هي أداة لتحويل تنسيق العلامات إلى تنسيق آخر.
- پگز هو مترجم و مفسر لـ لغة البرمجة راكو (سابقاً پرل 6).
- إكسموناد هو مدير نوافذ لـ نظام النافذة X، والمكتوب بالكامل بلغة هاسكل.[54]
في الصناعة
- لغة SystemVerilog بلوزسپك (BSV) وهي لغة لتصميم أشباه الموصلات وهي ملحق لـ هاسكل. أيضاً، يتم تنفيذ أدوات شركة بلوزسپك في هاسكل.
- تم تطبيق كرپتول، وهي لغة وأدوات لتطوير الخوارزميات [[علم]التعمية|التعمية] والتحقق منها، في هاسكل.
- ينفذ فيسبوك برامج مكافحة البريد العشوائي[55] في هاسكل، والحفاظ على مكتبة الوصول إلى البيانات الأساسية كـبرمجيات مفتوح المصدر.[56]
- قام گيتهَب بتطبيق الدلاليات، وهي مكتبة مفتوحة المصدر لتحليل وتنويع وتفسير شيفرة المصدر غير الموثوق بها، في هاسكل.[57]
- seL4، أول نوية، تم التحقق منها رسمياً[58] وقد تم استخدام هاسكل كلغة نماذج أولية لمطور نظام التشغيل.[58] في الوقت نفسه، حددت شيفرة هاسكل مواصفات قابلة للتنفيذ يمكن من خلالها التفكير، للترجمة الآلية بواسطة أداة إثبات المبرهنات.[58] وهكذا فإن شيفرة هاسكل كانت بمثابة نموذج أولي وسيط قبل التنقيح النهائي للغة سي.[58]
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
في الوب
تتضمن إطارات عمل الوب البارزة المكتوبة لـ هاسكل:[59]
الانتقاد
ناقش يان-ڤيليم مايسين، في عام 2002، و سيمون پيتون جونز، في عام 2003، المشكلات المرتبطة بالتقييم حسب الحاجة مع الاعتراف أيضاً بالدوافع النظرية لذلك.[60][61] بالإضافة إلى اعتبارات عملية بحتة مثل تحسين الأداء،[62] وقد لاحظوا أنه بالإضافة إلى إضافة بعض النفقات العامة للأداء، فإن التقييم البطيء يجعل من الصعب على المبرمجين التفكير في أداء الشيفرة الخاصة بهم (خاصة استخدام المساحة الخاصة بها). لاحظ كل من باستيان هيرين، ودان ليين، وأريان ڤان إيجيندورن في عام 2003 أيضاً بعض العقبات أمام متعلمي هاسكل: "تعد البنية الدقيقة ونظام النوع المتطور في هاسكل سيفاً ذا حدين - يحظى بتقدير كبير من قبل المبرمجين ذوي الخبرة ولكنه أيضاً مصدر إحباط بين المبتدئين، لأن عمومية هاسكل تؤدي غالباً إلى رسائل خطأ مشفرة."[63]لمعالجة هذه المشكلات، طور باحثون من جامعة أوترخت مترجماً متقدماً يسمى هيليوم، مما أدى إلى تحسين سهولة استخدام رسائل الخطأ عن طريق الحد من عمومية بعض ميزات هاسكل، وعلى وجه الخصوص إزالة دعم فئات النوع. قام بن لپماير بتصميم دسايپل[64]باعتبارها لغة صارمة افتراضياً (وحسب الحاجة من خلال التعليقات التوضيحية الصريحة) هاسكل مع نظام النوع والتأثير، لمعالجة صعوبات هاسكل في التفكير حول التقييم البطيء وفي استخدام هياكل البيانات التقليدية مثل المصفوفات.[65]وقد ناقش (p. 20) بأن "التحديث الهدام يزود المبرمج بأداتين مهمتين وقويتين ... مجموعة من هياكل البيانات الشبيهة بالمصفوفات لإدارة مجموعات الكائنات، و ... القدرة على بث قيمة جديدة لجميع أجزاء البرنامج بأقل عبء على المبرمج."
أعطى روبرت هارپر، أحد مؤلفي إمإل المعيارية، أسبابه لعدم استخدام هاسكل لتعليم البرمجة التمهيدية. من بين هذه صعوبة التفكير حول استخدام الموارد مع التقييم غير الصارم، وهذا التقييم حسب الحاجة يقوم بتعقيد تعريف أنواع البيانات والاستدلال الاستقرائي،[66] و "دونية" نظام الفصل (القديم) في هاسكل مقارنة بنظام الوحدات النمطية في إمإل.[67]
تعرضت أداة بناء هاسكل، كابال ، تاريخياً لانتقادات بسبب سوء التعامل مع إصدارات متعددة من نفس المكتبة، وهي مشكلة تُعرف باسم "كابال هل". تم إنشاء مخدم التكديس و المكدس رداً على هذه الانتقادات.[68] لدى كابال نفسها الآن نظام بناء أكثر تعقيداً، مستوحى بشكل كبير من نكس،[69] والذي أصبح الافتراضي مع الإصدار 3.0.
اللغات المرتبطة
كلين وهي لغة قريبة وأقدم قليلًا من هاسكل. أكبر انحراف لها عن هاسكل هو استخدام نوع التفرد بدلاً من مونادز للإدخال / الإخراج والآثار الجانبية.
تم تطوير سلسلة من اللغات المستوحاة من هاسكل، ولكن بأنظمة مختلفة، بما في ذلك:
- آگدا، لغة وظيفية بها أنواع تابعة.
- كايين، مع أنواع تابعة.
- إلم، لغة وظيفية لإنشاء تطبيقات الوب الأمامية، لا يوجد دعم للأنواع عالية الجودة.
- إپگرام، لغة وظيفية ذات أنواع تابعة مناسبة لإثبات خصائص البرامج.
- إدريس، لغة وظيفية للأغراض العامة مع أنواع تابعة، تم تطويرها في جامعة سانت أندروز.
- پيورسكرپت التي تحول إلى جاڤاسكرپت.
- أوميگا صارمة إلى حد بعيد.
تشمل اللغات الأخرى المرتبطة:
- كيري، لغة برمجة وظيفية / منطقية مبنية على هاسكل.
تشمل متغيرات هاسكل البارزة ما يلي:
- هاسكل عامة، وهي نسخة من هاسكل مع دعم نظام النوع لـ البرمجة العامة.
- هيوم، وهي لغة وظيفية صارمة لـ الأنظمة المضمنة والتي تعتمد على العمليات مثل التلقائية عديمة الحالة عبر نوع من مجموعات قنوات صندوق بريد عنصر واحد حيث يتم الاحتفاظ بالحالة عن طريق التغذية العكسية في علب البريد، ووصف تخطيط من المخرجات إلى القنوات مثل الأسلاك الصندوقية، مع لغة تعبير وصيغة تشبه هاسكل.
المؤتمرات وورشات العمل
يلتقي مجتمع هاسكل بانتظام لأنشطة البحث والتطوير. والأحداث الرئيسية هي:
- المؤتمر الدولي حول البرمجة الوظيفية (ICFP)
- ندوة هاسكل (ورشة هاسكل سابقاً)
- ورشة مطوري هاسكل
- المستخدمون التجاريون للبرمجة الوظيفية (CUFP)
منذ عام 2006، حدثت سلسلة من "الهاكاثونات" المنظمة، سلسلة هاك، والتي تهدف إلى تحسين أدوات لغة البرمجة والمكتبات.[70]
المراجع
- ^ أ ب ت Hudak et al. 2007.
- ^ أ ب قالب:Cite mailing list
- ^ أ ب قالب:Cite mailing list
- ^ أ ب ت ث ج ح خ د ذ ر ز س ش Peyton Jones 2003, p. xi
- ^ Norell, Ulf (2008). "Dependently Typed Programming in Agda" (PDF). Gothenburg: Chalmers University. Retrieved 9 فبراير 2012.
- ^ Hudak et al. 2007, pp. 12–38, 43.
- ^ Stroustrup, Bjarne; Sutton, Andrew (2011). "Design of Concept Libraries for C++" (PDF). Archived from the original (PDF) on 10 فبراير 2012.
{{cite journal}}
: Cite journal requires|journal=
(help) - ^ أ ب ت ث ج ح خ د ذ ر Hudak et al. 2007, pp. 12-45–46.
- ^ أ ب Meijer, Erik (2006). "Confessions of a Used Programming Language Salesman: Getting the Masses Hooked on Haskell". Oopsla 2007. CiteSeerX 10.1.1.72.868.
- ^ Meijer, Erik (1 أكتوبر 2009). "C9 Lectures: Dr. Erik Meijer – Functional Programming Fundamentals, Chapter 1 of 13". Channel 9. Microsoft. Retrieved 9 فبراير 2012.
- ^ Drobi, Sadek (4 مارس 2009). "Erik Meijer on LINQ". InfoQ. QCon SF 2008: C4Media Inc. Retrieved 9 فبراير 2012.
{{cite news}}
: CS1 maint: location (link) - ^ Hickey, Rich. "Clojure Bookshelf". Listmania!. Archived from the original on 3 أكتوبر 2017. Retrieved 3 أكتوبر 2017.
- ^ Heller, Martin (18 أكتوبر 2011). "Turn up your nose at Dart and smell the CoffeeScript". InfoWorld. Retrieved 2020-07-15.
- ^ "Declarative programming in Escher" (PDF). Retrieved 7 أكتوبر 2015.
- ^ Syme, Don; Granicz, Adam; Cisternino, Antonio (2007). Expert F#. Apress. p. 2.
F# also draws from Haskell particularly with regard to two advanced language features called sequence expressions and workflows.
- ^ Wechsung, Ingo. "The Frege Programming Language" (PDF). Retrieved 26 فبراير 2014.
- ^ "Facebook Introduces 'Hack,' the Programming Language of the Future". WIRED. 20 مارس 2014.
- ^ "Idris, a dependently typed language". Retrieved 26 أكتوبر 2014.
- ^ "LiveScript Inspiration". Retrieved 4 فبراير 2014.
- ^ Freeman, Phil (2016). "PureScript by Example". Leanpub. Retrieved 23 أبريل 2017.
- ^ Kuchling, A. M. "Functional Programming HOWTO". Python v2.7.2 documentation. Python Software Foundation. Retrieved 9 فبراير 2012.
- ^ "Glossary of Terms and Jargon". Perl Foundation Perl 6 Wiki. The Perl Foundation. Archived from the original on 21 يناير 2012. Retrieved 9 فبراير 2012.
- ^ "The Rust Reference: Appendix: Influences". Retrieved 3 فبراير 2016.
- ^ Fogus, Michael (6 أغسطس 2010). "MartinOdersky take(5) toList". Send More Paramedics. Retrieved 9 فبراير 2012.
- ^ Lattner, Chris (3 يونيو 2014). "Chris Lattner's Homepage". Chris Lattner. Retrieved 3 يونيو 2014.
The Swift language is the product of tireless effort from a team of language experts, documentation gurus, compiler optimization ninjas, and an incredibly important internal dogfooding group who provided feedback to help refine and battle-test ideas. Of course, it also greatly benefited from the experiences hard-won by many other languages in the field, drawing ideas from Objective-C, Rust, Haskell, Ruby, Python, C#, CLU, and far too many others to list.
- ^ "Timber/History". Retrieved 7 أكتوبر 2015.
- ^ قالب:Cite mailing list
- ^ Type inference originally using Hindley-Milner type inference
- ^ أ ب ت Peyton Jones 2003.
- ^ Edward Kmett, Edward Kmett – Type Classes vs. the World
- ^ "Haskell in education". Retrieved 15 فبراير 2016.
- ^ "Haskell in research". Retrieved 15 فبراير 2016.
- ^ Mossberg, Erik (2020-06-08), erkmos/haskell-companies, https://github.com/erkmos/haskell-companies, retrieved on 2020-06-22
- ^ "Haskell in industry - HaskellWiki". wiki.haskell.org. Retrieved 22 يونيو 2020.
- ^ "PYPL PopularitY of Programming Language index". pypl.github.io (in الإنجليزية). 22 يناير 2021. Archived from the original on 17 سبتمبر 2020. Retrieved 22 يناير 2021.
{{cite web}}
:|archive-date=
/|archive-url=
timestamp mismatch; 4 سبتمبر 2019 suggested (help) - ^ Frederickson, Ben. "Ranking Programming Languages by GitHub Users". www.benfrederickson.com. Retrieved 6 سبتمبر 2019.
- ^ أ ب ت Peyton Jones 2003, Preface.
- ^ "Type classes, first proposed during the design of the Haskell programming language, ..." —John Garrett Morris (2013), "Type Classes and Instance Chains: A Relational Approach"
- ^ Wadler, Philip (أكتوبر 1988). "How to make ad-hoc polymorphism less ad hoc".
- ^ "Haskell Wiki: Implementations". Retrieved 18 ديسمبر 2012.
- ^ "Welcome to Haskell'". The Haskell' Wiki.
- ^ Wadler, P.; Blott, S. (1989). "How to make ad-hoc polymorphism less ad hoc". Proceedings of the 16th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages. ACM: 60–76. doi:10.1145/75277.75283. ISBN 978-0-89791-294-5. S2CID 15327197.
- ^ Hallgren, T. (يناير 2001). "Fun with Functional Dependencies, or Types as Values in Static Computations in Haskell". Proceedings of the Joint CS/CE Winter Meeting. Varberg, Sweden.
- ^ Computer Language Benchmarks Game
- ^ "HackageDB statistics". Hackage.haskell.org. Archived from the original on 3 مايو 2013. Retrieved 26 يونيو 2013.
- ^ "Implementations" at the Haskell Wiki
- ^ "The LLVM Backend". GHC Trac.
- ^ (2010) "An LLVM Backend for GHC"., ACM Press.
- ^ C. Ryder and S. Thompson (2005). "Porting HaRe to the GHC API"
- ^ Utrecht Haskell Compiler
- ^ Hudak et al. 2007, pp. 12–22.
- ^ "The Haskell Cabal". Retrieved 8 أبريل 2015.
- ^ "Linspire/Freespire Core OS Team and Haskell". Debian Haskell mailing list. مايو 2006.
- ^ xmonad.org
- ^ "Fighting spam with Haskell". Facebook Code (in الإنجليزية الأمريكية). 26 يونيو 2015. Retrieved 11 أغسطس 2019.
- ^ "Open-sourcing Haxl, a library for Haskell". Facebook Code (in الإنجليزية الأمريكية). 10 يونيو 2014. Retrieved 11 أغسطس 2019.
- ^ Parsing, analyzing, and comparing source code across many languages: github/semantic, GitHub, 7 June 2019, https://github.com/github/semantic, retrieved on 7 June 2019
- ^ أ ب ت ث A formal proof of functional correctness was completed in 2009. (October 2009) "seL4: Formal verification of an OS kernel"..
- ^ "Web/Frameworks – HaskellWiki". wiki.haskell.org. Retrieved 11 أغسطس 2019.
- ^ Jan-Willem Maessen. Eager Haskell: Resource-bounded execution yields efficient iteration. Proceedings of the 2002 Association for Computing Machinery (ACM) SIGPLAN workshop on Haskell.
- ^ Simon Peyton Jones. Wearing the hair shirt: a retrospective on Haskell. Invited talk at POPL 2003.
- ^ "Lazy evaluation can lead to excellent performance, such as in The Computer Language Benchmarks Game".
- ^ Heeren, Bastiaan; Leijen, Daan; van IJzendoorn, Arjan (2003). "Helium, for learning Haskell" (PDF). Proceedings of the 2003 ACM SIGPLAN Workshop on Haskell: 62–71. doi:10.1145/871895.871902. ISBN 1581137583. S2CID 11986908.
- ^ "DDC – HaskellWiki". Haskell.org. 3 ديسمبر 2010. Retrieved 26 يونيو 2013.
- ^ Ben Lippmeier, Type Inference and Optimisation for an Impure World, Australian National University (2010) PhD thesis, chapter 1
- ^ Robert Harper. "The point of laziness". قالب:Closed access
- ^ Robert Harper. "Modules matter most". قالب:Closed access
- ^ "Solving Cabal Hell". www.yesodweb.com. Retrieved 11 أغسطس 2019.
- ^ "Announcing cabal new-build: Nix-style local builds". Retrieved 1 أكتوبر 2019.
- ^ "Hackathon – HaskellWiki".
للاستزادة
- التقارير
- Peyton Jones, Simon, ed. (2003). Haskell 98 Language and Libraries: The Revised Report. Cambridge University Press. ISBN 978-0521826143.
- Marlow, Simon, ed. (2010). Haskell 2010 Language Report (PDF). Haskell.org.
- الكتب التدريسية
- Davie, Antony (1992). An Introduction to Functional Programming Systems Using Haskell. Cambridge University Press. ISBN 978-0-521-25830-2.
- Bird, Richard (1998). Introduction to Functional Programming using Haskell (2nd ed.). Prentice Hall Press. ISBN 978-0-13-484346-9.
- Hudak, Paul (2000). The Haskell School of Expression: Learning Functional Programming through Multimedia. New York: Cambridge University Press. ISBN 978-0521643382.
- Hutton, Graham (2007). Programming in Haskell. Cambridge University Press. ISBN 978-0521692694.
- O'Sullivan, Bryan; Stewart, Don; Goerzen, John (2008). Real World Haskell. Sebastopol: O'Reilly. ISBN 978-0-596-51498-3 (full text)
{{cite book}}
: External link in
(help)CS1 maint: postscript (link)|postscript=
- Thompson, Simon (2011). Haskell: The Craft of Functional Programming (3rd ed.). Addison-Wesley. ISBN 978-0201882957.
- Lipovača, Miran (أبريل 2011). Learn You a Haskell for Great Good!. San Francisco: No Starch Press. ISBN 978-1-59327-283-8. (full text)
- Bird, Richard (2014). Thinking Functionally with Haskell. Cambridge University Press. ISBN 978-1-107-45264-0.
- دورات تعليمية
- Hudak, Paul; Peterson, John; Fasel, Joseph (يونيو 2000). "A Gentle Introduction To Haskell, Version 98". Haskell.org.
- Yet Another Haskell Tutorial, by Hal Daumé III; assumes far less prior knowledge than official tutorial
- Yorgey, Brent (12 مارس 2009). "The Typeclassopedia" (PDF). The Monad.Reader (13): 17–68.
- Maguire, Sandy (2018). Thinking with Types: Type-Level Programming in Haskell.
- تاريخ
- Hudak, Paul; Hughes, John; Peyton Jones, Simon; Wadler, Philip (2007). "A History of Haskell: Being Lazy with Class" (PDF). Proceedings of the Third ACM SIGPLAN Conference on History of Programming Languages (HOPL III): 12–1–55. doi:10.1145/1238844.1238856. ISBN 978-1-59593-766-7. S2CID 52847907.
- Hamilton, Naomi (19 سبتمبر 2008). "The A-Z of Programming Languages: Haskell". Computerworld.
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
وصلات خارجية
- CS1 maint: location
- CS1 errors: archive-url
- CS1 الإنجليزية الأمريكية-language sources (en-us)
- Short description is different from Wikidata
- Use dmy dates from November 2019
- Articles with unsourced statements from February 2012
- Articles with hatnote templates targeting a nonexistent page
- CS1 maint: postscript
- Academic programming languages
- Articles with example Haskell code
- لغات برمجة تعليمية
- لغات وظيفية
- Haskell programming language family
- Literate programming
- Pattern matching programming languages
- Programming languages created in 1990
- Statically typed programming languages