کامپایلر گلاسکو هسکل
نویسنده(های) اصلی | Kevin Hammond |
---|---|
توسعهدهنده(ها) | The Glasgow Haskell Team[۱] |
انتشار اولیه | دسامبر ۱۹۹۲[۲] |
انتشار پایدار | 8.10.2
/ ۸ اوت ۲۰۲۰[۳] |
مخزن | |
نوشتهشده با | هسکل و سی |
سیستمعامل | لینوکس، مکاواس و بعدا، آیاواس، ویندوز ۲۰۰۰ و بعدا، فریبیاسدی، سولاریس و بعدا |
پلتفرم | اکس۸۶, X86-64, معماری آرم |
در دسترس به | انگلیسی |
نوع | کامپایلر |
مجوز | پروانههای بیاسدی |
وبگاه |
کامپایلر گلاسکو هسکل (GHC) یک کامپایلر کد منبع باز برای زبان برنامهنویسی کاربردی هسکل است.[۴] این یک محیط بین پلتفرمی برای نوشتن و آزمایش کد Haskell فراهم میکند و از پسوندها، کتابخانهها و بهینهسازیهای متعددی که روند تولید و اجرای کد را ساده میکند پشتیبانی میکند. GHC متداولترین کامپایلر Haskell است.[۵] توسعه دهندگان اصلی Simon Peyton Jones و Simon Marlow هستند.
تاریخچه
[ویرایش]GHC در اصل در سال ۱۹۸۹ به عنوان نمونه اولیه، که توسط کوین هاموند در دانشگاه گلاسگو به زبان (LML (Lazy ML نوشته شدهاست، شروع به کار کرد. در اواخر همان سال، نمونه اولیه بهطور کامل--به جز تجزیه کننده آن--توسط کوردلیا هال، ویل پارتین و سیمون پیتون جونز در Haskell بازنویسی شد. اولین نسخه آزمایشی آن در تاریخ ۱ آوریل ۱۹۹۱ بود و نسخههای بعدی یک تجزیه و تحلیل سختگیری و همچنین برنامههای افزودنی زبانی مانند ورودی و خروجی monadic، آرایههای قابل تغییر، انواع دادههای واضح و مشخص، مدلهای برنامهنویسی همزمان و موازی (مانند حافظه معاملاتی نرمافزار و موازی سازی دادهها) و یک پروفایل را به آن اضافه کردند.
پیتون جونز و همچنین مارلو بعداً به مایکروسافت در کمبریج انگلستان نقل مکان کردند و در آنجا همچنان مسئول اصلی تولید GHC بودند. GHC همچنین حاوی کدی از بیش از سیصد نفر دیگر از مشارکت کنندگان است.[۱] از سال ۲۰۰۹، کمکهای شخص ثالث به GHC توسط گروه صنعتی هاسکل تأمین میشود.[۶]
معماری
[ویرایش]GHC خود به زبان Haskell نوشته شدهاست،[۷] اما سیستم زمان اجرا برای Haskell که برای اجرای برنامهها ضروری است، با C و C++نوشته شدهاست.
ظاهرGHC -incorporating lexer، تجزیه کننده و typechecker طراحی شدهاست تا حد ممکن اطلاعات زیادی در مورد زبان مبدأ را تا بعد کامل شدن استنتاج نوع حفظ کند، تا به هدف ارائه پیامهای خطا روشن به کاربران دست یابد. پس از بررسی نوع، کد Haskell به یک زبان typed نمایش میانیمعروف به "Core" (براساس سیستم F، با عبارت let
و case
) تقلیل داده میشود. اخیراً Core برای پشتیبانی از انواع دادههای جبری تعمیم یافته در سیستم نوع خود توسعه یافتهاست و اکنون براساس پسوند سیستم F معروف به System F C است.
در سنت کامپایل کردن بر حسب نوع، سادهساز GHC یا "انتهای میانی"، که بیشتر بهینهسازیهای پیادهسازی شده در GHC آنجا انجام میشود، به عنوان یک سری از تبدیلات منبع به منبع در کد هسته تشکیل شدهاست. تجزیه و تحلیل و تحولات انجام شده در این مرحله کامپایلر شامل تجزیه و تحلیل تقاضا (کلی سازی تجزیه و تحلیل سختگیری)، استفاده از قوانین بازنویسی تعریف شده توسط کاربر (شامل مجموعه ای از قوانین موجود در کتابخانههای استاندارد GHC که ترکیب فولدر / ساخت را انجام میدهد)، باز کردن (موسوم به " inlining "در کامپایلرهای سنتی تر)، let-floating، تحلیلی که تعیین میکند کدام استدلالهای عملکرد را میتوان واضح ساخت، تجزیه و تحلیل نتیجه محصول ساخته شده، تخصصی کردن توابع overloaded، و همچنین مجموعه ای از تحولات محلی سادهتر مانند ثابت مقدار دادن و کاهش بتا.
ابک اند کامپایلر از طریق یک زبان میانی STG (یعنی "Spineless Tagless G-machine") کد هسته را به نمایش داخلی C++ تبدیل میکند.[۸] سپس کد C++ میتواند یکی از سه مسیر را طی کند: یا به عنوان کد C برای تدوین با GCC چاپ میشود، مستقیماً به کد ماشین اصلی (مرحله سنتی " تولید کد ") تبدیل میشود، یا با LLVM برای تدوین به کد ماشین مجازی LLVM تبدیل میشود. در هر سه حالت، کد زبان اصلی حاصل در نهایت با سیستم زمان اجرا GHC پیوند داده میشود تا یک سیستم اجرایی تولید کند.
زبان
[ویرایش]GHC با استانداردهای زبان، هم Haskell 98[۹] و هم Haskell 2010 مطابقت دارد.[۱۰] این برنامه همچنین از بسیاری از برنامههای افزودنی اختیاری با استاندارد Haskell پشتیبانی میکند: برای مثال، کتابخانه حافظه تراکنش نرمافزاری (STM)، که امکان انجام معاملات حافظه ترکیبی را فراهم میکند.
برنامههای افزودنی به Haskell
[ویرایش]تعدادی از الحاقات به هاسکل پیشنهاد شدهاست. این پسوندها ویژگیهایی را ارائه میدهند که در مشخصات زبان توصیف نشدهاند، یا ساختارهای موجود را دوباره تعریف میکنند. به همین ترتیب، هر برنامه افزودنی ممکن است توسط همه پیادهسازیهای Haskell پشتیبانی نشود.[۱۱] تلاش مستمر برای توصیف برنامهٔ افزودنی و انتخاب مواردی که در نسخههای بعدی مشخصات زبان گنجانده شود در حال انجام است.
پسوندهای[۱۲] پشتیبانی شده توسط Glasgow Haskell Compiler شامل موارد زیر است:
- انواع و عملیات مشخص: اینها نوع دادههای ابتدایی سختافزارهای زیربنایی را نشان میدهند، بدون اینکه یک اشاره گر به پشته یا احتمال ارزیابی به تعویق انداخته شود. کدهای عددی پیچیده با استفاده از این نوع کد میتواند بهطور قابل توجهی سریعتر باشد.
- توانایی تعیین دقیق ارزیابی برای یک مقدار، الگوی الزامآور یا نوع داده.
- نحو راحت تر برای کار با ماژولها، الگوها، لیستها، اپراتورها، سوابق و tuples.
- سینتکس آسان برای محاسبه با فلش و تعریف ارزشهای یکه تعریف شده به صورت بازگشتی. هر دوی این مفاهیم مفهوم do قدیمی در Haskell استاندارد ارائه شده گسترش میدهند.
- یک سیستم کاملاً قدرتمندتر از انواع و کلاسهای تایپ، که در زیر شرح داده شدهاست.
- ث
جستارهای وابسته
[ویرایش]منابع
[ویرایش]- ↑ ۱٫۰ ۱٫۱ "The GHC Team". Haskell.org. Retrieved 1 September 2016.
- ↑ خطای یادکرد: خطای یادکرد:برچسب
<ref>
غیرمجاز؛ متنی برای یادکردهای با نامhistory
وارد نشده است. (صفحهٔ راهنما را مطالعه کنید.). - ↑ "The Glasgow Haskell Compiler". Haskell.org. 6 September 2020. Retrieved 6 September 2020.
- ↑ "The Glorious Glasgow Haskell Compilation System User's Guide". Haskell.org. Retrieved 27 July 2014.
- ↑ "2017 state of Haskell survey results". taylor.fausak.me. 15 November 2017. Retrieved 11 December 2017.
- ↑ "Industrial Haskell Group". Haskell.org. 2014. Retrieved 1 September 2016.
- ↑ "GHC Commentary: The Compiler". Haskell.org. 23 March 2016. Archived from the original on 23 March 2016. Retrieved 26 May 2016.
- ↑ Peyton Jones, S. (April 1992). "Implementing lazy functional languages on stock hardware: the Spineless Tagless G-machine, Version 2.5". Journal of Functional Programming. 2 (2): 127–202. doi:10.1017/S0956796800000319.
- ↑ "Haskell 98 Language and Libraries: The Revised Report". Haskell.org. Retrieved 28 January 2007.
- ↑ "Haskell 2010 Language Report". Haskell.org. Retrieved 30 August 2012.
- ↑ "Welcome to Haskell' (Haskell Prime)". Haskell.org. Archived from the original on 20 February 2016. Retrieved 26 May 2016.
- ↑ "GHC Language Features". Haskell.org. Archived from the original on 29 June 2016. Retrieved 25 May 2016.