" Vim color file " Maintainer: Ian Langworth " Last Change: 2004 Dec 24 " Email: " Color settings inspired by BBEdit for Mac OS, plus I liked " the low-contrast comments from the 'oceandeep' colorscheme " " gryf: Nice colorscheme for printing in white, or to generate html in dark on " bright. Added functions for converting it into terminal 256xterm codes. set background=light hi clear if exists("syntax_on") syntax reset endif if !has("gui_running") && &t_Co != 88 && &t_Co != 256 finish endif let g:colors_name="tolerable" " functions {{{ " returns an approximate grey index for the given grey level fun! grey_number(x) if &t_Co == 88 if a:x < 23 return 0 elseif a:x < 69 return 1 elseif a:x < 103 return 2 elseif a:x < 127 return 3 elseif a:x < 150 return 4 elseif a:x < 173 return 5 elseif a:x < 196 return 6 elseif a:x < 219 return 7 elseif a:x < 243 return 8 else return 9 endif else if a:x < 14 return 0 else let l:n = (a:x - 8) / 10 let l:m = (a:x - 8) % 10 if l:m < 5 return l:n else return l:n + 1 endif endif endif endfun " returns the actual grey level represented by the grey index fun! grey_level(n) if &t_Co == 88 if a:n == 0 return 0 elseif a:n == 1 return 46 elseif a:n == 2 return 92 elseif a:n == 3 return 115 elseif a:n == 4 return 139 elseif a:n == 5 return 162 elseif a:n == 6 return 185 elseif a:n == 7 return 208 elseif a:n == 8 return 231 else return 255 endif else if a:n == 0 return 0 else return 8 + (a:n * 10) endif endif endfun " returns the palette index for the given grey index fun! grey_color(n) if &t_Co == 88 if a:n == 0 return 16 elseif a:n == 9 return 79 else return 79 + a:n endif else if a:n == 0 return 16 elseif a:n == 25 return 231 else return 231 + a:n endif endif endfun " returns an approximate color index for the given color level fun! rgb_number(x) if &t_Co == 88 if a:x < 69 return 0 elseif a:x < 172 return 1 elseif a:x < 230 return 2 else return 3 endif else if a:x < 75 return 0 else let l:n = (a:x - 55) / 40 let l:m = (a:x - 55) % 40 if l:m < 20 return l:n else return l:n + 1 endif endif endif endfun " returns the actual color level for the given color index fun! rgb_level(n) if &t_Co == 88 if a:n == 0 return 0 elseif a:n == 1 return 139 elseif a:n == 2 return 205 else return 255 endif else if a:n == 0 return 0 else return 55 + (a:n * 40) endif endif endfun " returns the palette index for the given R/G/B color indices fun! rgb_color(x, y, z) if &t_Co == 88 return 16 + (a:x * 16) + (a:y * 4) + a:z else return 16 + (a:x * 36) + (a:y * 6) + a:z endif endfun " returns the palette index to approximate the given R/G/B color levels fun! color(r, g, b) " get the closest grey let l:gx = grey_number(a:r) let l:gy = grey_number(a:g) let l:gz = grey_number(a:b) " get the closest color let l:x = rgb_number(a:r) let l:y = rgb_number(a:g) let l:z = rgb_number(a:b) if l:gx == l:gy && l:gy == l:gz " there are two possibilities let l:dgr = grey_level(l:gx) - a:r let l:dgg = grey_level(l:gy) - a:g let l:dgb = grey_level(l:gz) - a:b let l:dgrey = (l:dgr * l:dgr) + (l:dgg * l:dgg) + (l:dgb * l:dgb) let l:dr = rgb_level(l:gx) - a:r let l:dg = rgb_level(l:gy) - a:g let l:db = rgb_level(l:gz) - a:b let l:drgb = (l:dr * l:dr) + (l:dg * l:dg) + (l:db * l:db) if l:dgrey < l:drgb " use the grey return grey_color(l:gx) else " use the color return rgb_color(l:x, l:y, l:z) endif else " only one possibility return rgb_color(l:x, l:y, l:z) endif endfun " returns the palette index to approximate the 'rrggbb' hex string fun! rgb(rgb) let l:r = ("0x" . strpart(a:rgb, 0, 2)) + 0 let l:g = ("0x" . strpart(a:rgb, 2, 2)) + 0 let l:b = ("0x" . strpart(a:rgb, 4, 2)) + 0 return color(l:r, l:g, l:b) endfun " sets the highlighting for the given group fun! X(group, fg, bg, attr) if a:fg != "" exec "hi ".a:group." guifg=#".a:fg." ctermfg=".rgb(a:fg) endif if a:bg != "" exec "hi ".a:group." guibg=#".a:bg." ctermbg=".rgb(a:bg) endif if a:attr != "" if a:attr == 'italic' exec "hi ".a:group." gui=".a:attr." cterm=none" else exec "hi ".a:group." gui=".a:attr." cterm=".a:attr endif endif endfun " }}} call X("Cursor", "006400", "", "none") call X("CursorLine", "", "eeeeee", "none") call X("CursorColumn", "", "eeeeee", "none") call X("Normal", "000000", "ffffff", "none") call X("NonText", "ffae1b", "", "none") call X("Statement", "0000ff", "", "none") call X("Special", "ff0000", "", "none") call X("Constant", "8b0000", "", "none") call X("Comment", "555555", "", "none") call X("Preproc", "008b8b", "", "none") call X("Type", "8b008b", "", "none") call X("Identifier", "006400", "", "none") call X("Title", "000000", "", "none") call X("StatusLine", "ffffff", "333333", "none") call X("StatusLineNC", "ffffff", "333333", "none") call X("VertSplit", "ffffff", "333333", "none") call X("Visual", "000000", "00ff00", "none") call X("Search", "", "ffff00", "none") call X("Directory", "00008b", "", "none") call X("WarningMsg", "ff0000", "", "none") call X("Error", "ffffff", "ff0000", "none") call X("Todo", "000000", "ffff00", "none") call X("MoreMsg", "", "", "none") call X("ModeMsg", "", "", "none") " vim:set ts=4 sw=4 noet fdm=marker: