| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 | /*Language: HaskellAuthor: Jeremy Hull <sourdrums@gmail.com>Contributors: Zena Treep <zena.treep@gmail.com>Website: https://www.haskell.orgCategory: functional*/function haskell(hljs) {  const COMMENT = {    variants: [      hljs.COMMENT('--', '$'),      hljs.COMMENT(        /\{-/,        /-\}/,        {          contains: ['self']        }      )    ]  };  const PRAGMA = {    className: 'meta',    begin: /\{-#/,    end: /#-\}/  };  const PREPROCESSOR = {    className: 'meta',    begin: '^#',    end: '$'  };  const CONSTRUCTOR = {    className: 'type',    begin: '\\b[A-Z][\\w\']*', // TODO: other constructors (build-in, infix).    relevance: 0  };  const LIST = {    begin: '\\(',    end: '\\)',    illegal: '"',    contains: [      PRAGMA,      PREPROCESSOR,      {        className: 'type',        begin: '\\b[A-Z][\\w]*(\\((\\.\\.|,|\\w+)\\))?'      },      hljs.inherit(hljs.TITLE_MODE, {        begin: '[_a-z][\\w\']*'      }),      COMMENT    ]  };  const RECORD = {    begin: /\{/,    end: /\}/,    contains: LIST.contains  };  return {    name: 'Haskell',    aliases: ['hs'],    keywords:      'let in if then else case of where do module import hiding ' +      'qualified type data newtype deriving class instance as default ' +      'infix infixl infixr foreign export ccall stdcall cplusplus ' +      'jvm dotnet safe unsafe family forall mdo proc rec',    contains: [      // Top-level constructions.      {        beginKeywords: 'module',        end: 'where',        keywords: 'module where',        contains: [          LIST,          COMMENT        ],        illegal: '\\W\\.|;'      },      {        begin: '\\bimport\\b',        end: '$',        keywords: 'import qualified as hiding',        contains: [          LIST,          COMMENT        ],        illegal: '\\W\\.|;'      },      {        className: 'class',        begin: '^(\\s*)?(class|instance)\\b',        end: 'where',        keywords: 'class family instance where',        contains: [          CONSTRUCTOR,          LIST,          COMMENT        ]      },      {        className: 'class',        begin: '\\b(data|(new)?type)\\b',        end: '$',        keywords: 'data family type newtype deriving',        contains: [          PRAGMA,          CONSTRUCTOR,          LIST,          RECORD,          COMMENT        ]      },      {        beginKeywords: 'default',        end: '$',        contains: [          CONSTRUCTOR,          LIST,          COMMENT        ]      },      {        beginKeywords: 'infix infixl infixr',        end: '$',        contains: [          hljs.C_NUMBER_MODE,          COMMENT        ]      },      {        begin: '\\bforeign\\b',        end: '$',        keywords: 'foreign import export ccall stdcall cplusplus jvm ' +                  'dotnet safe unsafe',        contains: [          CONSTRUCTOR,          hljs.QUOTE_STRING_MODE,          COMMENT        ]      },      {        className: 'meta',        begin: '#!\\/usr\\/bin\\/env\ runhaskell',        end: '$'      },      // "Whitespaces".      PRAGMA,      PREPROCESSOR,      // Literals and names.      // TODO: characters.      hljs.QUOTE_STRING_MODE,      hljs.C_NUMBER_MODE,      CONSTRUCTOR,      hljs.inherit(hljs.TITLE_MODE, {        begin: '^[_a-z][\\w\']*'      }),      COMMENT,      { // No markup, relevance booster        begin: '->|<-'      }    ]  };}module.exports = haskell;
 |