هاسكلهاسكل
هاسكل [6][7] هي لغة برمجة مطابقة للمعايير، للأغراض العامة، وهي لغة وظيفية إلى حد كبير، دون دلالات ألفاظ ملزمة وبكتابة ثابتة وقوية.[8] وقد سُميت بـ هاسكل علي اسم عالم المنطق «هاسكل كوري». وفي اللغة هاسكل، «تمثل الوظيفة مواطن من الدرجة الأولى» من لغة البرمجة.[9] ولكونها لغة برمجة وظيفية فإن بنية التحكم الرئيسية هي الوظيفة. وترجع أصول اللغة إلى ملاحظات هاسكل كوري وأتباعه من المفكرين، بأن «الإثبات هو برنامج؛ والمعادلة التي يثبتها هي نوع للبرنامج».[10][11][12][13] تاريخ اللغةعقب إصدار لغة البرمجة ميريندا في عام 1985 بواسطة شركة برمجيات البحوث المحدودة (Research Software Ltd، زاد الاهتمام بلغات البرمجة الوظيفية الكسولة: بحلول عام 1987 زاد عدد لغات البرمجة الوظيفية الصرفة بشكل كبير. من بين هذه اللغات كانت ميراندا الأكثر استخداماً ولكنها لم تكن خاضعة للملكية العامة. لذلك في مؤتمر اللغات البرمجية الوظيفية وعمارة الحاسوب (FPCA 87) والذي تم عقده في بورتلاند اوريجون، تم عقد اجتماع أعرب فيه المشاركون بالإجماع على ضرورة تشكيل لجنة لتعمل على تحديد معايير مفتوحة لهذه اللغات. وكانت اللجنة تهدف إلى دمج اللغات الوظيفية الموجودة في ذلك الوقت في لغة واحدة عامة لتكون أساس للأبحاث المستقبلية في تصميمات اللغات الوظيفية.[14] هاسكل 1.0ظهر الإصدار الأول من هاسكل («هاسكل 1.0») في عام 1990.[15] ونتج عن مجهودات اللجنة مجموعة من التعريفات اللغوية. هاسكل 98في أواخر عام 1997، توجت سلسلة هاسكل بـ هاسكل98، وكان يهدف الي تحديد إصدار ثابت، وبسيط، ومحمول ومزود بمكتبة قياسية للتدريس، وليكون قاعدة للتوسعات المستقبلية. وقد رحبت اللجنة بإنشاء الإضافات والبدائل لهاسكل 98 عن طريق إضافة ودمج الخصائص التجريبية.[14] في فبراير من عام 1999 أعلنت النسخة القياسية من لغة هاسكل 98 في أول الأمر تحت اسم «تقرير هاسكل 98»[14]«The Haskell 98 Report. وفي يناير من عام 2003 تم إصدار نسخة مُعدلة تحت اسم» هاسكل98 لغة ومكتبات: التقرير المُعدَل""Haskell 98 Language and Libraries: The Revised Report.[16] وواصلت لغة هاسكل تطورها بشكل سريع، وذلك مع تنفيذ المترجم غلاسكو هاسكل (GHC) الذي يعتبر القياسي حاليا. هاسكل برايمفي مطلع عام 2006 بدأت عملية إنشاء نسخة تخلُف الإصدار «هاسكل98 الأساسي» الدارج باسم «هاسكل» وأطلق على هذه النسخة اسم («هاسكل برايم»).[17] وهي تعتبر عملية متطورة ومستمرة لتعديل تعريفات اللغة وذلك لإنتاج نسخة معدلة جديدة سنوياً. وتم الإعلان عن أول نسخة مُعدلة في نوفمبر من عام 2009 وسميت بـ «هاسكل 2010».[18] هاسكل 2010تضيف هاسكل 2010 الواجهة البينية الوظيفية الخارجية (FFI) إلى لغة هاسكل، مما يسمح بربطها بلغات برمجة أخرى، وتثبيت بعض القواعد اللغوية (تغييرات في القواعد الشكلية)، وحظر ما يسمى بنماذج " n-plus-k"، أي تعريفات للصيغة " fak (n+1) = (n+1) * fak n " لم تعد مسموحة. ويقدم هذا الإصدار إمكانية تمديد الجمل في اللغة والتي تسمح بتعيين مصدر لهاسكل مثل هاسكل2010 أو تتطلب امتدادات محددة للغة هاسكل. وأسماء الامتدادات المقدمة في هاسكل2010 هي:[18] DoAndIfThenElse، HierarchicalModules، EmptyDataDeclarations، FixityResolution، ForeignFunctionInterface، LineCommentSyntax، PatternGuards، RelaxDependencyAnalysis، LanguagePragma، NoNPlusKPatterns الخصائصخصائص لغة الهاسكل هي التقييم الكسول، تطابق النماذج، قائمة الإدراك، فئات الكتابة وتعدد أشكالها. وهي لغة وظيفية صرف، والتي تعني بشكل عام، أن الوظائف في هاسكل ليس لها آثار جانبية. وهناك نوع مميز يمثل الآثار الجانبية وهو متعامد مع نوع الوظائف. حيث يمكن أن تنتج وظيفة صِرفة ما أثر جانبي يمكن أن ينفذ لاحقا، ويعد نماذج لوظائف غير صرفية للغات الأخرى. تتمتع هاسكل بنظام كتابة ثابت وقوي يقوم على واجهة كتابة هيندلي-ميلنر. والابتكار الرئيسي للغة هاسكل في هذا النطاق هو إضافة فئات الكتابة، والتي كانت معروفة في الأساس كطريقة رئيسية لإضافة حِمل زائدة إلى اللغة،[19] ولكن وُجد لها استخدامات أخرى كثيرة فيما بعد.[20] وتعتبر موناد مثالاً للكتابات التي لها آثار جانبية، كما تمثل كتابات موناد إطار عام يمكنه صياغة عمليات حسابية متنوعة، بما في ذلك معالجة الأخطاء، تنوع المُدخلات، التحليل اللغوي، وذاكرة عمليات البرمجيات. وتعرف كتابات موناد بأنها أنواع عادية من البيانات، بينما تقدم هاسكل بعض التبسيطات اللغوية لتسهيل استخدامها. كما أنها لغة ذات خصائص معلنة مفتوحة[16] وتطبيقات متعددة. ويحيط بهذه اللغة مجتمع فاعل، وأكثر من 3000 مكتبة مفتوحة المصدر وأدوات متاحة في مستودع حزمة الانترنت هاكاج Hackage.[21] ويعتبر مترجم جلاسجو GHC هو التطبيق الرئيسي للغة هاسكل، وهو مترجم ومفسر للشفرة الأم ويعمل علي معظم المنصات. كما يتسم بأداء عالية في تنفيذ التطبيقات المتزامنة والمتوازية،[22] ويتميز كذلك بوجود نظام كتابة غني يضم الابتكارات الحديثة مثل كتابات البيانات الجبرية العامة وعائلات الكتابة Type Families. أمثلة للأكوادالبرنامج التالي هو «هاللو ورلد» وهو مكتوب بلغة هاسكل (لاحظ أنه يمكن حذف جميع الخطوط ماعدا الخط الأخير). module Main where
main :: IO ()
main = putStrLn "Hello, World!"
هاهو العاملي الرياضي مشروحا بستة طرق مختلفة: -- type
factorial :: Integer -> Integer
-- using recursion
factorial 0 = 1
factorial n = n * factorial (n - 1)
-- using lists
factorial n = product [1..n]
-- using recursion but written without pattern matching
factorial n = if n> 0 then n * factorial (n-1) else 1
-- using fold
factorial n = foldl (*) 1 [1..n]
-- using only prefix notation and n+k-patterns (no longer allowed in Haskell 2010)
factorial 0 = 1
factorial (n+1) = (*) (n+1) (factorial n)
-- Point-free style
factorial = foldr (*) 1. enumFromTo 1
وهذا تطبيق فعال لأرقام فيبوتاتشي، كقائمة لا نهائية: -- Point-free style
fib :: Int -> Integer
fib = (fibs !!)
where fibs = 0 : scanl (+) 1 fibs
-- Explicit
fib :: Int -> Integer
fib n = fibs !! n
where fibs = 0 : scanl (+) 1 fibs
-- with a similar idea, using zipWith
fib :: Int -> Integer
fib n = fibs !! n
where fibs = 0 : 1 : zipWith (+) fibs (tail fibs)
-- Using an extra parameter
fib :: Int -> Integer
fib n = (fibs 0 1) !! n
where fibs a b = a : fibs b (a+b)
تشير الكتابة "Int" إلى عدد صحيح (machine-sized) (تستخدم كقائمة رموز سفلية مع المُعامل !!)، بينما «عدد صحيح» هو عدد صحيح ذو دقة تامة. وعلى سبيل المثال، فالكود الموجود بالأعلي يحسب سريعا "fib10000" كعدد من 2090-رقم. التطبيقاتتلتزم كافة التطبيقات التالية أو «معظمها تقريبا» لمعايير هاسكل 98، ويتم توزيعها برخص مصدر مفتوح. وحاليا لاتوجد ملكية لتطبيقات هاسكل.
تطبيقاتيتزايد استخدام هاسكل في الاستخدامات التجارية.[23] قامت المُبرمجة أودري تانج بعمل تطبيق من أجل بيرل 6 المنتظر طويلا يسمى Pugsوهو عبارة عن مترجم ومفسر أثبت أهميته بعد أشهر قليلة فقط من كتابته؛ وبالمثل المترجم جلاسجو الذي دائما ما يستخدم كمُختبِر لخصائص وتحسينات البرمجة الوظيفية المتقدمة. داركس Darcs هو نظام مراجعة وتحكم تمت كتابته بلغة هاسكل، ويتميز بخصائص مبتكرة عديدة. كما اختارت لينسبير جنو/ لينكس Linspire GNU/Linux هاسكل لتطوير أدوات النظام.[24] وكذلك إكس موناد (بالإنجليزية: Xmonad) وهو نظام إدارة النوافذ لنظام النوافذ إكس، مكتوب بلغة هاسكل بالكامل. نظام بلوسبك فيرلوج عبارة عن لغة لتصميم شبه موصل وهي امتداد للغة هاسكل. كما ان أداوت شركة بلوسبك تم تطبيقها في لغة هاسكل. كريبتول Cryptol هي عبارة عن لغة وسلسلة من الأدوات المستخدمة لتطوير وتدقيق الأكواد الحسابية، ويتم تطبيقه في لغة هاسكل. والنوية (microkernel) أول موثق رسميا وسيل4 الذي تم تدقيقه باستخدام هاسكل. اللغات المتعلقة بهاسكللغة التنظيف المتزامن "Concurrent Clean" وهي مرتبطة للغاية بلغة هاسكل. ومن أكبر انحرافاتها عن لغة هاسكل نجده في استخدامها للكتابات المتفردة بدلا من كتابات موناد من أجل I/O وكذلك الآثار الجانبية. هناك مجموعة من اللغات التي استوحت من اللغة هاسكل، ولكن بنظم كتابة مختلفة، والتي تم تطوريها ومنها:
كما توجد لغات اخري متعلقة بهاسكل:
واستخدمت هاسكل كاختبار للعديد من الأفكار الجديدة في تصميمات اللغة. وهناك عدد كبير من المنتجات المتنوعة لهاسكل والتي تستكشف الأفكار الجديدة للغة وتشمل:
النقدفي عامي 2002 و2003 ناقش كلاً من جان ويليام مايسن وسيمون بيتون جونز المشكلات المرتبطة بالتقييم الكسول مع إقرار الدافع النظري له،[30][31] بالإضافة إلى اعتبارات الممارسة الصرفية مثل الأداء المُحسن.[32] كما لاحظوا انه عند إضافة بعض التحسينات لرفع الأداء، فإن الكسل يزيد الأمر صعوبة علي المبرمجين لتقييم أداء أكوادهم (وخاصة استخدام مساحاتها). في عام 2003 لاحظ كل من: باستيات هيران ودان ليين وأريان فان إيزيندورن وجود بعض العوائق أمام دارسي لغة هاسكل، فقد لوحظ أن نظام الكتابة المعقد والقواعد اللغوية الدقيقة لهاسكل هي سلاح ذو حدين، فهو محل تقدير كبير من قِبل المبرمجين ذوي الخبرة بينما هو مصدر إحباط للمبتدئين، نظرا لأن عمومية تطبيقات هاسكل تؤدي إلى رسائل خطأ مُبهمة.[33] ولمعالجة تلك المسائل، قام باحثون من جامعة اُوتريخت بتطوير مترجم متقدم يسمي هيليوم والذي يقوم بتحسين استقبال المستخدمين لرسائل الخطأ عن طريق الحد من عمومية بعض خصائص هاسكل، وبالتحديد إزالة دعمها لفئات الكتابة. قام بِن ليبميير بتصميم التابع[34] كقيمة فرضية دقيقة (تطبيق كسول من خلال ملحقات واضحة) وهو من لهجات هاسكل التي تدعم نظام الكتابة والتأثير، وقد صُمم لمعالجة صعوبات هاسكل في التفكير بشأن التقييم الكسول وفي استخدام بنيات البيانات التقليدية مثل المصفوفات المتغيرة.[35] لقد حاول ليبميير (ص: 20) أن يبرهن علي أن «التحديث المُدمر يُزود المبرمجين بإثنتين من الأدوات الهامة والقوية... الأولى هي مجموعة بنيات البيانات الفعالة مثل المصفوفات من أجل إدارة مجموعة من الكائنات... والثانية هي إمكانية بث قيمة جديدة لجميع أجزاء برنامج ما مع أدني عبء علي المبرمج.» المؤتمرات وورش العمليتقابل مجتمع هاسكل بصورة منتظمة وذلك لأنشطة البحث والتطوير. والأحداث الرئيسية هي:
ومنذ عام 2006 أصبح هناك سلسلة من الإجراءات المنظمة، سلسلة Hac، والتي تهدف إلى تحسين أدوات ومكتبات لغات البرمجة وذلك مثل:
ومنذ عام 2005، تشكلت أعداد متزايدة من مجموعات مستخدمي هاسكل، في كل من الولايات المتحدة وكندا وأستراليا وأمريكا الجنوبية وأوروبا وآسيا. انظر أيضاالمراجع
وصلات خارجية |