| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 | 
							- --
 
- -- Built with,
 
- --
 
- --        ,gggg,
 
- --       d8" "8I                         ,dPYb,
 
- --       88  ,dP                         IP'`Yb
 
- --    8888888P"                          I8  8I
 
- --       88                              I8  8'
 
- --       88        gg      gg    ,g,     I8 dPgg,
 
- --  ,aa,_88        I8      8I   ,8'8,    I8dP" "8I
 
- -- dP" "88P        I8,    ,8I  ,8'  Yb   I8P    I8
 
- -- Yb,_,d88b,,_   ,d8b,  ,d8b,,8'_   8) ,d8     I8,
 
- --  "Y8P"  "Y888888P'"Y88P"`Y8P' "YY8P8P88P     `Y8
 
- --
 
- -- This is a starter colorscheme for use with Lush,
 
- -- for usage guides, see :h lush or :LushRunTutorial
 
- --
 
- -- Note: Because this is lua file, vim will append your file to the runtime,
 
- --       which means you can require(...) it in other lua code (this is useful),
 
- --       but you should also take care not to conflict with other libraries.
 
- --
 
- --       (This is a lua quirk, as it has somewhat poor support for namespacing.)
 
- --
 
- --       Basically, name your file,
 
- --
 
- --       "super_theme/lua/lush_theme/super_theme_dark.lua",
 
- --
 
- --       not,
 
- --
 
- --       "super_theme/lua/dark.lua".
 
- --
 
- --       With that caveat out of the way...
 
- --
 
- -- Enable lush.ify on this file, run:
 
- --
 
- --  `:Lushify`
 
- --
 
- --  or
 
- --
 
- --  `:lua require('lush').ify()`
 
- local lush = require('lush')
 
- local hsl = lush.hsl
 
- local theme = lush(function()
 
-   return {
 
-     -- The following are all the Neovim default highlight groups from the docs
 
-     -- as of 0.5.0-nightly-446, to aid your theme creation. Your themes should
 
-     -- probably style all of these at a bare minimum.
 
-     --
 
-     -- Referenced/linked groups must come before being referenced/lined,
 
-     -- so the order shown ((mostly) alphabetical) is likely
 
-     -- not the order you will end up with.
 
-     --
 
-     -- You can uncomment these and leave them empty to disable any
 
-     -- styling for that group (meaning they mostly get styled as Normal)
 
-     -- or leave them commented to apply vims default colouring or linking.
 
-     -- Comment      { }, -- any comment
 
-     -- ColorColumn  { }, -- used for the columns set with 'colorcolumn'
 
-     -- Conceal      { }, -- placeholder characters substituted for concealed text (see 'conceallevel')
 
-     -- Cursor       { }, -- character under the cursor
 
-     -- lCursor      { }, -- the character under the cursor when |language-mapping| is used (see 'guicursor')
 
-     -- CursorIM     { }, -- like Cursor, but used when in IME mode |CursorIM|
 
-     -- CursorColumn { }, -- Screen-column at the cursor, when 'cursorcolumn' is set.
 
-     -- CursorLine   { }, -- Screen-line at the cursor, when 'cursorline' is set.  Low-priority if foreground (ctermfg OR guifg) is not set.
 
-     -- Directory    { }, -- directory names (and other special names in listings)
 
-     -- DiffAdd      { }, -- diff mode: Added line |diff.txt|
 
-     -- DiffChange   { }, -- diff mode: Changed line |diff.txt|
 
-     -- DiffDelete   { }, -- diff mode: Deleted line |diff.txt|
 
-     -- DiffText     { }, -- diff mode: Changed text within a changed line |diff.txt|
 
-     -- EndOfBuffer  { }, -- filler lines (~) after the end of the buffer.  By default, this is highlighted like |hl-NonText|.
 
-     -- TermCursor   { }, -- cursor in a focused terminal
 
-     -- TermCursorNC { }, -- cursor in an unfocused terminal
 
-     -- ErrorMsg     { }, -- error messages on the command line
 
-     -- VertSplit    { }, -- the column separating vertically split windows
 
-     -- Folded       { }, -- line used for closed folds
 
-     -- FoldColumn   { }, -- 'foldcolumn'
 
-     -- SignColumn   { }, -- column where |signs| are displayed
 
-     -- IncSearch    { }, -- 'incsearch' highlighting; also used for the text replaced with ":s///c"
 
-     -- Substitute   { }, -- |:substitute| replacement text highlighting
 
-     -- LineNr       { }, -- Line number for ":number" and ":#" commands, and when 'number' or 'relativenumber' option is set.
 
-     -- CursorLineNr { }, -- Like LineNr when 'cursorline' or 'relativenumber' is set for the cursor line.
 
-     -- MatchParen   { }, -- The character under the cursor or just before it, if it is a paired bracket, and its match. |pi_paren.txt|
 
-     -- ModeMsg      { }, -- 'showmode' message (e.g., "-- INSERT -- ")
 
-     -- MsgArea      { }, -- Area for messages and cmdline
 
-     -- MsgSeparator { }, -- Separator for scrolled messages, `msgsep` flag of 'display'
 
-     -- MoreMsg      { }, -- |more-prompt|
 
-     -- NonText      { }, -- '@' at the end of the window, characters from 'showbreak' and other characters that do not really exist in the text (e.g., ">" displayed when a double-wide character doesn't fit at the end of the line). See also |hl-EndOfBuffer|.
 
-     -- Normal       { }, -- normal text
 
-     -- NormalFloat  { }, -- Normal text in floating windows.
 
-     -- NormalNC     { }, -- normal text in non-current windows
 
-     -- Pmenu        { }, -- Popup menu: normal item.
 
-     -- PmenuSel     { }, -- Popup menu: selected item.
 
-     -- PmenuSbar    { }, -- Popup menu: scrollbar.
 
-     -- PmenuThumb   { }, -- Popup menu: Thumb of the scrollbar.
 
-     -- Question     { }, -- |hit-enter| prompt and yes/no questions
 
-     -- QuickFixLine { }, -- Current |quickfix| item in the quickfix window. Combined with |hl-CursorLine| when the cursor is there.
 
-     -- Search       { }, -- Last search pattern highlighting (see 'hlsearch').  Also used for similar items that need to stand out.
 
-     -- SpecialKey   { }, -- Unprintable characters: text displayed differently from what it really is.  But not 'listchars' whitespace. |hl-Whitespace|
 
-     -- SpellBad     { }, -- Word that is not recognized by the spellchecker. |spell| Combined with the highlighting used otherwise. 
 
-     -- SpellCap     { }, -- Word that should start with a capital. |spell| Combined with the highlighting used otherwise.
 
-     -- SpellLocal   { }, -- Word that is recognized by the spellchecker as one that is used in another region. |spell| Combined with the highlighting used otherwise.
 
-     -- SpellRare    { }, -- Word that is recognized by the spellchecker as one that is hardly ever used.  |spell| Combined with the highlighting used otherwise.
 
-     -- StatusLine   { }, -- status line of current window
 
-     -- StatusLineNC { }, -- status lines of not-current windows Note: if this is equal to "StatusLine" Vim will use "^^^" in the status line of the current window.
 
-     -- TabLine      { }, -- tab pages line, not active tab page label
 
-     -- TabLineFill  { }, -- tab pages line, where there are no labels
 
-     -- TabLineSel   { }, -- tab pages line, active tab page label
 
-     -- Title        { }, -- titles for output from ":set all", ":autocmd" etc.
 
-     -- Visual       { }, -- Visual mode selection
 
-     -- VisualNOS    { }, -- Visual mode selection when vim is "Not Owning the Selection".
 
-     -- WarningMsg   { }, -- warning messages
 
-     -- Whitespace   { }, -- "nbsp", "space", "tab" and "trail" in 'listchars'
 
-     -- WildMenu     { }, -- current match in 'wildmenu' completion
 
-     -- These groups are not listed as default vim groups,
 
-     -- but they are defacto standard group names for syntax highlighting.
 
-     -- commented out groups should chain up to their "preferred" group by
 
-     -- default,
 
-     -- Uncomment and edit if you want more specific syntax highlighting.
 
-     -- Constant       { }, -- (preferred) any constant
 
-     -- String         { }, --   a string constant: "this is a string"
 
-     -- Character      { }, --  a character constant: 'c', '\n'
 
-     -- Number         { }, --   a number constant: 234, 0xff
 
-     -- Boolean        { }, --  a boolean constant: TRUE, false
 
-     -- Float          { }, --    a floating point constant: 2.3e10
 
-     -- Identifier     { }, -- (preferred) any variable name
 
-     -- Function       { }, -- function name (also: methods for classes)
 
-     -- Statement      { }, -- (preferred) any statement
 
-     -- Conditional    { }, --  if, then, else, endif, switch, etc.
 
-     -- Repeat         { }, --   for, do, while, etc.
 
-     -- Label          { }, --    case, default, etc.
 
-     -- Operator       { }, -- "sizeof", "+", "*", etc.
 
-     -- Keyword        { }, --  any other keyword
 
-     -- Exception      { }, --  try, catch, throw
 
-     -- PreProc        { }, -- (preferred) generic Preprocessor
 
-     -- Include        { }, --  preprocessor #include
 
-     -- Define         { }, --   preprocessor #define
 
-     -- Macro          { }, --    same as Define
 
-     -- PreCondit      { }, --  preprocessor #if, #else, #endif, etc.
 
-     -- Type           { }, -- (preferred) int, long, char, etc.
 
-     -- StorageClass   { }, -- static, register, volatile, etc.
 
-     -- Structure      { }, --  struct, union, enum, etc.
 
-     -- Typedef        { }, --  A typedef
 
-     -- Special        { }, -- (preferred) any special symbol
 
-     -- SpecialChar    { }, --  special character in a constant
 
-     -- Tag            { }, --    you can use CTRL-] on this
 
-     -- Delimiter      { }, --  character that needs attention
 
-     -- SpecialComment { }, -- special things inside a comment
 
-     -- Debug          { }, --    debugging statements
 
-     -- Underlined { gui = "underline" }, -- (preferred) text that stands out, HTML links
 
-     -- Bold       { gui = "bold" },
 
-     -- Italic     { gui = "italic" },
 
-     -- ("Ignore", below, may be invisible...)
 
-     -- Ignore         { }, -- (preferred) left blank, hidden  |hl-Ignore|
 
-     -- Error          { }, -- (preferred) any erroneous construct
 
-     -- Todo           { }, -- (preferred) anything that needs extra attention; mostly the keywords TODO FIXME and XXX
 
-     -- These groups are for the native LSP client. Some other LSP clients may
 
-     -- use these groups, or use their own. Consult your LSP client's
 
-     -- documentation.
 
-     -- LspReferenceText                     { }, -- used for highlighting "text" references
 
-     -- LspReferenceRead                     { }, -- used for highlighting "read" references
 
-     -- LspReferenceWrite                    { }, -- used for highlighting "write" references
 
-     -- LspDiagnosticsDefaultError           { }, -- Used as the base highlight group. Other LspDiagnostic highlights link to this by default (except Underline)
 
-     -- LspDiagnosticsDefaultWarning         { }, -- Used as the base highlight group. Other LspDiagnostic highlights link to this by default (except Underline)
 
-     -- LspDiagnosticsDefaultInformation     { }, -- Used as the base highlight group. Other LspDiagnostic highlights link to this by default (except Underline)
 
-     -- LspDiagnosticsDefaultHint            { }, -- Used as the base highlight group. Other LspDiagnostic highlights link to this by default (except Underline)
 
-     -- LspDiagnosticsVirtualTextError       { }, -- Used for "Error" diagnostic virtual text
 
-     -- LspDiagnosticsVirtualTextWarning     { }, -- Used for "Warning" diagnostic virtual text
 
-     -- LspDiagnosticsVirtualTextInformation { }, -- Used for "Information" diagnostic virtual text
 
-     -- LspDiagnosticsVirtualTextHint        { }, -- Used for "Hint" diagnostic virtual text
 
-     -- LspDiagnosticsUnderlineError         { }, -- Used to underline "Error" diagnostics
 
-     -- LspDiagnosticsUnderlineWarning       { }, -- Used to underline "Warning" diagnostics
 
-     -- LspDiagnosticsUnderlineInformation   { }, -- Used to underline "Information" diagnostics
 
-     -- LspDiagnosticsUnderlineHint          { }, -- Used to underline "Hint" diagnostics
 
-     -- LspDiagnosticsFloatingError          { }, -- Used to color "Error" diagnostic messages in diagnostics float
 
-     -- LspDiagnosticsFloatingWarning        { }, -- Used to color "Warning" diagnostic messages in diagnostics float
 
-     -- LspDiagnosticsFloatingInformation    { }, -- Used to color "Information" diagnostic messages in diagnostics float
 
-     -- LspDiagnosticsFloatingHint           { }, -- Used to color "Hint" diagnostic messages in diagnostics float
 
-     -- LspDiagnosticsSignError              { }, -- Used for "Error" signs in sign column
 
-     -- LspDiagnosticsSignWarning            { }, -- Used for "Warning" signs in sign column
 
-     -- LspDiagnosticsSignInformation        { }, -- Used for "Information" signs in sign column
 
-     -- LspDiagnosticsSignHint               { }, -- Used for "Hint" signs in sign column
 
-     -- These groups are for the neovim tree-sitter highlights.
 
-     -- As of writing, tree-sitter support is a WIP, group names may change.
 
-     -- By default, most of these groups link to an appropriate Vim group,
 
-     -- TSError -> Error for example, so you do not have to define these unless
 
-     -- you explicitly want to support Treesitter's improved syntax awareness.
 
-     -- TSAnnotation         { };    -- For C++/Dart attributes, annotations that can be attached to the code to denote some kind of meta information.
 
-     -- TSAttribute          { };    -- (unstable) TODO: docs
 
-     -- TSBoolean            { };    -- For booleans.
 
-     -- TSCharacter          { };    -- For characters.
 
-     -- TSComment            { };    -- For comment blocks.
 
-     -- TSConstructor        { };    -- For constructor calls and definitions: ` { }` in Lua, and Java constructors.
 
-     -- TSConditional        { };    -- For keywords related to conditionnals.
 
-     -- TSConstant           { };    -- For constants
 
-     -- TSConstBuiltin       { };    -- For constant that are built in the language: `nil` in Lua.
 
-     -- TSConstMacro         { };    -- For constants that are defined by macros: `NULL` in C.
 
-     -- TSError              { };    -- For syntax/parser errors.
 
-     -- TSException          { };    -- For exception related keywords.
 
-     -- TSField              { };    -- For fields.
 
-     -- TSFloat              { };    -- For floats.
 
-     -- TSFunction           { };    -- For function (calls and definitions).
 
-     -- TSFuncBuiltin        { };    -- For builtin functions: `table.insert` in Lua.
 
-     -- TSFuncMacro          { };    -- For macro defined fuctions (calls and definitions): each `macro_rules` in Rust.
 
-     -- TSInclude            { };    -- For includes: `#include` in C, `use` or `extern crate` in Rust, or `require` in Lua.
 
