From: Samir Benmendil Date: Fri, 3 Jul 2015 21:27:50 +0000 (+0000) Subject: Merge branch 'master' of rmz.io:dotfiles X-Git-Url: https://git.rmz.io/dotfiles.git/commitdiff_plain/e5d7e78f09fdaad72aea931b18487328d4509297?hp=a2ff99188323760defc287bdb38229407d2fa16f Merge branch 'master' of rmz.io:dotfiles --- diff --git a/.gitmodules b/.gitmodules index db79074..3905d84 100644 --- a/.gitmodules +++ b/.gitmodules @@ -7,3 +7,7 @@ [submodule "awesome/widgets/net_widgets"] path = awesome/widgets/net_widgets url = git@github.com:Ram-Z/net_widgets.git +[submodule "awesome/widgets/pomodoro"] + path = awesome/widgets/pomodoro + url = git@github.com:/Ram-Z/awesome-pomodoro + branch = module-path diff --git a/aliases b/aliases index e64bb85..92baf77 100644 --- a/aliases +++ b/aliases @@ -2,6 +2,7 @@ # this will allow aliasing any command after sudo alias sudo='sudo ' +alias ls='ls --color=auto' alias l='ls --color=auto -F' alias ls='ls --color=auto -F' alias ll='ls -lh --color=auto -F' diff --git a/awesome/topbar.lua b/awesome/topbar.lua index 7986af0..91b04fa 100644 --- a/awesome/topbar.lua +++ b/awesome/topbar.lua @@ -89,6 +89,8 @@ for s = 1, screen.count() do local right_layout = wibox.layout.fixed.horizontal() if s == 1 then right_layout:add(wibox.widget.systray()) end right_layout:add(separator) + right_layout:add(require("widgets/pomodoro")) + right_layout:add(separator) right_layout:add(require("widgets/awesompd")) right_layout:add(require("widgets/volume_widget")) if utils.host == "chronos" then diff --git a/awesome/widgets/pomodoro b/awesome/widgets/pomodoro new file mode 160000 index 0000000..a861385 --- /dev/null +++ b/awesome/widgets/pomodoro @@ -0,0 +1 @@ +Subproject commit a861385355d0ac10091eda49757fc9eda05480a3 diff --git a/awesome/widgets/pomodoro.lua b/awesome/widgets/pomodoro.lua new file mode 100644 index 0000000..3c7af63 --- /dev/null +++ b/awesome/widgets/pomodoro.lua @@ -0,0 +1,22 @@ +local pomodoro = require("widgets/pomodoro/init") +local wibox = require("wibox") + +-- durations in seconds +pomodoro.short_pause_duration = 5 * 60 +pomodoro.long_pause_duration = 30 * 60 +pomodoro.work_duration = 25 * 60 + +-- format string +pomodoro.format = function (t) return " "..t.."" end + +pomodoro.init() + +pombox = wibox.layout.fixed.horizontal() +pombox:add(pomodoro.icon_widget) +pombox:add(pomodoro.widget) + +globalkeys = awful.util.table.join(globalkeys, + awful.key({ modkey, "Shift" }, "p", function() pomodoro:start() end) +) + +return pombox diff --git a/dwb/default/bookmarks b/dwb/default/bookmarks index c38a209..173509b 100644 --- a/dwb/default/bookmarks +++ b/dwb/default/bookmarks @@ -4,15 +4,19 @@ http://blog.techdev.de/code-snippet-edit-a-file-in-all-branches-using-git/ Code http://chakraos.org/home/ Chakra | Home http://eudyptula-challenge.org/ The Eudyptula Challenge http://flexget.com/wiki/Plugins Plugins – FlexGet +http://nosuck.org/2015/04/01/you-are-managing-passwords-wrong-lastpass-and-friends/ You Are Managing Passwords Wrong: LastPass and Friends | No Suck http://paste.chakra-project.org/ New paste • The Chakra Project - Pastebin +http://rsync.chakraos.org/packages/ Index of /packages/ http://swarmlab.dyndns.org/ KForge - Home http://upstream-tracker.org/ Upstream Tracker for C/C++ Libraries http://www.ex-parrot.com/~pete/upside-down-ternet.html Upside-Down-Ternet http://www.explainxkcd.com/wiki/index.php/Main_Page explain xkcd http://www.reddit.com/ reddit: the front page of the internet +https://code.google.com/p/umh-arvc-ros/source/browse/trunk#trunk%2Fgraph_optimizer_slam%253Fstate%253Dclosed /trunk - umh-arvc-ros - ros packages from the ARVC group at UMH - Google Project Hosting https://eleum.unimaas.nl/ Blackboard Learn https://mail.google.com Gmail https://myum.unimaas.nl/irj/portal MyUm +https://orcahq.com/ Orca https://plus.google.com Google+ https://tardis:60665/ ZNC - Web Frontend https://www.bnpparibasfortis.be/private/Start.asp BNP Paribas Fortis, la banque et l'assurance d'un monde qui change diff --git a/dwb/default/cookies.allow b/dwb/default/cookies.allow index 96aaf12..b508efd 100644 --- a/dwb/default/cookies.allow +++ b/dwb/default/cookies.allow @@ -1,3 +1,4 @@ +.accounts.paradoxplaza.com .amazon.co.uk .amazon.de .awesome.naquadah.org @@ -24,6 +25,7 @@ .msvincognito.nl .musicbrainz.org .ohloh.net +.paradoxplaza.com .playstarbound.com .reddit.com .redditmedia.com diff --git a/dwb/default/scripts.allow b/dwb/default/scripts.allow index 5efba0d..4058994 100644 --- a/dwb/default/scripts.allow +++ b/dwb/default/scripts.allow @@ -13,6 +13,7 @@ github.com gitorious.org groups.google.com guides.github.com +i.imgur.com just-eat.co.uk localhost mail.google.com @@ -36,7 +37,9 @@ trakt.tv translate.google.com twitter.com unix.stackexchange.com +upstream-tracker.org upstream.rosalinux.ru +vi.stackexchange.com wiki.ros.org www.amazon.co.uk www.amazon.com @@ -46,8 +49,10 @@ www.facebook.com www.google.com www.humblebundle.com www.imdb.com +www.indeed.co.uk www.just-eat.co.uk www.loomio.org +www.paypal.com www.reddit.com www.ros.org www.splitwise.com diff --git a/dwb/forms b/dwb/forms index b7d1a24..3c87b06 100644 Binary files a/dwb/forms and b/dwb/forms differ diff --git a/dwb/keys b/dwb/keys index d342bab..f9d99db 100644 --- a/dwb/keys +++ b/dwb/keys @@ -1,16 +1,16 @@ [default] -save_search_field=gs -tab_new=ga -allow_session_cookie_tmp=CT -allow_cookie=CC -allow_session_cookie=CS -bookmark=M -buffers=gt -cancel_download=ad -sanitize= -clear_tab=gc -only= -close_tab=d +save_search_field= gs +tab_new= ga +allow_session_cookie_tmp= CT +allow_cookie= CC +allow_session_cookie= CS +bookmark= M +buffers= gt +cancel_download= ad +sanitize= +clear_tab= gc +only= +close_tab= d entry_escape=Control c entry_confirm=Control g entry_history_back=Control k @@ -27,152 +27,152 @@ complete_history=Control H complete_path=Control p complete_searchengines=Control S complete_userscript=Control U -download=gd +download= gd download_set_execute=Control x -command_mode=: -tabdo= -execute_javascript= -eval= -execute_userscript=eu -find_backward_ic=c? -find_backward=? -find_forward_ic=c/ -find_forward=/ -find_next=n -find_previous=N -focus_input=gi -focus_next=K -focus_tab=T -focus_prev=J -win_hist_back=wh -tab_hist_back=th -history_back=H -win_hist_forward=wl -tab_hist_forward=tl -history_forward=L -insert_mode=i -show_keys=Sk -load_html= -load_html_tab= -lock_domain=xd -lock_uri=xu -tab_move_left=gl -tab_move_right=gr -tab_move=gm +command_mode= : +tabdo= +execute_javascript= +eval= +execute_userscript= eu +find_backward_ic= c? +find_backward= ? +find_forward_ic= c/ +find_forward= / +find_next= n +find_previous= N +focus_input= gi +focus_next= K +focus_tab= T +focus_prev= J +win_hist_back= wh +tab_hist_back= th +history_back= H +win_hist_forward= wl +tab_hist_forward= tl +history_forward= L +insert_mode= i +show_keys= Sk +load_html= +load_html_tab= +lock_domain= xd +lock_uri= xu +tab_move_left= gl +tab_move_right= gr +tab_move= gm normal_mode=Control n open_editor=Control e -quickmark=b -tab_quickmark=B -win_quickmark=wb +quickmark= b +tab_quickmark= B +win_quickmark= wb start_page=Control h -web_inspector=wi -paste=pp -tab_paste=Pp -win_paste=wp -paste_primary=pP -win_paste_primary=wP -tab_paste_primary=PP +web_inspector= wi +paste= pp +tab_paste= Pp +win_paste= wp +paste_primary= pP +win_paste_primary= wP +tab_paste_primary= PP print=Control Mod1 p protect=Control P quit=Control q -reload_bookmarks= -reload=r -reload_bypass_cache=R -reload_quickmarks= -reload_userscripts= -save=sf -save_session=ZZ -save_named_session=gZZ -save_quickmark=m -scroll_down=j -scroll_right=l -scroll_left=h +reload_bookmarks= +reload= r +reload_bypass_cache= R +reload_quickmarks= +reload_userscripts= +save= sf +save_session= ZZ +save_named_session= gZZ +save_quickmark= m +scroll_down= j +scroll_right= l +scroll_left= h scroll_page_down=Control f scroll_page_up=Control b scroll_halfpage_down=Control d scroll_halfpage_up=Control u -scroll_bottom=G -scroll_top=gg -scroll_up=k -local_set= -set= -set_key=sk -set_local_setting=sl -set_setting=ss -show_settings=Ss -print_preview= -show_bookmarks=Sb -show_downloads=Sd -show_history=Sh -show_quickmarks=Sq +scroll_bottom= G +scroll_top= gg +scroll_up= k +local_set= +set= +set_key= sk +set_local_setting= sl +set_setting= ss +show_settings= Ss +print_preview= +show_bookmarks= Sb +show_downloads= Sd +show_history= Sh +show_quickmarks= Sq stop_loading=Control s -toggle_local_setting= -toggle_setting= +toggle_local_setting= +toggle_setting= toggle_tab=Control @Tab@ -toggle_plugins_host_tmp=pth -toggle_scripts_host=tsh -toggle_scripts_host_tmp=tth -toggle_scripts_uri=tsu -toggle_plugins_uri_tmp=ptu -toggle_scripts_uri_tmp=ttu -fullscreen=@F11@ -toggle_hidden_files=g. -toggle_plugins_host=ph -toggle_plugins_uri=pu -presentation_mode=@F12@ +toggle_plugins_host_tmp= pth +toggle_scripts_host= tsh +toggle_scripts_host_tmp= tth +toggle_scripts_uri= tsu +toggle_plugins_uri_tmp= ptu +toggle_scripts_uri_tmp= ttu +fullscreen= @F11@ +toggle_hidden_files= g. +toggle_plugins_host= ph +toggle_plugins_uri= pu +presentation_mode= @F12@ proxy=Control p -visible=xv -toggle_bars=xx -toggle_statusbar=xb -toggle_tabbar=xt -undo=u -view_source=gf -dump= -yank_title=yt -yank_title_primary=yT -yank=yy -yank_primary=yY -zoom== -zoom_in=+ -zoom_out=- -hints_background=;b -hints_images_background=.i -hints_url_background=.o -backopen_url=xO -backopen=xo -bookmarks=gb -hints=f -hints_clipboard=;y -hints_download=;d -hints_editable=;e -hints_images=;i -hints_links=;; -hints_primary=;Y -hints_rapid=;r -hints_url=;o -new_tab=V -new_win=W -open_url=go -open=o -hints_tab=F -hints_images_tab=;I -hints_url_tab=;O -tab_bookmarks=gB -tabopen_url=gO -tabopen=O -hints_win=wf -hints_rapid_win=;R -win_bookmarks=wB -winopen_url=wO -winopen=wo -adblock_reload_rules= -visual_mode=v -tabgrep= -repeat=. +visible= xv +toggle_bars= xx +toggle_statusbar= xb +toggle_tabbar= xt +undo= u +view_source= gf +dump= +yank_title= yt +yank_title_primary= yT +yank= yy +yank_primary= yY +zoom= = +zoom_in= + +zoom_out= - +hints_background= ;b +hints_images_background= .i +hints_url_background= .o +backopen_url= xO +backopen= xo +bookmarks= gb +hints= f +hints_clipboard= ;y +hints_download= ;d +hints_editable= ;e +hints_images= ;i +hints_links= ;; +hints_primary= ;Y +hints_rapid= ;r +hints_url= ;o +new_tab= V +new_win= W +open_url= go +open= o +hints_tab= F +hints_images_tab= ;I +hints_url_tab= ;O +tab_bookmarks= gB +tabopen_url= gO +tabopen= O +hints_win= wf +hints_rapid_win= ;R +win_bookmarks= wB +winopen_url= wO +winopen= wo +adblock_reload_rules= +visual_mode= v +tabgrep= +repeat= . entry_delete_active=Control d -jump=' -mark=` -hints_selector= +jump= ' +mark= ` +hints_selector= reload_searchengines= restart= diff --git a/dwb/userscripts/extension_loader.js b/dwb/userscripts/extension_loader.js index b1edc36..dcea6b0 100644 --- a/dwb/userscripts/extension_loader.js +++ b/dwb/userscripts/extension_loader.js @@ -110,6 +110,7 @@ domains : { "github.com" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/github.com.css" }, "humblebundle.com" : { "user-stylesheet-uri" : "" }, "imgur.com" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/imgur.com.css" }, + "paradoxplaza.com": { "user-stylesheet-uri" : "" }, "reddit.com" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/reddit.com.css" }, "soundcloud.com" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/soundcloud.com.css" }, "stackexchange.com" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/stackoverflow.com.css" }, @@ -119,10 +120,11 @@ domains : { "superuser.com" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/stackoverflow.com.css" }, "tardis" : { "user-stylesheet-uri" : "" }, "tardis.uni.cx" : { "user-stylesheet-uri" : "" }, - "trakt.tv" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/trakt.tv.css" }, "thetvdb.com" : { "user-stylesheet-uri" : "" }, + "trakt.tv" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/trakt.tv.css" }, "usenet-crawler.com" : { "user-stylesheet-uri" : "" }, "wikipedia.org" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/wikipedia.org.css" }, + "xkcd.com" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/xkcd.com.css" }, }, //Settings applied based on the hostname hosts : { @@ -130,6 +132,7 @@ hosts : { "docs.pointclouds.org" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/doxygen.css" }, "docs.ros.org" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/doxygen.css" }, "git.rmz.io" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/gitweb.css" }, + "git.chakraos.org" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/gitweb.css" }, "maps.google.com" : { "user-stylesheet-uri" : "" }, "paste.chakraos.org" : { "user-stylesheet-uri" : "file:///home/ramsi/.config/dwb/userstyles/paste.chakra-project.org.css" }, "plus.google.com" : { "user-stylesheet-uri" : "" }, diff --git a/dwb/userstyles/github.com.css b/dwb/userstyles/github.com.css index 0acc00c..f44fc6b 100644 --- a/dwb/userstyles/github.com.css +++ b/dwb/userstyles/github.com.css @@ -1,4 +1,4 @@ -/*! Github Dark Theme v1.12.0 (3/26/2015) *//* +/*! Github Dark Theme v1.13.1 (5/21/2015) *//* * https://github.com/StylishThemes/GitHub-Dark * http://userstyles.org/styles/37035 * License: http://sam.zoy.org/wtfpl/ @@ -9,8 +9,8 @@ background-image: /*[[bg-choice]]*/ url() !important; background-clip: border-box !important; background-origin: padding-box !important; + background-attachment: /*[[bg-attachment]]*/ fixed !important; /*[[bg-options]]*/ - /*[[bg-options2]]*/ } /* custom code font */ pre, code, tt, kbd:not(.badmono), pre, samp, .blob-code, .file-data pre, .line-data, #gist-form .file .input textarea, @@ -36,22 +36,24 @@ .discussion-sidebar-toggle:hover .octicon, .sidebar-assignee .assignee:hover, .timeline-commits .commit-message a:hover, .timeline-commits .commit-id:hover, #markdown-toc li a:hover, .sidebar-module ul ul li a:hover, .btn.btn-outline, .org-teams-list .team:hover .team-name, .gh-header-back:hover span:before, a.lock-toggle-link:hover, - a.tabnav-extra:hover, .org-header .edit-org:hover .octicon, - .diagram-icon-small:not(.active) .mega-octicon:before, .diagram-icon:not(.active) .mega-octicon:before, - .panel-nav:not(.disabled) .mega-octicon:before, .team-info-card .stats-group .stat:hover, - .team-info-card .stats-group .stat:hover .stat-number, .octicon-btn:hover, a.discussion-item-entity:hover, - span.discussion-item-entity:hover, .issues-listing .table-list-issues .issue-comments-link:hover, + .org-header .edit-org:hover .octicon, .diagram-icon-small:not(.active) .mega-octicon:before, + .diagram-icon:not(.active) .mega-octicon:before, .panel-nav:not(.disabled) .mega-octicon:before, + .team-info-card .stats-group .stat:hover, .team-info-card .stats-group .stat:hover .stat-number, .octicon-btn:hover, + a.discussion-item-entity:hover, span.discussion-item-entity:hover, .issues-listing .table-list-issues .issue-comments-link:hover, .issues-listing .table-list-issues .issue-title-link:hover, .issues-listing .table-list-issues .issue-meta-section a:hover, .issues-reset-query:hover, .issues-listing .table-list-issues .milestone-link:hover .octicon, .labels-list-action:hover, - .commits-list-item .commits-comments-link:hover, .discussion-item-ref-title .title-link:hover, .box-action:hover, .box-action:active, - input[type="text"]:focus+.scope-badge, .repo-list-stats .repo-list-stat-item:hover, .octotree_views .octotree_treeview .jstree-anchor, - .jstree-icon.tree::before, .octicon-file-directory, .branch-status-details, .notification-actions .btn-link:hover, - a.discussion-item-toggle-open:hover, a.discussion-item-toggle-closed:hover, - .task-list a, .full-commit .btn.btn-outline:hover, .zeroclipboard-link, .stats-group-stat:hover, - .stats-group-stat:hover .stat-number, a.commit-link, .tag-references > li a:hover, .two-factor-toggle .two-factor-status button, - .homepage .mega-octicon:before, .tree-browser tr.navigation-focus .octicon-chevron-right, #header ul.top-nav > li > a:hover, - #header ul.top-nav > li > button:hover, .new-file-form, .date_selector td, .pagination a, .pagination span, - .pagination em { + .commits-list-item .commits-comments-link:hover, .discussion-item-ref-title .title-link:hover, .box-action:hover, + .box-action:active, input[type="text"]:focus+.scope-badge, .repo-list-stats .repo-list-stat-item:hover, + .octotree_views .octotree_treeview .jstree-anchor, .jstree-icon.tree::before, .octicon-file-directory, + .branch-status-details, .notification-actions .btn-link:hover, a.discussion-item-toggle-open:hover, + a.discussion-item-toggle-closed:hover, .task-list a, .full-commit .btn.btn-outline:hover, .zeroclipboard-link, + .stats-group-stat:hover, .stats-group-stat:hover .stat-number, .tag-references > li a:hover, + .two-factor-toggle .two-factor-status button, .homepage .mega-octicon:before, + .tree-browser tr.navigation-focus .octicon-chevron-right, #header ul.top-nav > li > a:hover, + #header ul.top-nav > li > button:hover, .new-file-form, .date_selector td, .pagination a, .pagination span, .pagination em, + .timeline-comment-actions .octicon:hover, a.org-link:hover, a.commit-link, a.commit-link tt, .team-grid .team-name:focus, + .team-grid .team-name:hover, a.tabnav-extra:hover, .tabnav .tabnav-extras:hover, + .application-authorizations .oauth-app-owner:hover { color: /*[[base-color]]*/ #4183C4 !important; } /* Base color panel */ @@ -63,19 +65,24 @@ .example-nav li a.selected, .typeahead-result.navigation-focus, .typeahead-result:hover, .add-line-comment, .issues-reset-query:hover .octicon-x, .segmented-nav li.active, .diff-expander:hover, .pagination .current, .owner-select-target:hover, .btn.btn-outline:hover, .filter-item.selected, - .release-timeline-tags .expander-text:hover .expander-dots, a.gollum-minibutton:hover, a.gollum-minibutton:visited:hover { + .release-timeline-tags .expander-text:hover .expander-dots, a.gollum-minibutton:hover, a.gollum-minibutton:visited:hover, + .search-result-item.navigation-focus { background: /*[[base-color]]*/ #4183C4 !important; } .context-button:after { border-color: /*[[base-color]]*/ #4183C4 transparent transparent !important; } .octofication .message, .panel-nav:not(.disabled):active, .diagram-icon:not(.active), .full-commit .btn.btn-outline:hover, - .btn.btn-outline:hover, .btn.btn-outline.zeroclipboard-is-hover { + .btn.btn-outline:hover, .btn.btn-outline.zeroclipboard-is-hover, :checked + .radio-label { border-color: /*[[base-color]]*/ #4183C4 !important; } .header-nav-link:hover .dropdown-caret, .header-nav-link:focus .dropdown-caret { border-top-color: /*[[base-color]]*/ #4183C4 !important; } + .table-list .table-list-item.unread .table-list-cell-checkbox { + border-left-color: /*[[base-color]]*/ #4183C4 !important; + box-shadow: 2px 0px 0px /*[[base-color]]*/ #4183C4 inset !important; + } /* === Notification icon === */ .notification-indicator .mail-status { background-color: /*[[base-color]]*/ #4183C4 !important; @@ -102,17 +109,13 @@ color: #444 !important; opacity: 1 !important; } - /* checked & unread issue indicator */ - .table-list-item.unread .table-list-cell-checkbox { - box-shadow: 2px 0 0 #fff inset !important; - } /* input focus hightlight */ - input.focus[type="text"], #adv_code_search .focus.search-page-label, - input[type="text"]:focus:not(.js-color-editor-input):not(.tree-finder-input), + input.focus[type="text"], #adv_code_search .focus.search-page-label, .js-chromeless-input-container.focus, + input[type="text"]:focus:not(.js-color-editor-input):not(.tree-finder-input):not(.js-site-search-focus), .focused .drag-and-drop, #adv_code_search .search-page-label:focus, input.focus[type="password"], input[type="password"]:focus, input.focus[type="email"], input[type="email"]:focus, input.focus[type="number"], input[type="number"]:focus, input.focus[type="tel"], input[type="tel"]:focus, input.focus[type="url"], - input[type="url"]:focus, textarea.focus, textarea:focus, #q:focus ~ button { + input[type="url"]:focus, textarea.focus, textarea:focus, #q:focus ~ button, input.color-editor-input:focus { border-color: /*[[base-color]]*/ #4183C4 !important; box-shadow: inset 0 1px 2px rgba(0,0,0,0.075), 0 0 2px /*[[base-color]]*/ #4183C4 !important; } @@ -120,7 +123,7 @@ select, input:not(.js-color-editor-input), textarea { -moz-appearance: none !important; background: #181818 !important; - border: 1px solid #444 !important; + border: 1px solid #343434 !important; color: #eee !important; } /* custom checkbox and radio styles. We need a full set of styles here as WebKit removes all of them when @@ -171,15 +174,22 @@ tab-size: /*[[tab-size]]*/ 4 !important; -moz-tab-size: /*[[tab-size]]*/ 4 !important; } + + .repository-sidebar, .blog-aside, .gist-sidebar { + position: sticky !important; + top: 8px !important; + z-index: 1 !important; + } + /* HACK: Label colors */ - a.label[href*="/issues?"][style*=" color: #f"], a.label[href*="/pulls?"][style*=" color: #f"] { color: #fff !important } - a.label[href*="/issues?"][style*=" color: #e"], a.label[href*="/pulls?"][style*=" color: #e"] { color: #eee !important } - a.label[href*="/issues?"][style*=" color: #d"], a.label[href*="/pulls?"][style*=" color: #d"] { color: #ddd !important } - a.label[href*="/issues?"][style*=" color: #c"], a.label[href*="/pulls?"][style*=" color: #c"] { color: #ccc !important } - a.label[href*="/issues?"][style*=" color: #3"], a.label[href*="/pulls?"][style*=" color: #3"] { color: #333 !important } - a.label[href*="/issues?"][style*=" color: #2"], a.label[href*="/pulls?"][style*=" color: #2"] { color: #222 !important } - a.label[href*="/issues?"][style*=" color: #1"], a.label[href*="/pulls?"][style*=" color: #1"] { color: #111 !important } - a.label[href*="/issues?"][style*=" color: #0"], a.label[href*="/pulls?"][style*=" color: #0"] { color: #000 !important } + a.label[href*="/issues?"][style*=" color: #f"], a.label[href*="/pulls?"][style*=" color: #f"] { color: #e8e8e8 !important } + a.label[href*="/issues?"][style*=" color: #e"], a.label[href*="/pulls?"][style*=" color: #e"] { color: #e8e8e8 !important } + a.label[href*="/issues?"][style*=" color: #d"], a.label[href*="/pulls?"][style*=" color: #d"] { color: #e8e8e8 !important } + a.label[href*="/issues?"][style*=" color: #c"], a.label[href*="/pulls?"][style*=" color: #c"] { color: #e8e8e8 !important } + a.label[href*="/issues?"][style*=" color: #3"], a.label[href*="/pulls?"][style*=" color: #3"] { color: #181818 !important } + a.label[href*="/issues?"][style*=" color: #2"], a.label[href*="/pulls?"][style*=" color: #2"] { color: #181818 !important } + a.label[href*="/issues?"][style*=" color: #1"], a.label[href*="/pulls?"][style*=" color: #1"] { color: #181818 !important } + a.label[href*="/issues?"][style*=" color: #0"], a.label[href*="/pulls?"][style*=" color: #0"] { color: #181818 !important } /* HACK: Center emoji vertically on the line */ .emoji { position: relative; @@ -191,16 +201,15 @@ } /* HACK: Fix annoying text selection bug in Firefox */ .markdown-body code, .markdown-body tt { - padding: 0 .2em !important; + padding: 0 .3em !important; display: inline-block !important; - border: 1px solid #383838 !important; } .markdown-body pre code, .markdown-body pre tt { padding: .2em 0 !important; border: none !important; } .markdown-body code::before, .markdown-body code::after, .markdown-body tt::before, .markdown-body tt::after { - content: "" !important; + display: none !important; } .markdown-body pre code::before, .markdown-body pre code::after, .markdown-body pre tt::before, .markdown-body pre tt::after { display: none !important; @@ -214,11 +223,19 @@ .merge-pr-more-commits { padding: 2px 5px !important; } - input.tree-finder-input, input.tree-finder-input:focus { + input.tree-finder-input, input.tree-finder-input:focus, input.js-site-search-focus { background: transparent !important; border: none !important; box-shadow: none !important; } + .markdown-body a:not([href]), .markdown-body a code { + color: inherit !important; + text-decoration: none !important; + } + .markdown-body strike code, .markdown-body strike tt { + text-decoration: line-through !important + } + /* === Remove shadow === */ h1, h2, h3, h4, pre, pre *, code, tt, li, p, input, a, th, kbd, .news, #footer ul.sosueme li.main, .more-repos, .btn, .metabox em.placeholder, table.notifications, #download_button, .comment-count, em.date, input.search, #user-links, @@ -230,7 +247,7 @@ .avatar-stack.multiple-avatars .avatar:last-child, .avatar-stack.multiple-avatars:before, .box-action, .file-diff-line, .file-code-lines, #adv_code_search .search-page-input, li.ssh-key .ssh-key-state-indicator.not-recent, #gist-form .gist-name-textbox, .labels .label, .octotree_views .octotree_view .octotree_view_header, - .fullscreen-overlay textarea, .avatar-child, .discussion-item .label-color { + .fullscreen-overlay textarea, .avatar-child, .discussion-item .label-color, .coupons .coupon-form-body { text-shadow: none !important; box-shadow: none !important; } @@ -238,7 +255,7 @@ .minibutton span, span.name, .diff-line-code, .num, .user-list em, .diff-expander .octicon-unfold:hover, .select-menu-loading-overlay:before, .select-menu-item a, .minibutton, .mini-icon, .mini-icon:before, .list-tip:before, .line-num-content, .diff-expander .octicon-unfold, .minibutton i, .comment-header-author, .header, .gist .gist-file .gist-meta, - .logo-placeholder, .branch-group-heading, .render-bar, .auth-form-header .octicon { + .logo-placeholder, .branch-group-heading, .render-bar, .auth-form-header .octicon, .render-info .symbol { text-shadow: none !important; } /* === transparent background only === */ @@ -248,7 +265,7 @@ .gist-advanced-options .select-menu-button:after, #wrapper, li.commit, li.public, .gravatar img, .commit-comments-header-sha, pre.headers code, .audit-search-form, .columns.equacols.bordered, .gist-item ul.meta>li>a:hover, .commits li img, a.minibutton code, .milestone, .more-repos, - .previewable-comment-form, .keyboard-mappings th, .api #header-wrapper .nav, + .keyboard-mappings th, .api #header-wrapper .nav, .marketing-nav a.selected, #graph_data .tabs, .org-nav-item.selected, .edit-team-member:hover, tr.commit, .release-timeline .js-details-container, .section-heading-title a.js-selected-navigation-item, .featured-callout .screenshot, .sidebar-module h3 a:hover, .timeline-commits .commit-meta .status, .theme-picker-spinner, @@ -257,19 +274,13 @@ .diagram-icon-small, .commits-listing .commit-group-title .octicon-git-commit, #readme .highlight, .ace-github, .add-member-team-list.table-list, .theme-picker, .avatar-stack .avatar, .boxed-group, .full-commit .btn.btn-outline, .prose-diff > .markdown-body ins, .header .divider-vertical, .ace-github-base16, .markdown-body pre code, .markdown-body pre tt, - #readme .plain pre, .uploaded-files, .merge-pr-more-commits code, .two-factor-toggle .two-factor-status button { + #readme .plain pre, .uploaded-files, .merge-pr-more-commits code, .two-factor-toggle .two-factor-status button, .input_area, + #notebook .highlight, #notebook .highlight pre, .output_area pre { background: transparent !important; } .render-container.is-render-ready.is-render-requested:not(.is-render-failed) { background: none !important; } - /* Redeem Page */ - .coupons .coupon-form-body { - background-image: none !important; - background-color: #222 !important; - box-shadow: none !important; - border: 1px solid #666 !important; - } /* === Remove background gradient === */ #directory .repo, #dashboard .repo, #categories li, .sosueme li.main, #commit .separator, .big-notice, .clean td, .legend .clean, .avatar .overlay.size-48, .listing.closed, .gist .gist-file .gist-data, .gist-syntax, @@ -351,7 +362,7 @@ .wiki-wrapper .wiki-empty-box:hover { border-color: #777 !important; } - pre, hr, img, #browser table, #browser table th, #issues .menu ul li, .branches .more-branches, + img, #browser table, #browser table th, #issues .menu ul li, .branches .more-branches, .counter, .issues td, ul.main_nav li.selected, .browser_header, .issue-head, .bootcamp-help .image, ul.hook-list, .clone-url-button, .list-tip li, .section-nav a, .search-menu-container, .repo_list li a, .graphs .axis, .switcher > span:after, a.assignee-bit, .menu li, .notifications td, .filter-tab, @@ -366,7 +377,7 @@ .content-header, .user-list-item, .markdown-body, ul#categories li h5, .render-view-modes li, .gobutton.with-comments .sha, #gollum-editor-function-bar, .capped-box, .steps li, #common-issues, .steps, #graphs, .previewable-comment-form .comment, .org-module, .org-repo, .table-list, - .table-list-cell, .org-add-footer, .auto-search-group .search-filter, #notification-center li, .branch-status, + .org-add-footer, .auto-search-group .search-filter, #notification-center li, .branch-status, .commit-tease .commit-meta, .comment + .comment, .discussion-bubble-inner, .member-row, .press-info, .timeline-comment, .timeline-comment-header, .timeline-commits .timeline-commits-header, .marketing-section, .featured-callout .screenshot, .page-new-repo .license-container, @@ -385,11 +396,11 @@ .orgs-help-shelf-content .orgs-help-divider, .repository-lang-stats-graph { border-color: #484848 !important; } - h1, h2, h3, .header, #footer, .pagehead, table, table tr, table td, table th, blockquote, .pulse-graph, + pre, h1, h2, h3, .header, #footer, .pagehead, table, table tr, table td, table th, blockquote, .pulse-graph, .btn:not(img), .minibutton, .social-count, .discusion-topic-infobar, .box-header, .box-body, .timeline-comment-label, .logo-box, .suggester li, .developer-program-badge, .vcard-details, .vcard-stats, .auth-form-header, .nav-bar-tabs .section-title, .pagination a:last-child, .pagination span:first-child, .boxed-group-list > li, .toolbar-bordered, .new-issue-form, - .pagination span:last-child, .dashboard-tabs, .graphs, .graph, .featured-callout .rule, .sub-nav, .audit-search-clear, + .pagination span:last-child, .dashboard-tabs, .graphs, .graph, .sub-nav, .audit-search-clear, ul.sunken-menu-group a.selected, .repo-list-item, .email-signature-reply, footer, .bubble .bubble-expand, .grid .col, .composer-infobar, .email-quoted-reply, .summary-stats li, .columns.equacols.bordered, .file-diffstat, ul.filter-list, .news .alert, table.files td, .explore-section, .repolist > li, .featured-grid-outer, @@ -401,16 +412,17 @@ .table-list-bordered .table-list-cell:first-child, .table-list-bordered .table-list-cell:last-child, .table-list-cell, .table-list, .table-list-header, .blankslate, .labels-list-item, .subnav-divider-right, .subnav-bordered, .content table tr th, #search-results li, .subhead, #pages-composer, .render-bar, #gollum-editor-help, - #gollum-editor-help-parent, #gollum-editor-help-list, .markdown-format code, .auth-section, .commit-sha, + #gollum-editor-help-parent, #gollum-editor-help-list, .auth-section, .commit-sha, .comment-body, .mini-repo-list-item, .advanced-search-form fieldset, .contrib-column, .org-header .edit-org, .pulse-summary .summary-box, .pulse-summary .summary-box li:first-child, .list-item + .list-item, .list-item + .list-heading, .list-heading + .list-item, .issue-list-item, .ace_gutter, .collection-card, .setup-header, body.api pre, .stats-group-stat:first-child, .build-statuses-list, #gollum-dialog-dialog-buttons, #gollum-dialog-dialog h4, a.gollum-minibutton, a.gollum-minibutton:visited, .two-factor-toggle .two-factor-status, .two-factor-settings-group, .member-badge, ul.comparison-list > li, .markdown-format ol > li::before, .release-downloads, .release-downloads li, - .blob-interaction-bar, .file-header, input.subnav-search-input, .select-menu-header, + .blob-interaction-bar, .file-header, input.subnav-search-input, .select-menu-header, .search-results, .select-menu-text-filter:first-child:last-child, .select-menu-modal, #gist-form .file .meta, .file .meta, - .file-box .meta, .capped-card, .audit-results-header, .pagination a, .pagination span, .pagination em { + .file-box .meta, .capped-card, .audit-results-header, .pagination a, .pagination span, .pagination em, + .input_area, .output_area .rendered_html table, .render-info .message, .dashboard-notice, .radio-label { border-color: #343434 !important; } .discussion-item-icon, .date:after, .render-shell img, img.asset, ul.color-label-list .color { @@ -439,7 +451,7 @@ .discussion-timeline:before { margin-top: 2px !important; background: #444 !important; - height: calc(100% - 260px) !important; + height: calc(100% - 387px) !important; } .listings div.listing { border-left: 2px solid #333 !important; @@ -449,11 +461,11 @@ border-left: 1px solid #333 !important; border-right: 1px solid #333 !important; } - .timeline-comment:after { + .timeline-comment:after, .commit-form:after { border-right-color: #1d1d1d !important; } - .branch-action-body:after, .timeline-comment-wrapper > .timeline-comment::after, - .timeline-new-comment .timeline-comment::after { + .branch-action-body:after, .timeline-comment-wrapper > .timeline-comment:after, + .timeline-new-comment .timeline-comment:after { border-right-color: #181818 !important; } .timeline-comment:before, .branch-action-body:before { @@ -508,15 +520,17 @@ .native-download, .setup-info-module, div#common-issues ul, #gist-form .name, .subnav-item, .render-notice, .simple-box, .label-edit.edit-color-label-form .color-editor .color-editor-input, .date_selector td, .new-label, .range-editor .range, .range-editor .flag, .octotree_sidebar, .auth-form-body, div.border-wrap, - .profile-header, .btn.btn-outline, .comment-form-head.tabnav, .highlight .gc, .uploaded-files.is-populated, .range-editor, + .profile-header, .btn.btn-outline, .highlight .gc, .uploaded-files.is-populated, .range-editor, #gollum-editor-help-parent li a.selected, #gollum-editor-help-list li a.selected, #gollum-editor-help-parent li a:hover, #gollum-editor-help-list li a:hover, .github-access-banner, .protip-callout, ul.comparison-list, .wiki-custom-sidebar, - .invitation-container, .orgs-help-shelf, .orgs-help-item-octicon { + .invitation-container, .orgs-help-shelf, .orgs-help-item-octicon, .form-control, input[type="text"]:not(.tree-finder-input), + input[type="password"], input[type="email"], input[type="number"], input[type="tel"], input[type="url"], textarea, .two-factor-help { background: #181818 !important; border-color: #343434 !important; } #readme .plain, .readme .markdown-body, .readme .plain, .pull-request-composer, .drag-and-drop, - .octofication .broadcast-icon-mask, .file .image, .merge-pr-more-commits, .release-timeline-tags .expander-dots { + .octofication .broadcast-icon-mask, .file .image, .merge-pr-more-commits, .release-timeline-tags .expander-dots, + .coupons .coupon-form-body { background: #181818 !important; border-color: #484848 !important; } @@ -536,7 +550,7 @@ .render-shell, .list, .latest-commit .commit-author, .bubble, .tabs > a.selected, .pagination .gap, .pagination .disabled, .pagination .gap:hover, .pagination .disabled:hover, .comment-form-head .tabnav-tab.selected, .table-list, .oauth-org-access-details .boxed-group-list > li.on, #fullscreen_overlay, - .timeline-new-comment .discussion-topic-header, .branch-action-body { + .timeline-new-comment .discussion-topic-header, .branch-action-body, .inline-comment-form { background: #181818 !important; } .markdown-body table tr { @@ -551,7 +565,8 @@ /* headers */ .table-list-header, .timeline-comment-header, .boxed-group > h3, .boxed-group .heading, .file-header, .capped-card h3, .select-menu-header, #gist-form .file .meta, .file .meta, .file-box .meta, .menu-heading, - .audit-results-header, .branches .branch-group-heading, .auth-form-header { + .audit-results-header, .branches .branch-group-heading, .auth-form-header, .commit-form, + .comment-form-head.tabnav, .dashboard-notice { background: #1d1d1d !important; } /* Navigation focus */ @@ -560,30 +575,29 @@ .subnav-item:hover, .subnav-item:focus, .tree-browser tr.navigation-focus td, .issues-listing .table-list-issues .selectable:hover, .issues-listing .table-list-issues .navigation-focus, .setup-plans tr.selected, .notifications .navigation-focus, .sidebar-module ul ul li a:hover, .typeahead-result, .no-results, .link-overlay .link, #gollum-editor-help-list, - .owner-select-target, .divider .blob-code div.highlight, pre div[style^="background-color: rgb(248, 238, 199)"], + .owner-select-target, .divider .blob-code div.highlight, pre div[style^="background-color: rgb(248, 238, 199)"], .highlight td[style^="background-color: rgb(248, 238, 199)"], .line[style^="background-color: rgb(255, 255, 204)"], .oauth-org-access-details .boxed-group-list > li.on:hover, pre div:hover, .diff-table tr:hover > pre, .highlight:not(.lines) tr:not(.inline-comments):hover td:not(.line-age) { - background: #202020 !important; + background: #242424 !important; } - /* === #222 === */ #main, .capped-box, .unread_count, #browser table th, .markdown-format table th, .session-device, .profilecols ul.stats li strong, table.upgrades tr.current td, .definitions, .commit-tease .commit-meta, .discussion-topic-header, .facebox-popup, .timeline-commits-minimal .commit-icon .octicon, .timeline-commits .commit-icon .octicon, .upload-progress, .search-results-listing em, .repository-sidebar a.js-selected-navigation-item.selected, .discussion-bubble-inner, #wiki-history table td, - .commit.file-history-tease, .menu a.selected, .gist .gist-file .gist-data, #message.major, .logo-box, .commit-form, + .commit.file-history-tease, .menu a.selected, .gist .gist-file .gist-data, #message.major, .logo-box, .markdown-example .rendered, .team-grid .team-members, .diagram-icon:not(.active), table.capped-list th, .scope-badge, .filter-bar, .audit-search-clear, .country-info, .tabnav-tab.selected, .file-diff-split .empty-cell, .composer-infobar { background: #222 !important; } - #browser, .repos, .options-group, .pagehead ul.tabs li a.selected, .subnav-bar, .options-content, span.gravatar, .browsered, + hr, .rule, #browser, .repos, .options-group, .pagehead ul.tabs li a.selected, .subnav-bar, .options-content, span.gravatar, .browsered, .browsered .inner, .subnav-bar > ul > li > ul, .comment-form ul.tabs a.selected, .issue.open.read .summary, .unselected_month, .commits th, #MathJax_Message, #header .userbox, .chzn-single, .user-commits, .user-commits th, .metabox, .ranked-repositories > li, .pagehead ul.actions, #issues_search .comment, #header-wrapper, ul.feature-tabs li.highlight, .pagination, .filterbar .filters li, .starting-comment .body, .list-tip, .commit_oneline, .filterbox, .conversation-list-heading .inner, .autocomplete-results, .new-comments .body, .display tr, .render-container, .sunken-menu-item.selected, .boxed-group-table th, .features-highlight, .outline-box-highlighted, .nav-bar-tabs, #watchers li, .browser .listing, .item, .context-pane, .context-loader, .sidebar .module, - .tip-body, #assignee, .rule, .sidebar-module > ul, .commit_oneline td, #footer-push, .notifications th, .content table th, + .tip-body, #assignee, .sidebar-module > ul, .commit_oneline td, #footer-push, .notifications th, .content table th, .repo-collection>ul, #graph_data .tab.selected, .full-width-divider, .markdown-body .csv-data th, h3.conversation-list-heading strong, .file-commit-form .commit-form, .thread-subscription-status, .blog-feedback, .facebox-footer, .invited-banner, .build-status-item { @@ -592,15 +606,15 @@ } .btn:disabled, .btn:disabled:hover, .btn.disabled, .btn.disabled:hover, button.button:disabled, button.button:disabled:hover, button.button.disabled, button.button.disabled:hover, button.minibutton:disabled, button.minibutton:disabled:hover, - button.minibutton.disabled, button.minibutton.disabled:hover, a.minibutton:disabled:hover, a.minibutton.disabled:hover { + button.minibutton.disabled, span.minibutton.disabled, a.minibutton.disabled, button.minibutton.disabled:hover, + a.minibutton:disabled:hover, a.minibutton.disabled:hover, span.minibutton:disabled:hover, span.minibutton.disabled:hover, + .search-result-group { background: #222 !important; border-color: #282828 !important; color: #444 !important; } - /* inline code */ - .list-browser-item.closed, .content .verseblock-content, .content .verseblock-content, .commit-preview .message pre, - .content dl code, .content ul code, p code, body.blog pre > code, .content .sectionbody .dlist dt, .content p > tt, - .content .sectionbody .dlist dt, .content p > tt, .commit-sha, .markdown-body code, .markdown-body tt, .protip code, + + .list-browser-item.closed, .content .verseblock-content, .content .verseblock-content, .simple-stacked-bar, .rss-subscribe:hover, div#common-issues ul li a:hover, .date_selector td.selectable_day:hover, .date_selector td.selectable_day.hover, .pagination a:hover, .pagination a:focus, .pagination span:hover, .pagination span:focus, .pagination em:hover, .pagination em:focus { @@ -633,10 +647,10 @@ .pagehead ul.tabs li a:hover, .repos .bottom-bar, #languages .popular, .tip-box h4, table.upgrades td, .commit-preview .message, .commit-preview p.error, .pagehead ul.tabs li.contextswitch, #browser tr th, .status-box h4, .line_numbers, #files span.icon, #issues_list .actions, #repos .public, .inset-callout, #repo-message, - .summary-stats li a:hover { + .summary-stats li a:hover, .repo-private-label, .label-admin, a.team-member-ellipsis { background: #333 !important; } - .metabox .rule, .comment-form, #issues .labels, #gollum-editor select, .listings .odd, .feed, #files .description, + .comment-form, #issues .labels, #gollum-editor select, .listings .odd, .feed, #files .description, #message .envelope .header .info .title.unread, li.contextswitch ul li.current, .watcher-widget, ul.main_nav li.selected a, ul.states li, .add_file, .inset, li.label, .filterbar, .divider-vertical, #footer .upper_footer, .user-commits td, .starting-comment .infobar, #issues_next .infobar, .formbody, @@ -677,18 +691,28 @@ iframe[src*="polldaddy.com"], .jstree-icon.jstree-ocl, .octotree_toggle .loader, .swipe .swipe-frame .swipe-bar .top-handle, .swipe .swipe-frame .swipe-bar .bottom-handle, .onion-skin .controls .transparent, .onion-skin .controls .opaque, .onion-skin .controls .slider .slider-track, .onion-skin .controls .slider .slider-track .dragger { - filter: url("data:image/svg+xml;utf8, #i"); -webkit-filter: invert(100%) !important; + filter: invert(100%) !important; } .emoji[title=":soon:"], .emoji[title=":on:"], .emoji[title=":end:"], .emoji[title=":heavy_dollar_sign:"], .emoji[title=":registered:"], .emoji[title=":tm:"], .emoji[title=":heavy_multiplication_x:"], .emoji[title=":heavy_plus_sign:"], .emoji[title=":heavy_minus_sign:"], .emoji[title=":heavy_division_sign:"], .emoji[title=":heavy_check_mark:"], .emoji[title=":arrows_clockwise:"], .emoji[title=":wavy_dash:"], .emoji[title=":curly_loop:"], .emoji[title=":copyright:"], .emoji[title=":currency_exchange:"], .emoji[title=":top:"], .emoji[title=":back:"] { - filter: url("data:image/svg+xml;utf8, #i"); -webkit-filter: invert(100%) !important; + filter: invert(100%) !important; background: transparent !important; } + /* match white to #181818 */ + .output_area img { + -webkit-filter: invert(90%) !important; + filter: invert(90%) !important; + } + /* brighten language colors */ + .language-color { + -webkit-filter: brightness(150%) !important; + filter: brightness(150%) !important; + } /* slightly darker */ .more-repos-link { -webkit-filter: brightness(.666) !important; @@ -769,9 +793,12 @@ table.files tr.up-tree a:hover, .ellipsis-button:hover, .codesearch-results .repo-list-name em, .codesearch-results .repo-list-description em, .blog-search-results em, .codesearch-cols em, ul.bignav li a:hover, ul.smallnav li a:hover, .comments-wrapper, .rackspace, .subnav-bar > ul > li > ul > li > a:hover, ol.download-list li:nth-child(2n), .issue.active, .counter, .orgs-nav .count, - .filter-item:not(.selected):hover, .task-progress .progress-bar .progress, .markdown-body hr, .oauth-connection-illustration .oauth-image { + .filter-item:not(.selected):hover, .task-progress .progress-bar .progress, .oauth-connection-illustration .oauth-image { background: #444 !important; } + .markdown-body hr { + background: #383838 !important; + } .switcher > span:after, .list-module a:hover, .section-nav .active a, #dashboard .filter-bar li a.filter_selected:after { background-color: #555 !important; } @@ -779,7 +806,7 @@ .branch-a-b-count .meter, .branch-action-state-dirty .branch-action-icon, .branch-action-state-closed-dirty .branch-action-icon { background: #555 !important; } - .labels .label-neutral { + .labels .label-neutral, li.ssh-key .ssh-key-state-indicator.not-recent { background: #666 !important; } .diverge-widget .separator { @@ -807,6 +834,7 @@ .markdown-format .alert p, .blob-history { color: #8195BE !important; } + .timeline-comment.current-user, .github-jobs-promotion p, .octotip, .markdown-format .alert:not(.warning), .full-commit.commit, .bootcamp .bootcamp-body, .bootcamp h1, .owners-notice, .new-user-avatar-cta, .full-commit .browse-button, .commit-ref, .full-commit .btn.btn-outline, a.branch-name, .branch-name, @@ -840,15 +868,22 @@ .commit-icon .octicon { border-radius: 100% !important; } + /* notebooks */ + .input_prompt { + color: hsla(234, 100%, 65%, 1) !important; + } + .output_prompt { + color: hsla(0, 100%, 65%, 1) !important; + } /* === gradient === */ /* light grey gradient */ .btn:hover, .btn:active, .btn.zeroclipboard-is-hover, .btn.zeroclipboard-is-active, .minibutton:hover, .minibutton:active, .minibutton.zeroclipboard-is-hover, .minibutton.zeroclipboard-is-active.kbd, .signup-button:hover, a.signin:hover, - .hero .textographic, .hero .screenographic, .dashboard-notice, .pagination span.current, .box-action:active, .btn:active, + .hero .textographic, .hero .screenographic, .pagination span.current, .box-action:active, .btn:active, .btn.selected, .btn.selected:hover, .btn.zeroclipboard-is-active, .minibutton:active, .minibutton.selected, .minibutton.selected:hover, .minibutton.zeroclipboard-is-active, .clone-url-button.selected > a, - .clone-url-button.selected > a:hover, .octotree_toggle:hover, button.button:hover, button.minibutton:hover, - a.minibutton:hover { + .clone-url-button.selected > a:hover, .octotree_toggle:hover, button.button:hover, a.button:hover, span.button:hover, + button.minibutton:hover, a.minibutton:hover, span.minibutton:hover { background: linear-gradient(to bottom, #444, #333) !important; border-color: #484848 !important; } @@ -857,8 +892,9 @@ .pagehead ul.tabs li a, .login_form input[type="submit"], .top-bar, ul#bootcamp li a h4, .pull-info, #gists .context-menu-container, .branch-link, body#com #header, .white-nav .selected span, .clone-url-button a, .filter-tab, #header-wrapper, #header-wrapper .nav, .pagination span, .cheatsheet h2, .section a.section-head, .octotree_view_header, - .list-heading, .dashboard-tabs li a, a.function-button, .add-pill-form, - .gist .gist-file .gist-meta, .octotree_toggle, ul.comparison-list > li.title, button.button, button.minibutton, a.minibutton { + .list-heading, .dashboard-tabs li a, a.function-button, .add-pill-form, .gist .gist-file .gist-meta, .octotree_toggle, + ul.comparison-list > li.title, button.button, a.button, span.button, button.minibutton, a.minibutton, + span.minibutton { background: linear-gradient(to bottom, #282828, #181818) !important; border-color: #383838 !important; } @@ -892,7 +928,7 @@ .subnav li a:hover, .filters li.selected a, .filters li a:hover, .code-list em, a.header-anchor, .commandbar .choice .command, .search-term, .codesearch-cols em, .image, .selector-item:hover .mini-icon:before, .selector-item.selected .mini-icon:before, .new-repo .octicon, .select-menu-item.selected>.octicon, .sunken-menu a.selected .octicon, #header .nav a, - .feed-icon a .octicon, .release-label a, .minibutton i, + .feed-icon a .octicon, .release-label a, .minibutton i, .minibutton, .merge-status-icon .mega-octicon:before, .commit .mini-icon:before, .sidebar-milestone-widget .title, .select-menu-modal a.select-menu-item-text, .facebox-user-list-item a, .numbers-summary .num, #network .explain b,.sunken-menu-group li:hover .octicon, .featured-callout, h3 strong, @@ -906,11 +942,11 @@ .overall-summary .graphs .num, ul.summary-stats li .num, .pull-head-meta .pull-number a, .mini-discussion-bubble .mini-discussion-bubble-action, .sub-nav h2, .sub-nav h2 a, .boxed-group .boxed-group-inner strong, .accordion .section a.section-head, .commit-tease .authorship a, .orgs-nav .org-nav-item.selected, .sub-nav li a.active, - .pagehead .org-title .org-link, .gh-header-status .octicon:before, a.tabnav-tab.selected, .view-modes-menu li.active, + a.org-link, .gh-header-status .octicon:before, a.tabnav-tab.selected, .view-modes-menu li.active, span.discussion-item-icon, a.signin:hover, .marketing-benefits .mega-octicon:before, .thread-subscription-status .mega-octicon:before, .infobar-widget .text a, .dropdown-menu > li > a:hover > .octicon:before, .dropdown-menu > li > a.zeroclipboard-is-hover > .octicon:before, .highlight-module .mega-icon:before, - .headlines li a, .repository-sidebar .clone-options .octicon:before, .team:hover .team-name, + .headlines li a, .repository-sidebar .clone-options .octicon:before, #wiki-rightbar li, .i-am-error p, .select-menu-item-text, .markdown-body .octicon-link, .team-org-group strong, .gist-item ul.meta > li > a:hover, .native-download .mega-icon:before, #article-platform-nav ul li.selected a, .section-heading-title a.selected, .marketing-nav a.selected, @@ -938,7 +974,9 @@ #gollum-editor-help-parent li a.selected, #gollum-editor-help-list li a.selected, a.gollum-minibutton, a.gollum-minibutton:visited, a.token-warning, a.lightertooltipped, .org-team-sidebar .team-note .note-emphasis, .select-menu-tabs a.selected, #com .dropdown-menu a:hover, #com h1 span, #com h2 span, .breadcrumb strong.final-path, - button.button, button.minibutton, a.minibutton, .button.primary:hover, .pagination .current, .pagination .current:hover { + button.button, a.button, span.button, button.minibutton, a.minibutton, .button.primary:hover, .pagination .current, + .pagination .current:hover, .repo-private-label, a.repo_filter.js-repo-filter-tab.filter-selected, .keyboard-mappings th, + .rendered_html, .render-health:hover .symbol, .radio-label { color: #e0e0e0 !important; } pre, body, h3, h4, a.social-count, span.social-count, #languages a.bar, dl.form dt, .lineoption p, a.select-menu-button, a.blog-title, @@ -952,7 +990,7 @@ .select-menu-header .select-menu-title, #commits_tab_counter, .auto-search-group .search-filter, .usage-bar dt, .auto-search-group .search-filter .octicon:before, .github-jobs-promotion p a, .select-menu-item .description, .issue-head .number strong, .file-info .file-name, .explain strong, .file-box .meta, - .form-checkbox .note, .commit-tease .authorship .author-name, .gh-header-meta .author, .timeline-comment-header .author, + .commit-tease .authorship .author-name, .gh-header-meta .author, .timeline-comment-header .author, .timeline-commits .author, .new-discussion-timeline .sidebar-milestone .milestone-name, .sidebar-assignee .assignee, .rss-subscribe, .sidebar-module h3 a, .sidebar-module h3.disable span, .menu a, .octotip, .graph-canvas .activity, .boxed-group .boxed-group-inner, .ace_gutter-active-line, .billing-section .section-content, @@ -967,12 +1005,13 @@ .discussion-item .renamed-was, .discussion-item .renamed-is, a.discussion-item-entity, span.discussion-item-entity, .table-list-header-toggle .btn-link.selected, .table-list-header-toggle .btn-link.selected:hover, .table-list-header-toggle .btn-link:hover, a.issue-title-link, .table-list-item p, - .table-list-milestones .milestone-title-link a, .org-header .edit-org, .blob-code, .diff-line-code, .clone-url-button > a, + .table-list-milestones .milestone-title-link a, .org-header .edit-org, .blob-code, .blob-code-inner, .diff-line-code, .clone-url-button > a, .contrib-number, .pulse-summary .summary-box .count, .list-options .selected .list-item-title, .nav-bar-inner .brand-logo-invertocat .octicon-mark-github, .menu a .octicon, .issue-list-meta a, .stat-number, div.search-form button span, .fullscreen-overlay .octicon:hover:before, .fullscreen-overlay .mega-octicon:hover:before, .protip-callout, .fullscreen-overlay textarea:focus, .fullscreen-overlay textarea:hover, - #header ul.top-nav > li > a, #header ul.top-nav > li > button, a.octotree_toggle { + #header ul.top-nav > li > a, #header ul.top-nav > li > button, a.octotree_toggle, a.team-member-ellipsis:hover, + .rendered_html pre, .rendered_html code, .team-grid .team-name { color: #c0c0c0 !important; } h5, h6, .edit-repository-meta, .field label, .boxed-group-list li, .capped-box, .marketing-nav a, @@ -1006,15 +1045,15 @@ .table-list-milestones .stat, .commits-listing .commit-group-title .octicon-git-commit, .select-menu-header .octicon:hover, .repo-list-description, .latest-commit .bubble-content strong, .file .meta, .email-format .email-hidden-toggle a, .file-diffstat, - .program-info-column .mega-octicon, .octofication .notice-dismiss:hover, a.discussion-item-toggle-open, - a.discussion-item-toggle-closed, .timeline-commits .commit-message a, .markdown-format .intro, .markdown-format code, - .markdown-format ol > li::before, a.tabnav-extra { + .program-info-column .mega-octicon, .octofication .notice-dismiss:hover, .timeline-commits .commit-message a, .markdown-format .intro, .markdown-format code, + .markdown-format ol > li::before, a.tabnav-extra, .tabnav .tabnav-extras, .label-admin, .program-info-column p, + .form-checkbox .note { color: #a0a0a0 !important; } /* content text */ #contributions-calendar .contrib-details div, .mini-icon-remove-close:hover, .tabnav-tabs a, .time, .diffstat-bar, .gist-item .metadata .datetime, .list-group-item-meta, - a.keyboard-shortcuts, .simple-conversation-list, .simple-conversation-list > li .title .num, .drag-and-drop, + a.keyboard-shortcuts, button.keyboard-shortcuts, .simple-conversation-list, .simple-conversation-list > li .title .num, .drag-and-drop, .starred-repo .sort-info, .org-stats, .commandbar .choice, .commandbar .loading, .commandbar .description, ul.summary-stats li a, .authorship, .sha-block, .gh-header-meta, #last-edit, .setup-header .lead a, .repository-meta .edit-link a, .api-status a, .meta li, .who_when a,.numbers-summary a, .numbers-summary .octicon:before, @@ -1032,7 +1071,7 @@ .notifications .issue-notification.read .type-icon, .notifications .read a, .auth-form-header .octicon, .releases-tag-list p a, .history-link a, a.issue-nwo-link, ul.filter-list .filter-item, .blob-num, .blob-num:before, .member-meta .teams-link, .member-meta .btn-link, a.stats-group-stat, ul.comparison-list > li em, ul.comparison-list > li.title, - .diffstat-summary { + .diffstat-summary, a.team-member-ellipsis, a.discussion-item-toggle-open, a.discussion-item-toggle-closed { color: #808080 !important; } .vcard-detail .octicon, .command-bar .octicon-question:before, .auto-search-group .octicon:before, .news .alert .time, @@ -1049,7 +1088,8 @@ .blob-num-expandable .diff-expander, .file-type-icon, .uploaded-files .remove, .releases-tag-list td.date a, .fullscreen-overlay .octicon:before, .fullscreen-overlay .mega-octicon:before, .collaborators .collab-remove .remove-link, .octofication .notice-dismiss, ul.comparison-list > li .octicon, div.content-header h6, .fullscreen-overlay textarea, - #com h2.search-title, .blob-num.non-expandable:hover, .breadcrumb { + #com h2.search-title, .blob-num.non-expandable:hover, .breadcrumb, #footer .mega-octicon, .application-authorizations .oauth-app-list-meta, + .application-authorizations .oauth-app-owner, .boxed-group-inner .help, .thread-subscription-status .reason, .clone-url input.input-mini { color: #666 !important; } .context-pane .selector-item:hover a, .mega-icon:before, .mini-icon-public-repo:before, .mini-icon-pull-request, .mini-icon-remove-close, @@ -1065,7 +1105,7 @@ } .timeline-comment-header .timestamp, .vcard-stat:hover .text-muted, .boxed-group > h3 a, .boxed-group .heading a, .select-menu-item a, .list-heading a, .close-button, .timeline-comment-action, a.timeline-comment-action, - a.comment-type-icon { + a.comment-type-icon, .timeline-comment-actions .octicon { color: inherit !important; } /* Alerts and activity, remove background gradient */ @@ -1114,7 +1154,8 @@ .authors-and-code .deletions, .diffstat .diffstat-bar.diff-deleted, span.diffstat .diffstat-bar i.minus, .icon-for-failure, ul.summary-stats li .octicon-issue-closed, .branch-delete, #toc .octicon-diff-removed, .pagehead-actions .octicon-mute, .highlight .gd, .settings-email .email-actions .settings-remove-email, - .uploaded-files .remove:hover, .collaborators .collab-remove .remove-link:hover, .minibutton.danger { + .uploaded-files .remove:hover, .collaborators .collab-remove .remove-link:hover, .minibutton.danger, + .octicon-btn-danger:hover { color: #c31e16 !important; } @@ -1140,7 +1181,7 @@ /* === Yellow panel === */ .branch-status.status-pending .discussion-item-icon, .discussion-event-status-renamed .discussion-item-icon, .state-indicator.renamed, .discussion-topic .branch-status.status-pending, .secret .repo-label span, .compare-pr-placeholder, - .compare-cutoff, .diff-cutoff, .flash.flash-warn, .flash-global.flash-war { + .compare-cutoff, .diff-cutoff, .flash.flash-warn, .flash-global.flash-warn { background: #383812 !important; border-color: #884 !important; color: #aa6 !important; @@ -1224,7 +1265,7 @@ background: #6E5494 !important; } /* purple text */ - ul.summary-stats li .octicon-git-pull-request, .pull-request-notification .type-icon { + ul.summary-stats li .octicon-git-pull-request, .pull-request-notification .type-icon .type-icon-state-merged { color: #6E5494 !important; } .diagram-icon-small.active .mega-octicon:before { @@ -1283,11 +1324,12 @@ border-color: transparent #333 transparent transparent !important; } /* octocat spinners */ - img[src*="octocat-spinner"] { + img[src*="octocat-spinner"], img[src="/images/spinner.gif"] { width: 0 !important; height: 0 !important; } - img[src*="octocat-spinner"], .facebox-loading, .branch-action-body .spinner, .status-indicator-loading { + img[src*="octocat-spinner"], img[src="/images/spinner.gif"], .facebox-loading, .branch-action-body .spinner, + .status-indicator-loading { background: url() !important; background-size: contain !important; } @@ -1295,6 +1337,7 @@ img[src*="octocat-spinner"][width="64"] { padding: 32px !important } img[src*="octocat-spinner"][width="32"] { padding: 16px !important } img[src*="octocat-spinner"][width="16"] { padding: 8px !important } + img[src="/images/spinner.gif"] { padding: 32px !important } .branch-action-body .spinner, div.facebox-loading, .status-indicator-loading { background-position: center center !important; @@ -1303,7 +1346,7 @@ } /* image preview background */ - .render-shell img, .file .image img, .file .image canvas { + .render-shell .img-view img, .file .image img, .file .image canvas { background-image: url('') !important; } @@ -1349,7 +1392,11 @@ border-bottom: #343434 8px solid !important; } /* inline code - add with border */ - .markdown-format pre, .markdown-body pre, .markdown-format .highlight pre, .markdown-body .highlight pre, body.blog pre, + .markdown-format code, .markdown-body code, .markdown-body tt, .markdown-format pre, + .markdown-body pre, .markdown-format .highlight pre, .markdown-body .highlight pre, + body.blog pre { + border: 1px solid rgba(255,255,255,.1) !important; + } #facebox pre, #contributors-master svg.viz { border: 1px solid #343434 !important; } @@ -1529,7 +1576,7 @@ border-color: /*[[base-color]]*/ #4183C4 !important; color: #fff !important; } - .zh-pipeline-issue-toggler:hover { + .zh-pipeline-issue-toggler:hover, .date_selector .date-button { color: /*[[base-color]]*/ #4183C4 !important; } /* background */ @@ -1540,12 +1587,13 @@ background-color: #111 !important; border-color: #484848 !important; } - li.zh-pipeline, li.new-pipeline-column, .zh-schema-pipelines { + li.zh-pipeline, li.new-pipeline-column, .zh-schema-pipelines, .zh-pipeline-issue-heading { background-color: #181818 !important; border-color: #484848 !important; } li.zh-pipeline-issue, .zh-pipeline-issue-content, .zh-issue-meta, .zh-pipeline-issue-action, - .zh-pipeline-heading-container, .zh-button-grey, .zh-board-menu, .zh-schema-title { + .zh-pipeline-heading-container, .zh-button-grey, .zh-board-menu, .zh-schema-title, + .zh-burndown-chart .milestone-start-calendar-container { background-color: #222 !important; border-color: #484848 !important; } @@ -1553,13 +1601,14 @@ background: #333 !important; } /* border */ - .zh-paw-btn-inner, .zh-schema, .zh-schema-pipeline-name, .popover, .zh-uploader-drop { + .zh-paw-btn-inner, .zh-schema, .zh-schema-pipeline-name, .popover, .zh-uploader-drop, + .zh-milestone-dates, .zh-burndown-chart-container, .zh-burndown-chart .stats-container { border-color: #484848 !important; } .popover.right .arrow { border-right-color: #484848 !important; } - .file-commit-form .commit-form:before, .file-commit-form .commit-form:after { + .file-commit-form .commit-form:before, .file-commit-form .commit-form:after, .zh-burndown .stats-item { border-right-color: #343434 !important; } /* text */ @@ -1603,8 +1652,12 @@ } /* invert image */ .zh-upload-image { - filter: url("data:image/svg+xml;utf8,#i"); -webkit-filter: invert(40%) !important; + filter: invert(40%) !important; + } + .zh-icon-burndown { + -webkit-filter: invert(100%) !important; + filter: invert(100%) !important; } /* webkit scrollbars */ .zh-pipeline-issues-wrapper::-webkit-scrollbar-track { @@ -1620,12 +1673,6 @@ background: #444 !important; } - /* custom language colors */ - .language-color { - filter: brightness(150%) !important; - -webkit-filter: brightness(150%) !important; - } - /* OS X font rendering tweak, only active on sub-retina pixel ratios, might affect * Chrome on other OSs too, see https://github.com/StylishThemes/GitHub-Dark/issues/86 */ @@ -1636,9 +1683,17 @@ } } - /* inline code blocks - selector group is completed by the theme file */ + /* inline code - single lines */ + .markdown-body code, .markdown-body tt, .protip code, .content dl code, .content ul code, p code, + body.blog pre > code, .content .sectionbody .dlist dt, .content p > tt, .content .sectionbody .dlist dt, + .content p > tt, .commit-sha, .commit-preview .message pre, .rendered_html pre, .rendered_html code { + background: #202020 !important; + } + + /* inline code - big blocks */ pre, .markdown-format pre, .markdown-body pre, .markdown-format .highlight pre, .markdown-body .highlight pre, body.blog pre, #facebox pre, .blob-code-context, .blob-num-context, .blob-expanded, .terminal, .copyable-terminal, + #notebook .input_area, /*[[syntax-theme]]*/ /* grunt build - remove to end of file */ @@ -1778,3 +1833,67 @@ .ace_editor .ace_xml-pe{color:#494949!important} .ace_editor .ace_indent-guide{background:url() right repeat-y!important} + /* Jupyter Notebooks */ + /*! Twilight; https://gist.github.com/dansimpson/803005 */ + #notebook .highlight, #notebook .highlight pre, + #notebook .highlight table { background: #181818 !important; color: #F8F8F8 !important;font-family: Consolas, Monaco,"Lucida Console" !important; } + #notebook .highlight * { font-family: Consolas, Monaco,"Lucida Console" !important; color: #F8F8F8 !important; } + #notebook .highlight .hll { background-color: #ffffcc !important; } + #notebook .highlight .c { color: #5F5A60 !important; font-style: italic !important; } /* Comment */ + #notebook .highlight .err { border:#B22518 !important; } /* Error */ + #notebook .highlight .k { color: #CDA869 !important; } /* Keyword */ + #notebook .highlight .cm { color: #5F5A60 !important; font-style: italic !important; } /* Comment.Multiline */ + #notebook .highlight .cp { color: #5F5A60 !important; } /* Comment.Preproc */ + #notebook .highlight .c1 { color: #5F5A60 !important; font-style: italic !important; } /* Comment.Single */ + #notebook .highlight .cs { color: #5F5A60 !important; font-style: italic !important; } /* Comment.Special */ + #notebook .highlight .gd { background: #420E09 !important; } /* Generic.Deleted */ + #notebook .highlight .ge { font-style: italic !important; } /* Generic.Emph */ + #notebook .highlight .gr { background: #B22518 !important; } /* Generic.Error */ + #notebook .highlight .gh { color: #000080 !important; font-weight: bold !important; } /* Generic.Heading */ + #notebook .highlight .gi { background: #253B22 !important; } /* Generic.Inserted */ + #notebook .highlight .go { } /* Generic.Output */ + #notebook .highlight .gp { font-weight: bold !important; } /* Generic.Prompt */ + #notebook .highlight .gs { font-weight: bold !important; } /* Generic.Strong */ + #notebook .highlight .gu { color: #800080 !important; font-weight: bold !important; } /* Generic.Subheading */ + #notebook .highlight .gt { } /* Generic.Traceback */ + #notebook .highlight .kc { } /* Keyword.Constant */ + #notebook .highlight .kd { color: #e9df8f !important; } /* Keyword.Declaration */ + #notebook .highlight .kn { } /* Keyword.Namespace */ + #notebook .highlight .kp { color: #9B703F !important; } /* Keyword.Pseudo */ + #notebook .highlight .kr { } /* Keyword.Reserved */ + #notebook .highlight .kt { } /* Keyword.Type */ + #notebook .highlight .m { } /* Literal.Number */ + #notebook .highlight .s { } /* Literal.String */ + #notebook .highlight .na { color: #F9EE98 !important; } /* Name.Attribute */ + #notebook .highlight .nb { color: #CDA869 !important; } /* Name.Builtin */ + #notebook .highlight .nc { color: #9B859D !important; font-weight: bold !important; } /* Name.Class */ + #notebook .highlight .no { color: #9B859D !important; } /* Name.Constant */ + #notebook .highlight .nd { color: #7587A6 !important; } /* Name.Decorator */ + #notebook .highlight .ni { color: #CF6A4C !important; font-weight: bold !important; } /* Name.Entity */ + #notebook .highlight .nf { color: #9B703F !important; font-weight: bold !important; } /* Name.Function */ + #notebook .highlight .nn { color: #9B859D !important; font-weight: bold !important; } /* Name.Namespace */ + #notebook .highlight .nt { color: #CDA869 !important; font-weight: bold !important; } /* Name.Tag */ + #notebook .highlight .nv { color: #7587A6 !important; } /* Name.Variable */ + #notebook .highlight .ow { color: #AA22FF !important; font-weight: bold !important; } /* Operator.Word */ + #notebook .highlight .w { color: #141414 !important; } /* Text.Whitespace */ + #notebook .highlight .mf { color: #CF6A4C !important; } /* Literal.Number.Float */ + #notebook .highlight .mh { color: #CF6A4C !important; } /* Literal.Number.Hex */ + #notebook .highlight .mi { color: #CF6A4C !important; } /* Literal.Number.Integer */ + #notebook .highlight .mo { color: #CF6A4C !important; } /* Literal.Number.Oct */ + #notebook .highlight .sb { color: #8F9D6A !important; } /* Literal.String.Backtick */ + #notebook .highlight .sc { color: #8F9D6A !important; } /* Literal.String.Char */ + #notebook .highlight .sd { color: #8F9D6A !important; font-style: italic !important; } /* Literal.String.Doc */ + #notebook .highlight .s2 { color: #8F9D6A !important; } /* Literal.String.Double */ + #notebook .highlight .se { color: #F9EE98 !important; font-weight: bold !important; } /* Literal.String.Escape */ + #notebook .highlight .sh { color: #8F9D6A !important; } /* Literal.String.Heredoc */ + #notebook .highlight .si { color: #DAEFA3 !important; font-weight: bold !important; } /* Literal.String.Interpol */ + #notebook .highlight .sx { color: #8F9D6A !important; } /* Literal.String.Other */ + #notebook .highlight .sr { color: #E9C062 !important; } /* Literal.String.Regex */ + #notebook .highlight .s1 { color: #8F9D6A !important; } /* Literal.String.Single */ + #notebook .highlight .ss { color: #CF6A4C !important; } /* Literal.String.Symbol */ + #notebook .highlight .bp { color: #00aaaa !important; } /* Name.Builtin.Pseudo */ + #notebook .highlight .vc { color: #7587A6 !important; } /* Name.Variable.Class */ + #notebook .highlight .vg { color: #7587A6 !important; } /* Name.Variable.Global */ + #notebook .highlight .vi { color: #7587A6 !important; } /* Name.Variable.Instance */ + #notebook .highlight .il { color: #009999 !important; } /* Literal.Number.Integer.Long */ + diff --git a/dwb/userstyles/stackoverflow.com.css b/dwb/userstyles/stackoverflow.com.css index 8dca586..d8d1695 100644 --- a/dwb/userstyles/stackoverflow.com.css +++ b/dwb/userstyles/stackoverflow.com.css @@ -1,5 +1,5 @@ /*************************************************************** - StackOverflow Dark v2.6.2 (2/26/2015) + StackOverflow Dark v2.7.3 (5/21/2015) https://github.com/StylishThemes/StackOverflow-Dark http://userstyles.org/styles/35345 @@ -26,13 +26,15 @@ color: /*[[base-color]]*/ #008080 !important } - .nav .primarynav li a:hover { + .nav .primarynav li a:hover, .message.message-config .actions .button, .btn-careers:hover, + .btn-careers:visited { color: #fff !important; background: /*[[base-color]]*/ #008080 !important; } .post-tag:hover, .comments-link:hover, .summary .post-tag:hover , .commentslink, .bounty-indicator, - .bounty-indicator-tab, .bounty-award, span.bounty-indicator-tab { + .bounty-indicator-tab, .bounty-award, span.bounty-indicator-tab, #change-picture, .top-badge, + .supernovabg, .hotbg, .nav li.youarehere a, .nav a:hover, a.button:hover, .edit-count { background-color: /*[[base-color]]*/ #008080 !important; color: #eee !important; } @@ -52,7 +54,7 @@ border-color: /*[[base-color]]*/ #008080 !important; box-shadow: 0px 1px 2px rgba(255, 255, 255, 0.075) inset, 0px 0px 5px rgba(255, 255, 255, .075) !important; } - .tag-editor input:focus { + .tag-editor input:focus, .previous-button, .next-button { border: 0 !important; box-shadow: none !important; } @@ -67,6 +69,9 @@ .search-container input[type=text] { background-color: #000 !important; } + .popup-badges .all-badge-progress .completed:before, .previous-button, .next-button { + background-color: rgba(0,0,0,0.4) !important; + } #custom-header, .review-bar, .diff-choices a.selected, #header #topbar, td.owner, a.owner, .question-status, .profile-popup, .profile-popup div, .profile-popup th, .profile-popup td, #global, .actual-edit-overlay, @@ -75,7 +80,7 @@ color: #ddd !important; } - .summary .post-tag, .onebox, .profile-ad { + .summary .post-tag, .onebox, .profile-ad, .message.message-config { background: #151515 !important; } @@ -94,18 +99,22 @@ border: 1px solid transparent !important; } - #tabs a.youarehere, .tag-suggestions { + #tabs a.youarehere, .tabs a.youarehere, .tag-suggestions { background: #191919 !important; border: 1px solid #444 !important; } + .tabs a.youarehere { + border-bottom: 0 !important; + } - #user-about-me, .user-about-me, .mine .messages { + + #user-about-me, .user-about-me, .mine .messages, .avatar-card, .tag-container { background: #191919 !important; - border: 0px !important; + border: 0 !important; color: #C1BEBA !important; } - .topbar-dialog, .topbar-dialog .header, .share-tip, #input-area, + .topbar-dialog, .topbar-dialog .header, .share-tip, #input-area, .messages, #tag-menu, .sidebar h3, #overlay-header, .action-list .action-selected, .switcher-nudge-lightbox, .user-rep-chart-summary-tooltip:hover, .current-site-container { background-color: #222 !important; @@ -114,7 +123,7 @@ .profile-popup, .profile-popup tr, .profile-popup th, .profile-gravatar, .newuser, .roomcard, .seWrapper, h2.index.header, .privilege-table-row:hover, .list-originals .item.hover, - .list-originals .body-summary, .review-instructions-reason { + .list-originals .body-summary, .review-instructions-reason, .room-mini { background-color: #222 !important; border-color: #555 !important; color: #ddd !important; @@ -127,23 +136,28 @@ -webkit-border-radius: 3px !important; border-radius: 3px !important; } + .calendar, .calendar-small, .mspark .mspbar { + background: #222 !important; + } - .ad502-room { + .ad502-room, .message.message-config .actions, .tag-container .col { background-color: #232323 !important; border: 1px solid #191919 !important; } - .rep-recent-row, .bounty, .diff-choices a:hover, div.meter, .narrow .votes, .ob-post-votes { + .rep-recent-row, .bounty, .diff-choices a:hover, div.meter, .narrow .votes, .ob-post-votes, .card { background-color: #232323 !important; color: #bbb !important; } - .answer, #system-message, .commentlist, .revision td, #hero-content, .mdhelp-tabs .selected, .tabs .selected { + .answer, #system-message, .commentlist, .revision td, #hero-content, .mdhelp-tabs .selected, .tabs .selected, + .rep-card .rep-col { background: #232323 !important; color: #999 !important; } - .tagged-interesting, .tagged-interesting .views, .highlight-row, .highlighted { + .tagged-interesting, .tagged-interesting .views, .highlight-row, .highlighted, .card.rep-card .graph, + .popup-badges .badge-progress:hover:not(.completed) { background-color: #242424 !important; background-image: none !important; } @@ -151,12 +165,13 @@ .nav li, .seNav, .topbar a.topbar-icon-on, .topbar a.topbar-icon-on:hover, .owner, .nav a, .module li.current, .seCurrent, .community-bulletin, .owner-revision td, .markdown-diff .skip, #footer .container, .body-diffs .skip, .newsletter-anon, .tag-suggestions>div:hover, - .topbar-dialog .modal-content li:hover, .timestamp:hover+div.message .meta, div.message:hover .meta { + .topbar-dialog .modal-content li:hover, .timestamp:hover+div.message .meta, div.message:hover .meta, + #side-menu ul li a:hover, .conversation-info, .message.reply-parent, .message.reply-child { background-color: #333 !important; } .owner-answer, .question-status, .notification, #feed-ticker, #top-menu, .vote-revision td, - .topbar-dialog .unread-item { + .topbar-dialog .unread-item, .privileges-wrapper .stroke, .progress-bar .bar { background: #404040 !important; } @@ -172,8 +187,8 @@ } /* === Brown(ish) === */ - .new-post-activity, #new-answer-activity { - background-color: #840 !important; + .new-post-activity, #new-answer-activity, .val-info, .highlight { + background-color: #321 !important; } /* chat room buttons */ @@ -182,15 +197,17 @@ color: #eee !important; } - .supernovabg, .hotbg, .nav li.youarehere a, .nav a:hover, a.button:hover { - background-color: #d80 !important; - } - /* === Green === */ - .accepted-answer, .suggested-edit .inserted, .markdown-diff .inserted { + .accepted-answer, .suggested-edit .inserted, .markdown-diff .inserted, .rep-increase, .progress-bar .percent, + .recommended, .vote.accepted { background: #232 !important; } + /* accepted answer code blocks */ + .accepted-answer pre, .accepted-answer code, .accepted-answer .pln, .accepted-answer .youarehere { + background: #202A20 !important; + } + .answered, .answer-votes, .answered .vote-count-post { background: #232323 !important; color: #4b553c !important @@ -221,7 +238,7 @@ /* === Transparent background === */ div.message .meta, .spaces, .comment, span.feed-icon, a.role-switch, .nav.careers li, .nav.careers li:hover, - .switcher-nudge-content p, #content, #tabs a, #chat .username, #chat .messages { + .switcher-nudge-content p, #content, #tabs a, .tabs a, #chat .username, #chat .messages, .tag-container { background-color: transparent !important; } @@ -244,29 +261,50 @@ border-color: #333 !important; } - #tabs a.youarehere { - border-bottom: 1px solid #191919 !important; + .message .message-tip-top-right:before, .message .message-tip-top-left:before { + border-bottom-color: #191919 !important; + } + + .left-arrow { + border-right-color: rgba(119,119,119,0.4) !important; + } + .previous-button:hover .left-arrow { + border-right-color: #c0c0c0 !important; + } + .right-arrow { + border-left-color: rgba(119,119,119,0.4) !important; + } + .next-button:hover .right-arrow { + border-left-color: #c0c0c0 !important; } /* === No/hide border === */ div.list > div { border-right: 0 !important; } - - .module { + .module, .tabs a, div.message { border-color: transparent !important; } + .left-arrow, .right-arrow { + border-bottom-color: transparent !important; + border-top-color: transparent !important; + } + div.message:hover, .timestamp:hover + div.message { + visibility: inherit; + border: 1px dotted #333; + } /* blue label count */ - .bounty-indicator-tab { - background: #07d !important; + .bounty-indicator-tab, .hero.profile { + background: #046 !important; color: #ccc !important; } /* === Text Color === */ div, input, .accepted-answer .post-text, .accepted-answer .user-action-time, #question-header a, .post-text, .user-info, .topbar-dialog .header h3, .topbar-dialog .header h3 a, .topbar-dialog span, - .search-result .answered .vote-count-post strong, .votes-cast-stats th, .subheader h1 { + .search-result .answered .vote-count-post strong, .votes-cast-stats th, .subheader h1, .vote.accepted, + .message.message-config h1, .message.message-config h2, .message.message-config h3, .message.message-config h4 { color: #ddd !important; } @@ -284,9 +322,13 @@ } .comment, #top-menu a, .subheader a, .reputation a, .reputation-score, a:visited, .relativetime.old, - .votes-cast-stats td, .mini-counts span, #chat .system-message { + .votes-cast-stats td, .mini-counts span, #chat .system-message, .card .rep, a.badge, a.badge-tag, + .user-card .user-stats .number, .user-card .user-card-name { color: #aaa !important; } + .ob-post-tag, .ob-user-tag { + color: #999 !important; + } .answered-accepted strong, .youarehere, .nav .primarynav li a, .nav a, a:hover, .rep-up.special-rep { color: #fff !important @@ -340,14 +382,19 @@ white-space: nowrap !important } + .tag-container .col { + margin: 0 !important; + border: #333 1px solid !important; + } + .tag-container.row { + margin: 2px !important; + } .stats { margin-top: 5px !important; } - #hsearch, .statscontainer { margin-right: 5px !important; } - .stats { margin-bottom: 4px !important; } @@ -367,10 +414,19 @@ a.badge[title^="gold"], a.badge-tag[title^="gold"], .badge1 + .badgecount { color: #ffcc46 !important; } - .badge-tag { + .badge-tag, a.tag, .ob-post-tag, .ob-user-tag { background-color: #191919 !important; border-color: #111 !important; } + .badge3-alternate, .progress-bar.badge-3 .bar .percent { + background-color: #7C4318 !important; /* bronze */ + } + .badge2-alternate, .progress-bar.badge-2 .bar .percent { + background-color: #464a4f !important; /* silver */ + } + .badge1-alternate, .progress-bar.badge-1 .bar .percent { + background-color: #957000 !important; /* gold */ + } /* === code & syntax highlighting === */ pre, code, .pln, .youarehere { diff --git a/dwb/userstyles/trakt.tv.css b/dwb/userstyles/trakt.tv.css index 9df8fbf..12243c2 100644 --- a/dwb/userstyles/trakt.tv.css +++ b/dwb/userstyles/trakt.tv.css @@ -41,10 +41,33 @@ section { background-color: #222222 !important; } +/* always show search */ +/* +header#top-nav #header-search #header-search-query { + padding: 7px 12px !important; + width: 250px !important; +} + +header#top-nav #header-search #header-search-type { + opacity: 1 !important; +} + +header#top-nav #header-search #header-search-button { + opacity: 0 !important; +} */ + .comment-wrapper { background-color: #1d1d1d !important; } +.above-comment { + background-color: #252525 !important; +} + +.new-comment-wrapper textarea { + background-color: #2f2f2f !important; +} + .panel, .form-control { background-color: #1d1d1d !important; } diff --git a/dwb/userstyles/xkcd.com.css b/dwb/userstyles/xkcd.com.css new file mode 100644 index 0000000..f06fd87 --- /dev/null +++ b/dwb/userstyles/xkcd.com.css @@ -0,0 +1,31 @@ +:not(img) { + background-color: rgba(34, 34, 34, 0.5) ! important; + background-image: none !important; + color: #D4D2CF ! important; +} + +body, html { + background-color: #222222 ! important; + background-image: none !important; +} + +.dwb_hint { + background-color: #222222 ! important; +} + +:link, :link * { + color: #5DC3D7 !important; +} + +:visited, :visited * { + color: #666665 !important; +} + +.tagContainer { + display: none; +} + +img.illustration { + -webkit-filter: invert(100%) !important; + background-color: transparent !important; +} diff --git a/flexget/config.yml b/flexget/config.yml index 0eba784..baaa975 100644 --- a/flexget/config.yml +++ b/flexget/config.yml @@ -32,15 +32,11 @@ templates: # {{{1 usenet-movies: # {{{2 - set: - category: 'movies' inputs: - rss: { url: 'https://www.usenet-crawler.com/rss?t=2040&dl=1&num=100{{secrets.crawler.api}}', silent: yes } # Movies HD usenet-tv: # {{{2 - set: - category: 'tv' inputs: - rss: { url: 'https://www.usenet-crawler.com/rss?t=5030,5040&dl=1&num=100{{secrets.crawler.api}}', silent: yes } # TV SD/HD @@ -73,9 +69,29 @@ templates: # {{{1 - \b Go\): {from: title} # filter those misplaced french only movies - tv: # {{{2 + series: # {{{2 + set: + category: 'series' + series: + settings: + default: &default_settings + identified_by: ep + timeframe: 12 hours + target: 1080p webdl h264+ + quality: 480p+ h264+ + upgrade: yes + exists_series: + path: + - '/mnt/Skaro/Series/{{tvdb_series_name}}' + allow_different_qualities: better + content_size: + min: 100 + max: 6000 + strict: yes + + series-list: # {{{2 series: - normal: + default: - 8 out of 10 cats - american dad - archer 2009 @@ -115,11 +131,40 @@ templates: # {{{1 - the wire: { quality: 720p+ } + series-trakt: # {{{2 + configure_series: + from: + trakt_list: + username: Ram-Z + list: followlist + type: shows + settings: *default_settings + + + series-trakt-backfill: # {{{2 + configure_series: + from: + trakt_list: + username: Ram-Z + list: backfill + type: episodes + settings: # *default_settings + identified_by: ep + quality: 720p+ h264+ + discover: + interval: 1 hours + what: + - emit_series: + from_start: yes + from: + - newznab: + url: 'https://www.usenet-crawler.com/api?apikey={{secrets.crawler.apikey}}&t=tvsearch&cat=5030,5040&extended=1' + category: tv + + movies: # {{{2 - imdb: - min_score: 7.5 - min_votes: 30000 - imdb_required: on + set: + category: 'movies' exists_movie: path: - '/mnt/Skaro/Movies' @@ -128,10 +173,31 @@ templates: # {{{1 lookup: imdb - queued-movies: # {{{2 + movies-imdb: # {{{2 + imdb: + min_score: 7.5 + min_votes: 30000 + imdb_required: on + + + movies-1080p: # {{{2 + quality: 1080p bluray+ h264+ + content_size: + min: 3000 + max: 15000 + strict: yes + + + movies-720p: # {{{2 + quality: 720p+ webdl+ h264+ + delay: 14 days + content_size: + min: 1000 + max: 10000 + strict: yes + + movies-discover-queue: # {{{2 movie_queue: accept - set: - category: 'movies' discover: what: - emit_movie_queue: yes @@ -139,87 +205,121 @@ templates: # {{{1 - newznab: url: 'https://www.usenet-crawler.com/api?apikey={{secrets.crawler.apikey}}&t=movie&extended=1&cat=2040' category: movie - interval: 5 seconds + interval: 7 days # search each entry only once a week + + + trakt-add-collection: # {{{2 + trakt_add: + username: '{{secrets.trakt.login}}' + password: '{{secrets.trakt.passw}}' + list: collection tasks: # {{{1 - dl-tv: # {{{2 + dl-series: # {{{2 priority: 100 template: - email - - tv + - series + - series-list + - series-trakt - filters - usenet - usenet-tv - series: - settings: - normal: - timeframe: 12 hours - target: 1080p webdl h264+ - quality: 480p+ h264+ - upgrade: yes - exists_series: - path: '/mnt/Skaro/Series/{{tvdb_series_name}}' - allow_different_qualities: better - content_size: - min: 100 - max: 6000 - strict: yes - dl-movie-queue-1080p: # {{{2 + dl-series-trakt-backfill: # {{{2 + priority: 110 + template: + - series + - series-trakt-backfill + - filters + - usenet + digest: backfill + + + dl-movies-trakt: # {{{2 + priority: 10 + trakt_list: + username: Ram-Z + list: watchlist + type: movies + accept_all: yes + movie_queue: add + + + dl-movies-discover-queue-1080p: # {{{2 priority: 100 template: - email - - queued-movies + - movies + - movies-discover-queue + - movies-1080p - filters - usenet - quality: 1080p bluray+ h264+ - dl-movie-queue-720p: # {{{2 + dl-movies-discover-queue-720p: # {{{2 priority: 110 template: - email - - queued-movies + - movies + - movies-discover-queue + - movies-720p - filters - usenet - quality: 720p+ webdl+ h264+ - delay: 14 days - dl-movies-1080p: # {{{2 + dl-movies-queue-1080p: # {{{2 + priority: 100 + template: + - email + - movies + - movies-1080p + - filters + - usenet + - usenet-movies + + + dl-movies-queue-720p: # {{{2 + priority: 110 + template: + - email + - movies + - movies-720p + - filters + - usenet + - usenet-movies + + + dl-movies-imdb-1080p: # {{{2 priority: 120 template: - email - movies + - movies-imdb + - movies-1080p - filters - usenet - usenet-movies - quality: 1080p webdl+ h264+ - content_size: - min: 3000 - max: 15000 - strict: yes - dl-movies-720p: # {{{2 + dl-movies-imdb-720p: # {{{2 priority: 130 template: - email - movies + - movies-imdb + - movies-720p - filters - usenet - usenet-movies - quality: 720p+ webdl+ h264+ - delay: 14 days - content_size: - min: 1000 - max: 10000 - strict: yes - move-tv: # {{{2 + move-series: # {{{2 + manual: yes + template: + - trakt-add-collection seen: local disable: - retry_failed @@ -240,6 +340,7 @@ tasks: # {{{1 all_series: parse_only: yes accept_all: yes + require_field: tvdb_series_name set: destination: '/mnt/Skaro/Series' @@ -251,13 +352,13 @@ tasks: # {{{1 clean_source: 100 # removes dir if < [N] MB exec: echo "<<<{{folder}}/{{filename}}>>>" - email: - from: flexget@tardis - to: ramsi@localhost - template: move + digest: move-tasks move-movies: # {{{2 + manual: yes + template: + - trakt-add-collection seen: local disable: - retry_failed @@ -275,7 +376,16 @@ tasks: # {{{1 - '[Ss]ample' imdb_lookup: yes + if: + - movie_name is None: + manipulate: + - title: + extract: '([^/]*)/[^/]*$' + from: location + imdb_lookup: yes + accept_all: yes + require_field: imdb_name set: destination: '/mnt/Skaro/Movies' @@ -286,18 +396,45 @@ tasks: # {{{1 clean_source: 100 # removes dir if < [N] MB exec: echo "<<<{{filename}}>>>" + digest: move-tasks + + + daily-mail: # {{{2 + manual: yes + no_entries_ok: yes + emit_digest: + list: move-tasks + seen: local + accept_all: yes email: from: flexget@tardis to: ramsi@localhost template: move - seed-tv-db: # {{{2 + backfill-mail: # {{{2 + priority: 500 + manual: yes + template: + - email + no_entries_ok: yes + emit_digest: + list: backfill + seen: local + accept_all: yes + + + seed-trakt-series: # {{{2 manual: yes + seen: local + template: + - seed-search + - trakt-add-collection find: - path: '/mnt/Skaro/Series' - regexp: '.*\.(avi|mkv|mp4|webm)$' + path: + - '/mnt/Skaro/Series' + regexp: '.*\.(avi|mkv|mp4|webm|m4v)$' recursive: yes manipulate: @@ -315,17 +452,46 @@ tasks: # {{{1 regexp: '[\(\)\{\}]' format: ' ' + metainfo_series: yes + thetvdb_lookup: yes all_series: yes assume_quality: 480p + accept_all: yes + require_field: + - tvdb_id + + seed-trakt-movies: # {{{2 + manual: yes + seen: local + template: + - trakt-add-collection + seen: local + find: + path: + - '/mnt/Skaro/Movies' + regexp: '.*\.(avi|mkv|mp4|webm|m4v)$' + recursive: yes + imdb_lookup: yes + accept_all: yes require_field: - - series_name + - imdb_id schedules: # {{{1 + - tasks: ['daily-mail'] + schedule: + hour: '17' + minute: '00' + - tasks: ['dl-*'] schedule: hour: '*' minute: '48' + - tasks: ['backfill-mail'] + schedule: + hour: '*' + minute: '48' + # vim: sts=2 ts=2 sw=2 et diff --git a/git/config b/git/config index 911ad2c..21d2ea6 100644 --- a/git/config +++ b/git/config @@ -1,6 +1,6 @@ [user] name = Samir Benmendil - email = samir.benmendil@gmail.com + email = me@rmz.io [color] branch = auto status = auto @@ -26,3 +26,5 @@ defaultToUpstream = true [mergetool] prompt = no +[rebase] + autostash = true diff --git a/mpv/config b/mpv/config index 025f82b..5958775 100644 --- a/mpv/config +++ b/mpv/config @@ -1,5 +1,6 @@ # default ytdl +ytdl-format=[height<=720] cache=auto cache-default=50000 cache-initial=100 diff --git a/msmtprc b/msmtprc index 75b5d98..e280535 100644 --- a/msmtprc +++ b/msmtprc @@ -9,13 +9,11 @@ host smtp.gmail.com port 587 protocol smtp auth on -from samir.benmendil@gmail.com user samir.benmendil@gmail.com password # unimaas inherits from gmail account unimaas : gmail -from s.benmendil@student.maastrichtuniversity.nl #set default account account default : gmail diff --git a/mutt/colors b/mutt/colors index 102dd0b..bbc3b9e 100644 --- a/mutt/colors +++ b/mutt/colors @@ -6,7 +6,6 @@ color normal white default color status green default -color sidebar cyan default color indicator brightwhite blue color tree blue default color error brightred default @@ -19,7 +18,6 @@ color index cyan default ~P color index brightblue default "~(~N)" # new messages + sidebar color index brightyellow default "~N" -color sidebar_new brightyellow default # threads containing old messages color index blue default "~(~O)" # old messages diff --git a/mutt/muttrc b/mutt/muttrc index 83e7b9b..a5c2bdf 100644 --- a/mutt/muttrc +++ b/mutt/muttrc @@ -62,14 +62,6 @@ unignore from: to: cc: date: subject: x-clacks-overhead: unhdr_order * hdr_order from: to: cc: date: subject: x-clacks-overhead: -# sidebar -set sidebar_width = 14 -set sidebar_visible = no -set sidebar_delim = '│' -set sidebar_sort = no -set sidebar_shortpath = yes -set sidebar_format = "%B%* %?N?%N?" - # deal with crap set mailcap_path = ~/.mutt/mailcap auto_view text/html # view html automatically diff --git a/ranger/rc.conf b/ranger/rc.conf index 1569492..04abbd0 100644 --- a/ranger/rc.conf +++ b/ranger/rc.conf @@ -141,7 +141,7 @@ set padding_right false # command :get_cumulative_size or typing "dc". The size is expensive to # calculate and will not be updated automatically. You can choose # to update it automatically though by turning on this option: -#set autoupdate_cumulative_size false +set autoupdate_cumulative_size false # Turning this on makes sense for screen readers: #set show_cursor false diff --git a/ranger/rifle.conf b/ranger/rifle.conf index 79881ca..7cf2654 100644 --- a/ranger/rifle.conf +++ b/ranger/rifle.conf @@ -130,12 +130,13 @@ mime ^video, terminal, !X, has mplayer = mplayer -- "$@" #------------------------------------------- # Image Viewing: #------------------------------------------- -mime ^image, has eog, X, flag f = eog -- "$@" -mime ^image, has sxiv, X, flag f = sxiv -- "$@" -mime ^image, has feh, X, flag f = feh -- "$@" -mime ^image, has mirage, X, flag f = mirage -- "$@" -mime ^image, has gimp, X, flag f = gimp -- "$@" -ext xcf, X, flag f = gimp -- "$@" +ext svg, has inkscape, X, flag f = inkscape -- "$@" +mime ^image, has eog, X, flag f = eog -- "$@" +mime ^image, has sxiv, X, flag f = sxiv -- "$@" +mime ^image, has feh, X, flag f = feh -- "$@" +mime ^image, has mirage, X, flag f = mirage -- "$@" +mime ^image, has gimp, X, flag f = gimp -- "$@" +ext xcf, has gimp, X, flag f = gimp -- "$@" #------------------------------------------- # Documents diff --git a/tmux.conf b/tmux.conf index 32d4fa3..000fb30 100644 --- a/tmux.conf +++ b/tmux.conf @@ -3,4 +3,38 @@ set -g utf8 on set -g set-titles on set -g mouse-utf8 on -new -s weechat -n weechat weechat +set -g mode-keys vi + +bind Escape copy-mode +unbind p +bind p paste-buffer +bind -t vi-copy 'v' begin-selection +bind -t vi-copy 'y' copy-selection +bind -t vi-copy 'Space' halfpage-down +bind -t vi-copy 'Bspace' halfpage-up + +# extra commands for interacting with the ICCCM clipboard +bind C-c run "tmux save-buffer - | xclip -i -sel clipboard" +bind C-v run "tmux set-buffer \"$(xclip -o -sel clipboard)\"; tmux paste-buffer" + +# easy-to-remember split pane commands +bind | split-window -h +bind - split-window -v +unbind '"' +unbind % + +# moving between panes with vim movement keys +bind h select-pane -L +bind j select-pane -D +bind k select-pane -U +bind l select-pane -R + +# moving between windows with vim movement keys +bind -r C-h select-window -t :- +bind -r C-l select-window -t :+ + +# resize panes with vim movement keys +bind -r H resize-pane -L 5 +bind -r J resize-pane -D 5 +bind -r K resize-pane -U 5 +bind -r L resize-pane -R 5 diff --git a/vim/filetype.vim b/vim/filetype.vim index 9ba5826..9dfce86 100644 --- a/vim/filetype.vim +++ b/vim/filetype.vim @@ -7,6 +7,7 @@ augroup END augroup ft_ros autocmd! BufNewFile,BufRead */ros/*.py setfiletype python.rospy + autocmd! BufNewFile,BufRead */ros/*.cfg setfiletype python.roscfg autocmd! BufNewFile,BufRead */ros/*.cpp setfiletype cpp.roscpp autocmd! BufNewFile,BufRead */ros/*.h setfiletype cpp.roscpp autocmd! BufNewFile,BufRead */ros/*.cfg setfiletype python.roscfg diff --git a/vim/ftplugin/help.vim b/vim/ftplugin/help.vim index 1432ebb..c79df7a 100644 --- a/vim/ftplugin/help.vim +++ b/vim/ftplugin/help.vim @@ -4,3 +4,4 @@ setlocal sidescroll=0 setlocal sidescrolloff=0 wincmd L vertical resize 78 +normal ze diff --git a/vim/ultisnips/PKGBUILD.snippets b/vim/ultisnips/PKGBUILD.snippets index b18ae81..6f0ce75 100644 --- a/vim/ultisnips/PKGBUILD.snippets +++ b/vim/ultisnips/PKGBUILD.snippets @@ -1,33 +1,58 @@ snippet pkgver "pkgver() function" b pkgver() { - cd ${1:$pkgname-$pkgver} - ( set -o pipefail - git describe --long --tags 2>/dev/null | sed 's/\([^-]*-g\)/r\1/;s/-/./g' || - printf "r%s.%s" "$(git rev-list --count HEAD)" "$(git rev-parse --short HEAD)" - ) + cd ${1:$pkgname-$pkgver} + ( set -o pipefail + git describe --long --tags 2>/dev/null | sed 's/\([^-]*-g\)/r\1/;s/-/./g' || + printf "r%s.%s" "$(git rev-list --count HEAD)" "$(git rev-parse --short HEAD)" + ) } endsnippet snippet prep "prepare() function" b prepare() { - cd ${1:$pkgname-$pkgver} - $0 + cd ${1:$pkgname-$pkgver} + $0 } endsnippet snippet build "build() function" b build() { - cd ${1:$pkgname-$pkgver} - ./configure \ - --prefix=/usr $2 - $0 + cd ${1:$pkgname-$pkgver} + ./configure \ + --prefix=/usr \ + --libexecdir=/usr/bin \ + --libdir=/usr/lib \ + --sysconfdir=/etc \ + --localstatedir=/var \ + --disable-static $2 + make + $0 +} +endsnippet + +snippet build32 "Standard lib32 make" b +build() { + export CC="gcc -m32" + export CXX="g++ -m32" + export PKG_CONFIG_PATH="/usr/lib32/pkgconfig" + + cd ${1:$pkgname-$pkgver} + ./configure \ + --prefix=/usr \ + --libdir=/usr/lib32 \ + --sysconfdir=/etc \ + --localstatedir=/var \ + --disable-static $2 + make } endsnippet snippet pack "package() function" b package() { - cd ${1:$pkgname-$pkgver} - make DESTDIR="$pkgdir" install - $0 + cd ${1:$pkgname-$pkgver} + make DESTDIR="$pkgdir" install + $0 } endsnippet + +# vim:set ft=snippets: diff --git a/vim/ultisnips/all.snippets b/vim/ultisnips/all.snippets index 1908d71..7b779f6 100644 --- a/vim/ultisnips/all.snippets +++ b/vim/ultisnips/all.snippets @@ -168,7 +168,7 @@ snippet AGPL3 "AGPL3 License" b ${0} endsnippet -snippet GMGPL linking exception "GMGPL linking exception License" b +snippet GMGPL "GMGPL linking exception License" b `!p snip.rv = b` `!p snip.rv = i + m` As a special exception, if other files instantiate generics from `!p snip.rv = i + m` this unit, or you link this unit with other files to produce an diff --git a/vim/ultisnips/roscfg.snippets b/vim/ultisnips/roscfg.snippets new file mode 100644 index 0000000..4766e2d --- /dev/null +++ b/vim/ultisnips/roscfg.snippets @@ -0,0 +1,3 @@ +snippet add "Add a new reconfigure parameter" b +gen.add("${1:Name}", ${2:int_t}, ${3:0}, "${4:$1}", default=${5:None}, min=${6:None}, max=${7:None}) +endsnippet diff --git a/vim/ultisnips/rospy.snippets b/vim/ultisnips/rospy.snippets new file mode 100644 index 0000000..e303186 --- /dev/null +++ b/vim/ultisnips/rospy.snippets @@ -0,0 +1,19 @@ +snippet debug "Log Debug" b +rospy.logdebug(${0:"message"}) +endsnippet + +snippet info "Log Info" b +rospy.loginfo(${0:"message"}) +endsnippet + +snippet warn "Log Warning" b +rospy.logwarn(${0:"message"}) +endsnippet + +snippet err "Log Error" b +rospy.logerr(${0:"message"}) +endsnippet + +snippet fatal "Log Fatal" b +rospy.logfatal(${0:"message"}) +endsnippet diff --git a/vim/ultisnips/sh.snippets b/vim/ultisnips/sh.snippets index ff10449..1ea5c21 100644 --- a/vim/ultisnips/sh.snippets +++ b/vim/ultisnips/sh.snippets @@ -26,7 +26,7 @@ function usage () # Parse arguments declare -a args -while [[ $# > 0 ]]; do +while [[ $# -gt 0 ]]; do opt="\$1" case $opt in @@ -36,7 +36,7 @@ while [[ $# > 0 ]]; do echo -e "\n Option does not exist : $opt\n" usage; exit 1 ;; - *) args+=($opt); shift ;; + *) args+=("$opt"); shift ;; esac done endsnippet diff --git a/vim/vimrc b/vim/vimrc index 3905add..65242d4 100644 --- a/vim/vimrc +++ b/vim/vimrc @@ -29,6 +29,8 @@ Plugin 'raimondi/delimitmate' " Plugin 'rking/ag.vim' Plugin 'scrooloose/nerdtree' Plugin 'scrooloose/syntastic' +Plugin 'shougo/vimproc.vim' +Plugin 'shougo/unite.vim' Plugin 'sjl/gundo.vim' Plugin 'tomtom/tcomment_vim' Plugin 'tpope/vim-endwise' @@ -63,8 +65,7 @@ Plugin 'justinmk/vim-sneak' Plugin 'chrisbra/checkattach' Plugin 'nathanaelkane/vim-indent-guides' Plugin 'alx741/vinfo' -Plugin 'shougo/vimproc.vim' -Plugin 'shougo/unite.vim' +Plugin 'vim-scripts/mediawiki.vim' " remove entries first set runtimepath -=$HOME/.vim @@ -100,7 +101,7 @@ set showbreak=↪ " show these chars for wrapped lines set lazyredraw " don't redraw while executing macros set list " show chars defined in 'listchars' -set listchars=tab:▸\ " list of strings used for list mode +set listchars=tab:❭\ " list of strings used for list mode set listchars+=extends:❯,precedes:❮ " Only shown when not in insert mode augroup trailing @@ -313,6 +314,8 @@ nmap # :%s:/::gn " center cursor after search and open folds nnoremap n nzzzv nnoremap N Nzzzv +nnoremap ^O ^Ozzzv +nnoremap ^I ^Izzzv " same when jumping around nnoremap g; g;zzzv @@ -381,10 +384,13 @@ map Q gq " break undo sequence before removing word inoremap u -nmap b :set expandtab tabstop=4 shiftwidth=4 softtabstop=4 -nmap B :set expandtab tabstop=8 shiftwidth=8 softtabstop=4 -nmap M :set noexpandtab tabstop=8 softtabstop=4 shiftwidth=4 -nmap m :set expandtab tabstop=2 shiftwidth=2 softtabstop=2 +nnoremap coe :set =&expandtab ? 'noexpandtab' : 'expandtab' +nnoremap [oe :set expandtab +nnoremap ]oe :set noexpandtab + +for idt in range(1,8) + exe 'nnoremap co'.idt.' :set tabstop='.idt.' shiftwidth='.idt.' softtabstop='.idt.'' +endfor " space will toggle current fold in normal mode nnoremap za @@ -428,7 +434,7 @@ autocmd BufReadPost fugitive://* set bufhidden=delete nnoremap gs :Gstatus nnoremap gd :Gdiff -nnoremap gc :tab Gcommit -v +nnoremap gc :Gcommit -v nnoremap ga :Gwrite nnoremap gb :Gblame @@ -517,23 +523,44 @@ call unite#custom#profile('default', 'context', { \ 'direction': 'botright' \ }) +nnoremap [unite] +nmap u [unite] + +" unite-grep {{{3 " seems not respected let g:unite_source_grep_max_candidates = 2000 if executable('ag') - " Use ag in unite rec source - let g:unite_source_rec_async_command = 'ag --follow --nocolor --nogroup --hidden -g ""' " Use ag in unite grep source. let g:unite_source_grep_command = 'ag' let g:unite_source_grep_default_opts = '--smart-case -w --vimgrep --hidden --ignore ''.hg'' --ignore ''.svn'' --ignore ''.git'' --ignore ''.bzr''' let g:unite_source_grep_recursive_opt = '' end +nnoremap [unite]a :Unite grep -input= -nnoremap [unite] -nmap u [unite] +" unite-file_rec {{{3 +if executable('ag') + " Use ag in unite rec source + let g:unite_source_rec_async_command = 'ag --follow --nocolor --nogroup --hidden -g ""' +end nnoremap [unite]f :Unite -start-insert file_rec/async + +" unite-buffer {{{3 call unite#custom#default_action('buffer', 'goto') nnoremap [unite]b :Unite buffer -nnoremap [unite]a :Unite grep -input= + +" unite-menu {{{3 +let g:unite_source_menu_menus = {} +let g:unite_source_menu_menus.fugitive = { 'description' : 'fugitive menu'} +let g:unite_source_menu_menus.fugitive.command_candidates = { + \ 'Gstatus gs' : 'Gstatus', + \ 'Gcommit -v gc' : 'Gcommit -v', + \ 'Glog' : 'Glog', + \} + +nnoremap gg :Unite menu:fugitive + +let g:unite_source_history_yank_enable = 1 +nnoremap [unite]p :Unite history/yank " yankring {{{2 nnoremap p :YRShow @@ -616,7 +643,7 @@ nmap ev :call EditConfig('vimrc') nmap ef :call EditConfig('ftplugin') nmap es :call EditConfig('syntax') nmap ei :call EditConfig('indent') -nmap eu :UltiSnipsEdit +nmap eu :UltiSnipsEdit:lcd %:p:h " spell check {{{2 " http://tex.stackexchange.com/a/52932 diff --git a/wakeonlan/gallifrey b/wakeonlan/gallifrey new file mode 100644 index 0000000..2fc5ed3 --- /dev/null +++ b/wakeonlan/gallifrey @@ -0,0 +1 @@ +F4:6D:04:AD:A1:0F 192.168.1.0/24 diff --git a/wakeonlan/shada b/wakeonlan/shada new file mode 100644 index 0000000..ab50032 --- /dev/null +++ b/wakeonlan/shada @@ -0,0 +1 @@ +1c:6f:65:3f:48:9a 192.168.1.0/24 diff --git a/xkb/symbols/dvorak b/xkb/symbols/dvorak index 2195784..e351fab 100644 --- a/xkb/symbols/dvorak +++ b/xkb/symbols/dvorak @@ -14,7 +14,7 @@ xkb_symbols "default" { //{{{1 key { [ parenright, 0 ] }; key { [ bracketleft, braceleft ] }; key { [ bracketright, braceright, dead_tilde, NoSymbol ] }; - key { [ BackSpace, BackSpace ] }; + key { [ BackSpace, BackSpace, Delete, Delete ] }; // 2nd Row {{{2 key { [ Tab, ISO_Left_Tab ] }; @@ -66,7 +66,7 @@ xkb_symbols "default" { //{{{1 key { [ Control_L ] }; key { [ Alt_L ] }; key { [ Super_L ] }; - key { [ space ] }; + key { [ space, space, Delete, Delete ] }; key { [ Super_R ] }; key { [ ISO_Level3_Shift ] }; key { [ Control_R ] }; diff --git a/zsh/aliases/misc.zsh b/zsh/aliases/misc.zsh index 88abc76..aebe4a6 100644 --- a/zsh/aliases/misc.zsh +++ b/zsh/aliases/misc.zsh @@ -1,2 +1,4 @@ function info() { vim -c "Vinfo $1" -c "only" } compdef _texinfo info=info + +alias cdtmp='cd $(mktemp -d)' diff --git a/zsh/lib/00-key-bindings.zsh b/zsh/lib/00-key-bindings.zsh index 803ec37..7fd00e5 100644 --- a/zsh/lib/00-key-bindings.zsh +++ b/zsh/lib/00-key-bindings.zsh @@ -1,33 +1,59 @@ -# TODO: Explain what some of this does.. +bindkey -v -bindkey -e -bindkey -s '\el' "ls\n" -bindkey '\ew' kill-region -bindkey '^r' history-incremental-search-backward -bindkey "^[[5~" up-line-or-history -bindkey "^[[6~" down-line-or-history +bindkey '^N' history-search-forward +bindkey '^P' history-search-backward +bindkey ' ' magic-space # also do history expansion on space -# make search up and down work, so partially type and hit up/down to find relevant stuff -bindkey '^[[A' up-line-or-search # up arrow -bindkey '^[[B' down-line-or-search # down arrow - -bindkey "^[[H" beginning-of-line -bindkey "^[[1~" beginning-of-line -bindkey "^[OH" beginning-of-line -bindkey "[7~" beginning-of-line -bindkey "^[[F" end-of-line -bindkey "^[[4~" end-of-line -bindkey "[8~" end-of-line -bindkey "^[OF" end-of-line -bindkey ' ' magic-space # also do history expansion on space - -bindkey "^[[1;5C" forward-word -bindkey "^[[1;5D" backward-word +bindkey -s '^[l' 'ls ' # show dir content bindkey '^[[Z' reverse-menu-complete +bindkey -M vicmd 'v' edit-command-line + +# delay after ESC (in 0.01s) +export KEYTIMEOUT=40 + +# emacs bindings +bindkey '^A' beginning-of-line +bindkey '^B' backward-char +bindkey '^E' end-of-line +bindkey '^F' edit-command-line +bindkey '^G' list-expand +bindkey '^O' accept-line-and-down-history +bindkey '^Q' push-input +bindkey '^?' backward-delete-char +bindkey '^H' backward-delete-char +bindkey '^W' backward-kill-word +bindkey '^X=' what-cursor-position +bindkey '^[.' insert-last-word +bindkey '^[?' which-command +bindkey '^[A' accept-and-hold +bindkey '^[a' accept-and-hold +bindkey '^[C' capitalize-word +bindkey '^[c' capitalize-word +bindkey '^[H' run-help +bindkey '^[h' run-help +bindkey '^[T' transpose-words +bindkey '^[t' transpose-words + +# make search up and down work, so partially type and hit up/down to find relevant stuff +bindkey '^[[A' up-line-or-search # up arrow +bindkey '^[[B' down-line-or-search # down arrow +bindkey '^[[5~' up-line-or-history # PgUp +bindkey '^[[6~' down-line-or-history # PgDown + +bindkey '^[OA' up-line-or-history +bindkey '^[OB' down-line-or-history +bindkey '^[OC' forward-char +bindkey '^[OD' backward-char +bindkey '^[OF' end-of-line +bindkey '^[OH' beginning-of-line + +bindkey '' forward-word +bindkey '' backward-word + # Make the delete key (or Fn + Delete on the Mac) work instead of outputting a ~ bindkey '^?' backward-delete-char -bindkey "^[[3~" delete-char -bindkey "^[3;5~" delete-char -bindkey "\e[3~" delete-char +bindkey '^[[3~' delete-char +bindkey '^[3;5~' delete-char +bindkey '\e[3~' delete-char diff --git a/zsh/lib/fzf.zsh b/zsh/lib/fzf.zsh index fdeb0b8..6f0b81f 100755 --- a/zsh/lib/fzf.zsh +++ b/zsh/lib/fzf.zsh @@ -47,7 +47,7 @@ bindkey '^T' fzf-file-widget # ALT-C - cd into the selected directory fzf-cd-widget() { - cd "${$(command find -L . \( -path '*/\.*' -o -fstype 'dev' -o -fstype 'proc' \) -prune \ + cd "${$(command find -L . -xdev \( -path '*/\.*' -o -fstype 'dev' -o -fstype 'proc' \) -prune \ -o -type d -print 2> /dev/null | sed 1d | cut -b3- | fzf +m):-.}" zle reset-prompt } diff --git a/zsh/lib/git.zsh b/zsh/lib/git.zsh deleted file mode 100644 index bffd284..0000000 --- a/zsh/lib/git.zsh +++ /dev/null @@ -1,100 +0,0 @@ -# get the name of the branch we are on -function git_prompt_info() { - ref=$(git symbolic-ref HEAD 2> /dev/null) || \ - ref=$(git rev-parse --short HEAD 2> /dev/null) || return - echo "$ZSH_THEME_GIT_PROMPT_PREFIX${ref#refs/heads/}$(parse_git_dirty)$ZSH_THEME_GIT_PROMPT_SUFFIX" -} - - -# Checks if working tree is dirty -parse_git_dirty() { - if [[ -n $(git status -s 2> /dev/null) ]]; then - echo "$ZSH_THEME_GIT_PROMPT_DIRTY" - else - echo "$ZSH_THEME_GIT_PROMPT_CLEAN" - fi -} - -# get the difference between the local and remote branches -git_remote_status() { - remote=${$(git rev-parse --verify ${hook_com[branch]}@{upstream} --symbolic-full-name 2>/dev/null)/refs\/remotes\/} - if [[ -n ${remote} ]] ; then - ahead=$(git rev-list ${hook_com[branch]}@{upstream}..HEAD 2>/dev/null | wc -l) - behind=$(git rev-list HEAD..${hook_com[branch]}@{upstream} 2>/dev/null | wc -l) - - if [ $ahead -eq 0 ] && [ $behind -gt 0 ] - then - echo "$ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE" - elif [ $ahead -gt 0 ] && [ $behind -eq 0 ] - then - echo "$ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE" - elif [ $ahead -gt 0 ] && [ $behind -gt 0 ] - then - echo "$ZSH_THEME_GIT_PROMPT_DIVERGED_REMOTE" - fi - fi -} - -# Checks if there are commits ahead from remote -function git_prompt_ahead() { - if $(echo "$(git log origin/$(current_branch)..HEAD 2> /dev/null)" | grep '^commit' &> /dev/null); then - echo "$ZSH_THEME_GIT_PROMPT_AHEAD" - fi -} - -# Formats prompt string for current git commit short SHA -function git_prompt_short_sha() { - SHA=$(git rev-parse --short HEAD 2> /dev/null) && echo "$ZSH_THEME_GIT_PROMPT_SHA_BEFORE$SHA$ZSH_THEME_GIT_PROMPT_SHA_AFTER" -} - -# Formats prompt string for current git commit long SHA -function git_prompt_long_sha() { - SHA=$(git rev-parse HEAD 2> /dev/null) && echo "$ZSH_THEME_GIT_PROMPT_SHA_BEFORE$SHA$ZSH_THEME_GIT_PROMPT_SHA_AFTER" -} - -# Get the status of the working tree -git_prompt_status() { - INDEX=$(git status --porcelain -b 2> /dev/null) - STATUS="" - if $(echo "$INDEX" | grep '^?? ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_UNTRACKED$STATUS" - fi - if $(echo "$INDEX" | grep '^A ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" - elif $(echo "$INDEX" | grep '^M ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" - fi - if $(echo "$INDEX" | grep '^ M ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" - elif $(echo "$INDEX" | grep '^AM ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" - elif $(echo "$INDEX" | grep '^ T ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" - fi - if $(echo "$INDEX" | grep '^R ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_RENAMED$STATUS" - fi - if $(echo "$INDEX" | grep '^ D ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" - elif $(echo "$INDEX" | grep '^D ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" - elif $(echo "$INDEX" | grep '^AD ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" - fi - if $(git rev-parse --verify refs/stash >/dev/null 2>&1); then - STATUS="$ZSH_THEME_GIT_PROMPT_STASHED$STATUS" - fi - if $(echo "$INDEX" | grep '^UU ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_UNMERGED$STATUS" - fi - if $(echo "$INDEX" | grep '^## .*ahead' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_AHEAD$STATUS" - fi - if $(echo "$INDEX" | grep '^## .*behind' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_BEHIND$STATUS" - fi - if $(echo "$INDEX" | grep '^## .*diverged' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DIVERGED$STATUS" - fi - echo $STATUS -} diff --git a/zsh/lib/misc.zsh b/zsh/lib/misc.zsh index 3de8a53..8667e83 100644 --- a/zsh/lib/misc.zsh +++ b/zsh/lib/misc.zsh @@ -12,4 +12,7 @@ setopt long_list_jobs export PAGER="less" export LESS="-SR" +# ls colors +eval $(dircolors $XDG_CONFIG_HOME/dircolors) + export LC_CTYPE=$LANG diff --git a/zsh/lib/motd.zsh b/zsh/lib/motd.zsh new file mode 100644 index 0000000..43e8152 --- /dev/null +++ b/zsh/lib/motd.zsh @@ -0,0 +1,9 @@ +autoload colors; colors; + +msg() +{ + print "$fg_bold[white]$1$reset_color\n$2\n" +} + +msg "gc --{fixup,squash} :/commitmsg " "auto constructs a '{fixup,squash}!' commit message for the last commit matching 'commitmsg'" +msg "git rebase --autosquash " "{fixup,squash} commits starting with {fixup,squash}!, must be --interactive" diff --git a/zsh/lib/prompt.zsh b/zsh/lib/prompt.zsh new file mode 100644 index 0000000..61f5db8 --- /dev/null +++ b/zsh/lib/prompt.zsh @@ -0,0 +1,116 @@ +# Setup the prompt with pretty colors +setopt prompt_subst +autoload colors; colors; + +hostcolor=green +[[ $(hostname) == "tardis" ]] && hostcolor=red + +precmd() { + PROMPT='%T %n@%{$fg[$hostcolor]%}%m%(1j. $fg_bold[white]↵%{$fg_bold[red]%}%j.)%{$reset_color%}%-0>..>$(git_prompt_status)%>> +%(?..%{$fg_bold[white]%}%?)%{$reset_color%}$(vi_prompt_info)%{%(!.$fg[red]❰.$fg[green]❱)%1G%} ' + RPROMPT='%{$fg[green]%}%~%{$reset_color%}' +} + +vi_prompt_info() { + local vicmd="$fg_bold[green]❰$reset_color%1G" + local viins="$fg_bold[blue]❱$reset_color%1G" + printf '%s' "%{${${KEYMAP/vicmd/$vicmd}/(main|viins)/$viins}%}" +} + +function zle-line-init zle-line-finish zle-keymap-select { + zle reset-prompt + zle -R +} + +zle -N zle-line-init +zle -N zle-line-finish +zle -N zle-keymap-select + +# reset zle on resize +TRAPWINCH() { + zle && { zle reset-prompt; zle -R } +} + +# Get the status of the working tree +git_prompt_status() { + local branch ahead behind + local added deleted modified renamed unmerged untracked dirty + # Use porcelain status for easy parsing. + local status_cmd="git status --porcelain -b" + + # Get current status. + while IFS=$'\n' read line; do + if [[ "$line" == \#\#\ * ]]; then + [[ "$line" =~ '## ([^.]*)\.\.\.(.*)' ]] && branch=$match[1] + [[ "$line" =~ 'ahead ([0-9]+)' ]] && ahead=$match[1] + [[ "$line" =~ 'behind ([0-9]+)' ]] && behind=$match[1] + else + # Count added, deleted, modified, renamed, unmerged, untracked, dirty. + # T (type change) is undocumented, see http://git.io/FnpMGw. + # index + [[ "$line" == M[\ MTD]\ * ]] && (( updated++ )) + [[ "$line" == [AC][\ MTD]\ * ]] && (( added++ )) + [[ "$line" == D[\ MT]\ * ]] && (( deleted++ )) + [[ "$line" == R[\ MTD]\ * ]] && (( renamed++ )) + + # work tree + [[ "$line" == [\ MARCT]M\ * ]] && (( modified++ )) + [[ "$line" == [\ MARCT]D\ * ]] && (( deleted_wt++ )) + [[ "$line" == \?\?\ * ]] && (( untracked++ )) + + # morge conflicts + [[ "$line" == (AA|DD|U?|?U)\ * ]] && (( unmerged++ )) + fi + done < <(${(z)status_cmd} 2> /dev/null) + + local git_status=" %{$fg[yellow]%}" + + # Format branch + if [[ -n $branch ]]; then + git_status+="$branch" + else + git_status+="$(git rev-parse --short HEAD 2> /dev/null)" + [[ $? -ne 0 ]] && return + fi + + # Format upstream + local upstream_str + (( ahead > 0 )) && upstream_str+="%{$fg[blue]%} >$ahead" + (( behind > 0 )) && upstream_str+="%{$fg[blue]%} <$behind" + git_status+="$upstream_str" + + # Format stashed + stashed=$(git stash list | wc -l) + if (( stashed > 0 )) then + stashed_str+="%{$fg_bold[cyan]%} ⋎$stashed%{$reset_color%}" + fi + git_status+="$stashed_str" + + # Format index + local index_str + (( updated > 0 )) && index_str+="%{$fg[green]%} *$updated" + (( added > 0 )) && index_str+="%{$fg[green]%} +$added" + (( deleted > 0 )) && index_str+="%{$fg[green]%} -$deleted" + (( renamed > 0 )) && index_str+="%{$fg[green]%} ≈$renamed" + git_status+="$index_str" + + # Format working tree + local wt_str + (( modified > 0 )) && wt_str+="%{$fg[red]%} *$modified" + (( deleted_wt > 0 )) && wt_str+="%{$fg[red]%} -$deleted_wt" + (( untracked > 0 )) && wt_str+="%{$fg[red]%} +$untracked" + (( unmerged > 0 )) && wt_str+="%{$fg[magenta]%} ♒$unmerged" + git_status+="$wt_str" + + git_status+="%{$reset_color%}" + + echo $git_status +} + +function print_if_fits() { + local zero length + + zero='%([BSUbfksu]|([FB]|){*})' + length=${#${(S%%)1//$~zero/}} + echo "%-$length(l.$1.)" +} diff --git a/zsh/lib/theme-and-appearance.zsh b/zsh/lib/theme-and-appearance.zsh deleted file mode 100644 index 4900895..0000000 --- a/zsh/lib/theme-and-appearance.zsh +++ /dev/null @@ -1,28 +0,0 @@ -# ls colors -autoload colors; colors; -eval $(dircolors $XDG_CONFIG_HOME/dircolors) - -# Enable ls colors -ls='ls --color=auto' - -setopt no_beep -setopt multios - -if [[ x$WINDOW != x ]] -then - SCREEN_NO="%B$WINDOW%b " -else - SCREEN_NO="" -fi - -# Apply theming defaults -PS1="%n@%m:%~%# " - -# git theming default: Variables for theming the git info prompt -ZSH_THEME_GIT_PROMPT_PREFIX="git:(" # Prefix at the very beginning of the prompt, before the branch name -ZSH_THEME_GIT_PROMPT_SUFFIX=")" # At the very end of the prompt -ZSH_THEME_GIT_PROMPT_DIRTY="*" # Text to display if the branch is dirty -ZSH_THEME_GIT_PROMPT_CLEAN="" # Text to display if the branch is clean - -# Setup the prompt with pretty colors -setopt prompt_subst diff --git a/zsh/themes/ramsi.zsh-theme b/zsh/themes/ramsi.zsh-theme deleted file mode 100644 index 8964a07..0000000 --- a/zsh/themes/ramsi.zsh-theme +++ /dev/null @@ -1,9 +0,0 @@ -[[ $(hostname) == "tardis" ]] && hostcolor=red -[[ $(hostname) == "shada" ]] && hostcolor=green -PROMPT='%(?..%{$fg_bold[white]%}[%?])%{$reset_color%}[%D{%k:%M} %n@%{$fg[$hostcolor]%}%m%{$reset_color%}$(git_prompt_info)]%# ' -RPROMPT='%{$fg[green]%}%~%{$reset_color%}' - -ZSH_THEME_GIT_PROMPT_PREFIX=" %{$fg[yellow]%}<" -ZSH_THEME_GIT_PROMPT_SUFFIX=">%{$reset_color%}" -ZSH_THEME_GIT_PROMPT_DIRTY="*" -ZSH_THEME_GIT_PROMPT_CLEAN=""