-     -- TSKeyword            { };    -- For keywords that don't fall in previous categories.
 
-     -- TSKeywordFunction    { };    -- For keywords used to define a fuction.
 
-     -- TSLabel              { };    -- For labels: `label:` in C and `:label:` in Lua.
 
-     -- TSMethod             { };    -- For method calls and definitions.
 
-     -- TSNamespace          { };    -- For identifiers referring to modules and namespaces.
 
-     -- TSNone               { };    -- TODO: docs
 
-     -- TSNumber             { };    -- For all numbers
 
-     -- TSOperator           { };    -- For any operator: `+`, but also `->` and `*` in C.
 
-     -- TSParameter          { };    -- For parameters of a function.
 
-     -- TSParameterReference { };    -- For references to parameters of a function.
 
-     -- TSProperty           { };    -- Same as `TSField`.
 
-     -- TSPunctDelimiter     { };    -- For delimiters ie: `.`
 
-     -- TSPunctBracket       { };    -- For brackets and parens.
 
-     -- TSPunctSpecial       { };    -- For special punctutation that does not fall in the catagories before.
 
-     -- TSRepeat             { };    -- For keywords related to loops.
 
-     -- TSString             { };    -- For strings.
 
-     -- TSStringRegex        { };    -- For regexes.
 
-     -- TSStringEscape       { };    -- For escape characters within a string.
 
-     -- TSSymbol             { };    -- For identifiers referring to symbols or atoms.
 
-     -- TSType               { };    -- For types.
 
-     -- TSTypeBuiltin        { };    -- For builtin types.
 
-     -- TSVariable           { };    -- Any variable name that does not have another highlight.
 
-     -- TSVariableBuiltin    { };    -- Variable names that are defined by the languages, like `this` or `self`.
 
-     -- TSTag                { };    -- Tags like html tag names.
 
-     -- TSTagDelimiter       { };    -- Tag delimiter like `<` `>` `/`
 
-     -- TSText               { };    -- For strings considered text in a markup language.
 
-     -- TSEmphasis           { };    -- For text to be represented with emphasis.
 
-     -- TSUnderline          { };    -- For text to be represented with an underline.
 
-     -- TSStrike             { };    -- For strikethrough text.
 
-     -- TSTitle              { };    -- Text that is part of a title.
 
-     -- TSLiteral            { };    -- Literal text.
 
-     -- TSURI                { };    -- Any URI like a link or email.
 
-   }
 
- end)
 
- -- return our parsed theme for extension or use else where.
 
- return theme
 
- -- vi:nowrap
 
 
  |