diff --git a/0.9.6/404.html b/0.9.6/404.html new file mode 100644 index 00000000..875f48a8 --- /dev/null +++ b/0.9.6/404.html @@ -0,0 +1,1052 @@ + + + + + + + + + + + + + + + + + + + + + + bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ +

404 - Not found

+ +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/assets/images/favicon.png b/0.9.6/assets/images/favicon.png new file mode 100644 index 00000000..1cf13b9f Binary files /dev/null and b/0.9.6/assets/images/favicon.png differ diff --git a/0.9.6/assets/javascripts/bundle.220ee61c.min.js b/0.9.6/assets/javascripts/bundle.220ee61c.min.js new file mode 100644 index 00000000..116072a1 --- /dev/null +++ b/0.9.6/assets/javascripts/bundle.220ee61c.min.js @@ -0,0 +1,29 @@ +"use strict";(()=>{var Ci=Object.create;var gr=Object.defineProperty;var Ri=Object.getOwnPropertyDescriptor;var ki=Object.getOwnPropertyNames,Ht=Object.getOwnPropertySymbols,Hi=Object.getPrototypeOf,yr=Object.prototype.hasOwnProperty,nn=Object.prototype.propertyIsEnumerable;var rn=(e,t,r)=>t in e?gr(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,P=(e,t)=>{for(var r in t||(t={}))yr.call(t,r)&&rn(e,r,t[r]);if(Ht)for(var r of Ht(t))nn.call(t,r)&&rn(e,r,t[r]);return e};var on=(e,t)=>{var r={};for(var n in e)yr.call(e,n)&&t.indexOf(n)<0&&(r[n]=e[n]);if(e!=null&&Ht)for(var n of Ht(e))t.indexOf(n)<0&&nn.call(e,n)&&(r[n]=e[n]);return r};var Pt=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Pi=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of ki(t))!yr.call(e,o)&&o!==r&&gr(e,o,{get:()=>t[o],enumerable:!(n=Ri(t,o))||n.enumerable});return e};var yt=(e,t,r)=>(r=e!=null?Ci(Hi(e)):{},Pi(t||!e||!e.__esModule?gr(r,"default",{value:e,enumerable:!0}):r,e));var sn=Pt((xr,an)=>{(function(e,t){typeof xr=="object"&&typeof an!="undefined"?t():typeof define=="function"&&define.amd?define(t):t()})(xr,function(){"use strict";function e(r){var n=!0,o=!1,i=null,s={text:!0,search:!0,url:!0,tel:!0,email:!0,password:!0,number:!0,date:!0,month:!0,week:!0,time:!0,datetime:!0,"datetime-local":!0};function a(O){return!!(O&&O!==document&&O.nodeName!=="HTML"&&O.nodeName!=="BODY"&&"classList"in O&&"contains"in O.classList)}function f(O){var Qe=O.type,De=O.tagName;return!!(De==="INPUT"&&s[Qe]&&!O.readOnly||De==="TEXTAREA"&&!O.readOnly||O.isContentEditable)}function c(O){O.classList.contains("focus-visible")||(O.classList.add("focus-visible"),O.setAttribute("data-focus-visible-added",""))}function u(O){O.hasAttribute("data-focus-visible-added")&&(O.classList.remove("focus-visible"),O.removeAttribute("data-focus-visible-added"))}function p(O){O.metaKey||O.altKey||O.ctrlKey||(a(r.activeElement)&&c(r.activeElement),n=!0)}function m(O){n=!1}function d(O){a(O.target)&&(n||f(O.target))&&c(O.target)}function h(O){a(O.target)&&(O.target.classList.contains("focus-visible")||O.target.hasAttribute("data-focus-visible-added"))&&(o=!0,window.clearTimeout(i),i=window.setTimeout(function(){o=!1},100),u(O.target))}function v(O){document.visibilityState==="hidden"&&(o&&(n=!0),Y())}function Y(){document.addEventListener("mousemove",N),document.addEventListener("mousedown",N),document.addEventListener("mouseup",N),document.addEventListener("pointermove",N),document.addEventListener("pointerdown",N),document.addEventListener("pointerup",N),document.addEventListener("touchmove",N),document.addEventListener("touchstart",N),document.addEventListener("touchend",N)}function B(){document.removeEventListener("mousemove",N),document.removeEventListener("mousedown",N),document.removeEventListener("mouseup",N),document.removeEventListener("pointermove",N),document.removeEventListener("pointerdown",N),document.removeEventListener("pointerup",N),document.removeEventListener("touchmove",N),document.removeEventListener("touchstart",N),document.removeEventListener("touchend",N)}function N(O){O.target.nodeName&&O.target.nodeName.toLowerCase()==="html"||(n=!1,B())}document.addEventListener("keydown",p,!0),document.addEventListener("mousedown",m,!0),document.addEventListener("pointerdown",m,!0),document.addEventListener("touchstart",m,!0),document.addEventListener("visibilitychange",v,!0),Y(),r.addEventListener("focus",d,!0),r.addEventListener("blur",h,!0),r.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&r.host?r.host.setAttribute("data-js-focus-visible",""):r.nodeType===Node.DOCUMENT_NODE&&(document.documentElement.classList.add("js-focus-visible"),document.documentElement.setAttribute("data-js-focus-visible",""))}if(typeof window!="undefined"&&typeof document!="undefined"){window.applyFocusVisiblePolyfill=e;var t;try{t=new CustomEvent("focus-visible-polyfill-ready")}catch(r){t=document.createEvent("CustomEvent"),t.initCustomEvent("focus-visible-polyfill-ready",!1,!1,{})}window.dispatchEvent(t)}typeof document!="undefined"&&e(document)})});var cn=Pt(Er=>{(function(e){var t=function(){try{return!!Symbol.iterator}catch(c){return!1}},r=t(),n=function(c){var u={next:function(){var p=c.shift();return{done:p===void 0,value:p}}};return r&&(u[Symbol.iterator]=function(){return u}),u},o=function(c){return encodeURIComponent(c).replace(/%20/g,"+")},i=function(c){return decodeURIComponent(String(c).replace(/\+/g," "))},s=function(){var c=function(p){Object.defineProperty(this,"_entries",{writable:!0,value:{}});var m=typeof p;if(m!=="undefined")if(m==="string")p!==""&&this._fromString(p);else if(p instanceof c){var d=this;p.forEach(function(B,N){d.append(N,B)})}else if(p!==null&&m==="object")if(Object.prototype.toString.call(p)==="[object Array]")for(var h=0;hd[0]?1:0}),c._entries&&(c._entries={});for(var p=0;p1?i(d[1]):"")}})})(typeof global!="undefined"?global:typeof window!="undefined"?window:typeof self!="undefined"?self:Er);(function(e){var t=function(){try{var o=new e.URL("b","http://a");return o.pathname="c d",o.href==="http://a/c%20d"&&o.searchParams}catch(i){return!1}},r=function(){var o=e.URL,i=function(f,c){typeof f!="string"&&(f=String(f)),c&&typeof c!="string"&&(c=String(c));var u=document,p;if(c&&(e.location===void 0||c!==e.location.href)){c=c.toLowerCase(),u=document.implementation.createHTMLDocument(""),p=u.createElement("base"),p.href=c,u.head.appendChild(p);try{if(p.href.indexOf(c)!==0)throw new Error(p.href)}catch(O){throw new Error("URL unable to set base "+c+" due to "+O)}}var m=u.createElement("a");m.href=f,p&&(u.body.appendChild(m),m.href=m.href);var d=u.createElement("input");if(d.type="url",d.value=f,m.protocol===":"||!/:/.test(m.href)||!d.checkValidity()&&!c)throw new TypeError("Invalid URL");Object.defineProperty(this,"_anchorElement",{value:m});var h=new e.URLSearchParams(this.search),v=!0,Y=!0,B=this;["append","delete","set"].forEach(function(O){var Qe=h[O];h[O]=function(){Qe.apply(h,arguments),v&&(Y=!1,B.search=h.toString(),Y=!0)}}),Object.defineProperty(this,"searchParams",{value:h,enumerable:!0});var N=void 0;Object.defineProperty(this,"_updateSearchParams",{enumerable:!1,configurable:!1,writable:!1,value:function(){this.search!==N&&(N=this.search,Y&&(v=!1,this.searchParams._fromString(this.search),v=!0))}})},s=i.prototype,a=function(f){Object.defineProperty(s,f,{get:function(){return this._anchorElement[f]},set:function(c){this._anchorElement[f]=c},enumerable:!0})};["hash","host","hostname","port","protocol"].forEach(function(f){a(f)}),Object.defineProperty(s,"search",{get:function(){return this._anchorElement.search},set:function(f){this._anchorElement.search=f,this._updateSearchParams()},enumerable:!0}),Object.defineProperties(s,{toString:{get:function(){var f=this;return function(){return f.href}}},href:{get:function(){return this._anchorElement.href.replace(/\?$/,"")},set:function(f){this._anchorElement.href=f,this._updateSearchParams()},enumerable:!0},pathname:{get:function(){return this._anchorElement.pathname.replace(/(^\/?)/,"/")},set:function(f){this._anchorElement.pathname=f},enumerable:!0},origin:{get:function(){var f={"http:":80,"https:":443,"ftp:":21}[this._anchorElement.protocol],c=this._anchorElement.port!=f&&this._anchorElement.port!=="";return this._anchorElement.protocol+"//"+this._anchorElement.hostname+(c?":"+this._anchorElement.port:"")},enumerable:!0},password:{get:function(){return""},set:function(f){},enumerable:!0},username:{get:function(){return""},set:function(f){},enumerable:!0}}),i.createObjectURL=function(f){return o.createObjectURL.apply(o,arguments)},i.revokeObjectURL=function(f){return o.revokeObjectURL.apply(o,arguments)},e.URL=i};if(t()||r(),e.location!==void 0&&!("origin"in e.location)){var n=function(){return e.location.protocol+"//"+e.location.hostname+(e.location.port?":"+e.location.port:"")};try{Object.defineProperty(e.location,"origin",{get:n,enumerable:!0})}catch(o){setInterval(function(){e.location.origin=n()},100)}}})(typeof global!="undefined"?global:typeof window!="undefined"?window:typeof self!="undefined"?self:Er)});var qr=Pt((Mt,Nr)=>{/*! + * clipboard.js v2.0.11 + * https://clipboardjs.com/ + * + * Licensed MIT © Zeno Rocha + */(function(t,r){typeof Mt=="object"&&typeof Nr=="object"?Nr.exports=r():typeof define=="function"&&define.amd?define([],r):typeof Mt=="object"?Mt.ClipboardJS=r():t.ClipboardJS=r()})(Mt,function(){return function(){var e={686:function(n,o,i){"use strict";i.d(o,{default:function(){return Ai}});var s=i(279),a=i.n(s),f=i(370),c=i.n(f),u=i(817),p=i.n(u);function m(j){try{return document.execCommand(j)}catch(T){return!1}}var d=function(T){var E=p()(T);return m("cut"),E},h=d;function v(j){var T=document.documentElement.getAttribute("dir")==="rtl",E=document.createElement("textarea");E.style.fontSize="12pt",E.style.border="0",E.style.padding="0",E.style.margin="0",E.style.position="absolute",E.style[T?"right":"left"]="-9999px";var H=window.pageYOffset||document.documentElement.scrollTop;return E.style.top="".concat(H,"px"),E.setAttribute("readonly",""),E.value=j,E}var Y=function(T,E){var H=v(T);E.container.appendChild(H);var I=p()(H);return m("copy"),H.remove(),I},B=function(T){var E=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{container:document.body},H="";return typeof T=="string"?H=Y(T,E):T instanceof HTMLInputElement&&!["text","search","url","tel","password"].includes(T==null?void 0:T.type)?H=Y(T.value,E):(H=p()(T),m("copy")),H},N=B;function O(j){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?O=function(E){return typeof E}:O=function(E){return E&&typeof Symbol=="function"&&E.constructor===Symbol&&E!==Symbol.prototype?"symbol":typeof E},O(j)}var Qe=function(){var T=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},E=T.action,H=E===void 0?"copy":E,I=T.container,q=T.target,Me=T.text;if(H!=="copy"&&H!=="cut")throw new Error('Invalid "action" value, use either "copy" or "cut"');if(q!==void 0)if(q&&O(q)==="object"&&q.nodeType===1){if(H==="copy"&&q.hasAttribute("disabled"))throw new Error('Invalid "target" attribute. Please use "readonly" instead of "disabled" attribute');if(H==="cut"&&(q.hasAttribute("readonly")||q.hasAttribute("disabled")))throw new Error(`Invalid "target" attribute. You can't cut text from elements with "readonly" or "disabled" attributes`)}else throw new Error('Invalid "target" value, use a valid Element');if(Me)return N(Me,{container:I});if(q)return H==="cut"?h(q):N(q,{container:I})},De=Qe;function $e(j){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?$e=function(E){return typeof E}:$e=function(E){return E&&typeof Symbol=="function"&&E.constructor===Symbol&&E!==Symbol.prototype?"symbol":typeof E},$e(j)}function Ei(j,T){if(!(j instanceof T))throw new TypeError("Cannot call a class as a function")}function tn(j,T){for(var E=0;E0&&arguments[0]!==void 0?arguments[0]:{};this.action=typeof I.action=="function"?I.action:this.defaultAction,this.target=typeof I.target=="function"?I.target:this.defaultTarget,this.text=typeof I.text=="function"?I.text:this.defaultText,this.container=$e(I.container)==="object"?I.container:document.body}},{key:"listenClick",value:function(I){var q=this;this.listener=c()(I,"click",function(Me){return q.onClick(Me)})}},{key:"onClick",value:function(I){var q=I.delegateTarget||I.currentTarget,Me=this.action(q)||"copy",kt=De({action:Me,container:this.container,target:this.target(q),text:this.text(q)});this.emit(kt?"success":"error",{action:Me,text:kt,trigger:q,clearSelection:function(){q&&q.focus(),window.getSelection().removeAllRanges()}})}},{key:"defaultAction",value:function(I){return vr("action",I)}},{key:"defaultTarget",value:function(I){var q=vr("target",I);if(q)return document.querySelector(q)}},{key:"defaultText",value:function(I){return vr("text",I)}},{key:"destroy",value:function(){this.listener.destroy()}}],[{key:"copy",value:function(I){var q=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{container:document.body};return N(I,q)}},{key:"cut",value:function(I){return h(I)}},{key:"isSupported",value:function(){var I=arguments.length>0&&arguments[0]!==void 0?arguments[0]:["copy","cut"],q=typeof I=="string"?[I]:I,Me=!!document.queryCommandSupported;return q.forEach(function(kt){Me=Me&&!!document.queryCommandSupported(kt)}),Me}}]),E}(a()),Ai=Li},828:function(n){var o=9;if(typeof Element!="undefined"&&!Element.prototype.matches){var i=Element.prototype;i.matches=i.matchesSelector||i.mozMatchesSelector||i.msMatchesSelector||i.oMatchesSelector||i.webkitMatchesSelector}function s(a,f){for(;a&&a.nodeType!==o;){if(typeof a.matches=="function"&&a.matches(f))return a;a=a.parentNode}}n.exports=s},438:function(n,o,i){var s=i(828);function a(u,p,m,d,h){var v=c.apply(this,arguments);return u.addEventListener(m,v,h),{destroy:function(){u.removeEventListener(m,v,h)}}}function f(u,p,m,d,h){return typeof u.addEventListener=="function"?a.apply(null,arguments):typeof m=="function"?a.bind(null,document).apply(null,arguments):(typeof u=="string"&&(u=document.querySelectorAll(u)),Array.prototype.map.call(u,function(v){return a(v,p,m,d,h)}))}function c(u,p,m,d){return function(h){h.delegateTarget=s(h.target,p),h.delegateTarget&&d.call(u,h)}}n.exports=f},879:function(n,o){o.node=function(i){return i!==void 0&&i instanceof HTMLElement&&i.nodeType===1},o.nodeList=function(i){var s=Object.prototype.toString.call(i);return i!==void 0&&(s==="[object NodeList]"||s==="[object HTMLCollection]")&&"length"in i&&(i.length===0||o.node(i[0]))},o.string=function(i){return typeof i=="string"||i instanceof String},o.fn=function(i){var s=Object.prototype.toString.call(i);return s==="[object Function]"}},370:function(n,o,i){var s=i(879),a=i(438);function f(m,d,h){if(!m&&!d&&!h)throw new Error("Missing required arguments");if(!s.string(d))throw new TypeError("Second argument must be a String");if(!s.fn(h))throw new TypeError("Third argument must be a Function");if(s.node(m))return c(m,d,h);if(s.nodeList(m))return u(m,d,h);if(s.string(m))return p(m,d,h);throw new TypeError("First argument must be a String, HTMLElement, HTMLCollection, or NodeList")}function c(m,d,h){return m.addEventListener(d,h),{destroy:function(){m.removeEventListener(d,h)}}}function u(m,d,h){return Array.prototype.forEach.call(m,function(v){v.addEventListener(d,h)}),{destroy:function(){Array.prototype.forEach.call(m,function(v){v.removeEventListener(d,h)})}}}function p(m,d,h){return a(document.body,m,d,h)}n.exports=f},817:function(n){function o(i){var s;if(i.nodeName==="SELECT")i.focus(),s=i.value;else if(i.nodeName==="INPUT"||i.nodeName==="TEXTAREA"){var a=i.hasAttribute("readonly");a||i.setAttribute("readonly",""),i.select(),i.setSelectionRange(0,i.value.length),a||i.removeAttribute("readonly"),s=i.value}else{i.hasAttribute("contenteditable")&&i.focus();var f=window.getSelection(),c=document.createRange();c.selectNodeContents(i),f.removeAllRanges(),f.addRange(c),s=f.toString()}return s}n.exports=o},279:function(n){function o(){}o.prototype={on:function(i,s,a){var f=this.e||(this.e={});return(f[i]||(f[i]=[])).push({fn:s,ctx:a}),this},once:function(i,s,a){var f=this;function c(){f.off(i,c),s.apply(a,arguments)}return c._=s,this.on(i,c,a)},emit:function(i){var s=[].slice.call(arguments,1),a=((this.e||(this.e={}))[i]||[]).slice(),f=0,c=a.length;for(f;f{"use strict";/*! + * escape-html + * Copyright(c) 2012-2013 TJ Holowaychuk + * Copyright(c) 2015 Andreas Lubbe + * Copyright(c) 2015 Tiancheng "Timothy" Gu + * MIT Licensed + */var rs=/["'&<>]/;Yo.exports=ns;function ns(e){var t=""+e,r=rs.exec(t);if(!r)return t;var n,o="",i=0,s=0;for(i=r.index;i0&&i[i.length-1])&&(c[0]===6||c[0]===2)){r=0;continue}if(c[0]===3&&(!i||c[1]>i[0]&&c[1]=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function W(e,t){var r=typeof Symbol=="function"&&e[Symbol.iterator];if(!r)return e;var n=r.call(e),o,i=[],s;try{for(;(t===void 0||t-- >0)&&!(o=n.next()).done;)i.push(o.value)}catch(a){s={error:a}}finally{try{o&&!o.done&&(r=n.return)&&r.call(n)}finally{if(s)throw s.error}}return i}function D(e,t,r){if(r||arguments.length===2)for(var n=0,o=t.length,i;n1||a(m,d)})})}function a(m,d){try{f(n[m](d))}catch(h){p(i[0][3],h)}}function f(m){m.value instanceof et?Promise.resolve(m.value.v).then(c,u):p(i[0][2],m)}function c(m){a("next",m)}function u(m){a("throw",m)}function p(m,d){m(d),i.shift(),i.length&&a(i[0][0],i[0][1])}}function pn(e){if(!Symbol.asyncIterator)throw new TypeError("Symbol.asyncIterator is not defined.");var t=e[Symbol.asyncIterator],r;return t?t.call(e):(e=typeof Ee=="function"?Ee(e):e[Symbol.iterator](),r={},n("next"),n("throw"),n("return"),r[Symbol.asyncIterator]=function(){return this},r);function n(i){r[i]=e[i]&&function(s){return new Promise(function(a,f){s=e[i](s),o(a,f,s.done,s.value)})}}function o(i,s,a,f){Promise.resolve(f).then(function(c){i({value:c,done:a})},s)}}function C(e){return typeof e=="function"}function at(e){var t=function(n){Error.call(n),n.stack=new Error().stack},r=e(t);return r.prototype=Object.create(Error.prototype),r.prototype.constructor=r,r}var It=at(function(e){return function(r){e(this),this.message=r?r.length+` errors occurred during unsubscription: +`+r.map(function(n,o){return o+1+") "+n.toString()}).join(` + `):"",this.name="UnsubscriptionError",this.errors=r}});function Ve(e,t){if(e){var r=e.indexOf(t);0<=r&&e.splice(r,1)}}var Ie=function(){function e(t){this.initialTeardown=t,this.closed=!1,this._parentage=null,this._finalizers=null}return e.prototype.unsubscribe=function(){var t,r,n,o,i;if(!this.closed){this.closed=!0;var s=this._parentage;if(s)if(this._parentage=null,Array.isArray(s))try{for(var a=Ee(s),f=a.next();!f.done;f=a.next()){var c=f.value;c.remove(this)}}catch(v){t={error:v}}finally{try{f&&!f.done&&(r=a.return)&&r.call(a)}finally{if(t)throw t.error}}else s.remove(this);var u=this.initialTeardown;if(C(u))try{u()}catch(v){i=v instanceof It?v.errors:[v]}var p=this._finalizers;if(p){this._finalizers=null;try{for(var m=Ee(p),d=m.next();!d.done;d=m.next()){var h=d.value;try{ln(h)}catch(v){i=i!=null?i:[],v instanceof It?i=D(D([],W(i)),W(v.errors)):i.push(v)}}}catch(v){n={error:v}}finally{try{d&&!d.done&&(o=m.return)&&o.call(m)}finally{if(n)throw n.error}}}if(i)throw new It(i)}},e.prototype.add=function(t){var r;if(t&&t!==this)if(this.closed)ln(t);else{if(t instanceof e){if(t.closed||t._hasParent(this))return;t._addParent(this)}(this._finalizers=(r=this._finalizers)!==null&&r!==void 0?r:[]).push(t)}},e.prototype._hasParent=function(t){var r=this._parentage;return r===t||Array.isArray(r)&&r.includes(t)},e.prototype._addParent=function(t){var r=this._parentage;this._parentage=Array.isArray(r)?(r.push(t),r):r?[r,t]:t},e.prototype._removeParent=function(t){var r=this._parentage;r===t?this._parentage=null:Array.isArray(r)&&Ve(r,t)},e.prototype.remove=function(t){var r=this._finalizers;r&&Ve(r,t),t instanceof e&&t._removeParent(this)},e.EMPTY=function(){var t=new e;return t.closed=!0,t}(),e}();var Sr=Ie.EMPTY;function jt(e){return e instanceof Ie||e&&"closed"in e&&C(e.remove)&&C(e.add)&&C(e.unsubscribe)}function ln(e){C(e)?e():e.unsubscribe()}var Le={onUnhandledError:null,onStoppedNotification:null,Promise:void 0,useDeprecatedSynchronousErrorHandling:!1,useDeprecatedNextContext:!1};var st={setTimeout:function(e,t){for(var r=[],n=2;n0},enumerable:!1,configurable:!0}),t.prototype._trySubscribe=function(r){return this._throwIfClosed(),e.prototype._trySubscribe.call(this,r)},t.prototype._subscribe=function(r){return this._throwIfClosed(),this._checkFinalizedStatuses(r),this._innerSubscribe(r)},t.prototype._innerSubscribe=function(r){var n=this,o=this,i=o.hasError,s=o.isStopped,a=o.observers;return i||s?Sr:(this.currentObservers=null,a.push(r),new Ie(function(){n.currentObservers=null,Ve(a,r)}))},t.prototype._checkFinalizedStatuses=function(r){var n=this,o=n.hasError,i=n.thrownError,s=n.isStopped;o?r.error(i):s&&r.complete()},t.prototype.asObservable=function(){var r=new F;return r.source=this,r},t.create=function(r,n){return new xn(r,n)},t}(F);var xn=function(e){ie(t,e);function t(r,n){var o=e.call(this)||this;return o.destination=r,o.source=n,o}return t.prototype.next=function(r){var n,o;(o=(n=this.destination)===null||n===void 0?void 0:n.next)===null||o===void 0||o.call(n,r)},t.prototype.error=function(r){var n,o;(o=(n=this.destination)===null||n===void 0?void 0:n.error)===null||o===void 0||o.call(n,r)},t.prototype.complete=function(){var r,n;(n=(r=this.destination)===null||r===void 0?void 0:r.complete)===null||n===void 0||n.call(r)},t.prototype._subscribe=function(r){var n,o;return(o=(n=this.source)===null||n===void 0?void 0:n.subscribe(r))!==null&&o!==void 0?o:Sr},t}(x);var Et={now:function(){return(Et.delegate||Date).now()},delegate:void 0};var wt=function(e){ie(t,e);function t(r,n,o){r===void 0&&(r=1/0),n===void 0&&(n=1/0),o===void 0&&(o=Et);var i=e.call(this)||this;return i._bufferSize=r,i._windowTime=n,i._timestampProvider=o,i._buffer=[],i._infiniteTimeWindow=!0,i._infiniteTimeWindow=n===1/0,i._bufferSize=Math.max(1,r),i._windowTime=Math.max(1,n),i}return t.prototype.next=function(r){var n=this,o=n.isStopped,i=n._buffer,s=n._infiniteTimeWindow,a=n._timestampProvider,f=n._windowTime;o||(i.push(r),!s&&i.push(a.now()+f)),this._trimBuffer(),e.prototype.next.call(this,r)},t.prototype._subscribe=function(r){this._throwIfClosed(),this._trimBuffer();for(var n=this._innerSubscribe(r),o=this,i=o._infiniteTimeWindow,s=o._buffer,a=s.slice(),f=0;f0?e.prototype.requestAsyncId.call(this,r,n,o):(r.actions.push(this),r._scheduled||(r._scheduled=ut.requestAnimationFrame(function(){return r.flush(void 0)})))},t.prototype.recycleAsyncId=function(r,n,o){var i;if(o===void 0&&(o=0),o!=null?o>0:this.delay>0)return e.prototype.recycleAsyncId.call(this,r,n,o);var s=r.actions;n!=null&&((i=s[s.length-1])===null||i===void 0?void 0:i.id)!==n&&(ut.cancelAnimationFrame(n),r._scheduled=void 0)},t}(Wt);var Sn=function(e){ie(t,e);function t(){return e!==null&&e.apply(this,arguments)||this}return t.prototype.flush=function(r){this._active=!0;var n=this._scheduled;this._scheduled=void 0;var o=this.actions,i;r=r||o.shift();do if(i=r.execute(r.state,r.delay))break;while((r=o[0])&&r.id===n&&o.shift());if(this._active=!1,i){for(;(r=o[0])&&r.id===n&&o.shift();)r.unsubscribe();throw i}},t}(Dt);var Oe=new Sn(wn);var M=new F(function(e){return e.complete()});function Vt(e){return e&&C(e.schedule)}function Cr(e){return e[e.length-1]}function Ye(e){return C(Cr(e))?e.pop():void 0}function Te(e){return Vt(Cr(e))?e.pop():void 0}function zt(e,t){return typeof Cr(e)=="number"?e.pop():t}var pt=function(e){return e&&typeof e.length=="number"&&typeof e!="function"};function Nt(e){return C(e==null?void 0:e.then)}function qt(e){return C(e[ft])}function Kt(e){return Symbol.asyncIterator&&C(e==null?void 0:e[Symbol.asyncIterator])}function Qt(e){return new TypeError("You provided "+(e!==null&&typeof e=="object"?"an invalid object":"'"+e+"'")+" where a stream was expected. You can provide an Observable, Promise, ReadableStream, Array, AsyncIterable, or Iterable.")}function zi(){return typeof Symbol!="function"||!Symbol.iterator?"@@iterator":Symbol.iterator}var Yt=zi();function Gt(e){return C(e==null?void 0:e[Yt])}function Bt(e){return un(this,arguments,function(){var r,n,o,i;return $t(this,function(s){switch(s.label){case 0:r=e.getReader(),s.label=1;case 1:s.trys.push([1,,9,10]),s.label=2;case 2:return[4,et(r.read())];case 3:return n=s.sent(),o=n.value,i=n.done,i?[4,et(void 0)]:[3,5];case 4:return[2,s.sent()];case 5:return[4,et(o)];case 6:return[4,s.sent()];case 7:return s.sent(),[3,2];case 8:return[3,10];case 9:return r.releaseLock(),[7];case 10:return[2]}})})}function Jt(e){return C(e==null?void 0:e.getReader)}function U(e){if(e instanceof F)return e;if(e!=null){if(qt(e))return Ni(e);if(pt(e))return qi(e);if(Nt(e))return Ki(e);if(Kt(e))return On(e);if(Gt(e))return Qi(e);if(Jt(e))return Yi(e)}throw Qt(e)}function Ni(e){return new F(function(t){var r=e[ft]();if(C(r.subscribe))return r.subscribe(t);throw new TypeError("Provided object does not correctly implement Symbol.observable")})}function qi(e){return new F(function(t){for(var r=0;r=2;return function(n){return n.pipe(e?A(function(o,i){return e(o,i,n)}):de,ge(1),r?He(t):Dn(function(){return new Zt}))}}function Vn(){for(var e=[],t=0;t=2,!0))}function pe(e){e===void 0&&(e={});var t=e.connector,r=t===void 0?function(){return new x}:t,n=e.resetOnError,o=n===void 0?!0:n,i=e.resetOnComplete,s=i===void 0?!0:i,a=e.resetOnRefCountZero,f=a===void 0?!0:a;return function(c){var u,p,m,d=0,h=!1,v=!1,Y=function(){p==null||p.unsubscribe(),p=void 0},B=function(){Y(),u=m=void 0,h=v=!1},N=function(){var O=u;B(),O==null||O.unsubscribe()};return y(function(O,Qe){d++,!v&&!h&&Y();var De=m=m!=null?m:r();Qe.add(function(){d--,d===0&&!v&&!h&&(p=$r(N,f))}),De.subscribe(Qe),!u&&d>0&&(u=new rt({next:function($e){return De.next($e)},error:function($e){v=!0,Y(),p=$r(B,o,$e),De.error($e)},complete:function(){h=!0,Y(),p=$r(B,s),De.complete()}}),U(O).subscribe(u))})(c)}}function $r(e,t){for(var r=[],n=2;ne.next(document)),e}function K(e,t=document){return Array.from(t.querySelectorAll(e))}function z(e,t=document){let r=ce(e,t);if(typeof r=="undefined")throw new ReferenceError(`Missing element: expected "${e}" to be present`);return r}function ce(e,t=document){return t.querySelector(e)||void 0}function _e(){return document.activeElement instanceof HTMLElement&&document.activeElement||void 0}function tr(e){return L(b(document.body,"focusin"),b(document.body,"focusout")).pipe(ke(1),l(()=>{let t=_e();return typeof t!="undefined"?e.contains(t):!1}),V(e===_e()),J())}function Xe(e){return{x:e.offsetLeft,y:e.offsetTop}}function Kn(e){return L(b(window,"load"),b(window,"resize")).pipe(Ce(0,Oe),l(()=>Xe(e)),V(Xe(e)))}function rr(e){return{x:e.scrollLeft,y:e.scrollTop}}function dt(e){return L(b(e,"scroll"),b(window,"resize")).pipe(Ce(0,Oe),l(()=>rr(e)),V(rr(e)))}var Yn=function(){if(typeof Map!="undefined")return Map;function e(t,r){var n=-1;return t.some(function(o,i){return o[0]===r?(n=i,!0):!1}),n}return function(){function t(){this.__entries__=[]}return Object.defineProperty(t.prototype,"size",{get:function(){return this.__entries__.length},enumerable:!0,configurable:!0}),t.prototype.get=function(r){var n=e(this.__entries__,r),o=this.__entries__[n];return o&&o[1]},t.prototype.set=function(r,n){var o=e(this.__entries__,r);~o?this.__entries__[o][1]=n:this.__entries__.push([r,n])},t.prototype.delete=function(r){var n=this.__entries__,o=e(n,r);~o&&n.splice(o,1)},t.prototype.has=function(r){return!!~e(this.__entries__,r)},t.prototype.clear=function(){this.__entries__.splice(0)},t.prototype.forEach=function(r,n){n===void 0&&(n=null);for(var o=0,i=this.__entries__;o0},e.prototype.connect_=function(){!Wr||this.connected_||(document.addEventListener("transitionend",this.onTransitionEnd_),window.addEventListener("resize",this.refresh),va?(this.mutationsObserver_=new MutationObserver(this.refresh),this.mutationsObserver_.observe(document,{attributes:!0,childList:!0,characterData:!0,subtree:!0})):(document.addEventListener("DOMSubtreeModified",this.refresh),this.mutationEventsAdded_=!0),this.connected_=!0)},e.prototype.disconnect_=function(){!Wr||!this.connected_||(document.removeEventListener("transitionend",this.onTransitionEnd_),window.removeEventListener("resize",this.refresh),this.mutationsObserver_&&this.mutationsObserver_.disconnect(),this.mutationEventsAdded_&&document.removeEventListener("DOMSubtreeModified",this.refresh),this.mutationsObserver_=null,this.mutationEventsAdded_=!1,this.connected_=!1)},e.prototype.onTransitionEnd_=function(t){var r=t.propertyName,n=r===void 0?"":r,o=ba.some(function(i){return!!~n.indexOf(i)});o&&this.refresh()},e.getInstance=function(){return this.instance_||(this.instance_=new e),this.instance_},e.instance_=null,e}(),Gn=function(e,t){for(var r=0,n=Object.keys(t);r0},e}(),Jn=typeof WeakMap!="undefined"?new WeakMap:new Yn,Xn=function(){function e(t){if(!(this instanceof e))throw new TypeError("Cannot call a class as a function.");if(!arguments.length)throw new TypeError("1 argument required, but only 0 present.");var r=ga.getInstance(),n=new La(t,r,this);Jn.set(this,n)}return e}();["observe","unobserve","disconnect"].forEach(function(e){Xn.prototype[e]=function(){var t;return(t=Jn.get(this))[e].apply(t,arguments)}});var Aa=function(){return typeof nr.ResizeObserver!="undefined"?nr.ResizeObserver:Xn}(),Zn=Aa;var eo=new x,Ca=$(()=>k(new Zn(e=>{for(let t of e)eo.next(t)}))).pipe(g(e=>L(ze,k(e)).pipe(R(()=>e.disconnect()))),X(1));function he(e){return{width:e.offsetWidth,height:e.offsetHeight}}function ye(e){return Ca.pipe(S(t=>t.observe(e)),g(t=>eo.pipe(A(({target:r})=>r===e),R(()=>t.unobserve(e)),l(()=>he(e)))),V(he(e)))}function bt(e){return{width:e.scrollWidth,height:e.scrollHeight}}function ar(e){let t=e.parentElement;for(;t&&(e.scrollWidth<=t.scrollWidth&&e.scrollHeight<=t.scrollHeight);)t=(e=t).parentElement;return t?e:void 0}var to=new x,Ra=$(()=>k(new IntersectionObserver(e=>{for(let t of e)to.next(t)},{threshold:0}))).pipe(g(e=>L(ze,k(e)).pipe(R(()=>e.disconnect()))),X(1));function sr(e){return Ra.pipe(S(t=>t.observe(e)),g(t=>to.pipe(A(({target:r})=>r===e),R(()=>t.unobserve(e)),l(({isIntersecting:r})=>r))))}function ro(e,t=16){return dt(e).pipe(l(({y:r})=>{let n=he(e),o=bt(e);return r>=o.height-n.height-t}),J())}var cr={drawer:z("[data-md-toggle=drawer]"),search:z("[data-md-toggle=search]")};function no(e){return cr[e].checked}function Ke(e,t){cr[e].checked!==t&&cr[e].click()}function Ue(e){let t=cr[e];return b(t,"change").pipe(l(()=>t.checked),V(t.checked))}function ka(e,t){switch(e.constructor){case HTMLInputElement:return e.type==="radio"?/^Arrow/.test(t):!0;case HTMLSelectElement:case HTMLTextAreaElement:return!0;default:return e.isContentEditable}}function Ha(){return L(b(window,"compositionstart").pipe(l(()=>!0)),b(window,"compositionend").pipe(l(()=>!1))).pipe(V(!1))}function oo(){let e=b(window,"keydown").pipe(A(t=>!(t.metaKey||t.ctrlKey)),l(t=>({mode:no("search")?"search":"global",type:t.key,claim(){t.preventDefault(),t.stopPropagation()}})),A(({mode:t,type:r})=>{if(t==="global"){let n=_e();if(typeof n!="undefined")return!ka(n,r)}return!0}),pe());return Ha().pipe(g(t=>t?M:e))}function le(){return new URL(location.href)}function ot(e){location.href=e.href}function io(){return new x}function ao(e,t){if(typeof t=="string"||typeof t=="number")e.innerHTML+=t.toString();else if(t instanceof Node)e.appendChild(t);else if(Array.isArray(t))for(let r of t)ao(e,r)}function _(e,t,...r){let n=document.createElement(e);if(t)for(let o of Object.keys(t))typeof t[o]!="undefined"&&(typeof t[o]!="boolean"?n.setAttribute(o,t[o]):n.setAttribute(o,""));for(let o of r)ao(n,o);return n}function fr(e){if(e>999){let t=+((e-950)%1e3>99);return`${((e+1e-6)/1e3).toFixed(t)}k`}else return e.toString()}function so(){return location.hash.substring(1)}function Dr(e){let t=_("a",{href:e});t.addEventListener("click",r=>r.stopPropagation()),t.click()}function Pa(e){return L(b(window,"hashchange"),e).pipe(l(so),V(so()),A(t=>t.length>0),X(1))}function co(e){return Pa(e).pipe(l(t=>ce(`[id="${t}"]`)),A(t=>typeof t!="undefined"))}function Vr(e){let t=matchMedia(e);return er(r=>t.addListener(()=>r(t.matches))).pipe(V(t.matches))}function fo(){let e=matchMedia("print");return L(b(window,"beforeprint").pipe(l(()=>!0)),b(window,"afterprint").pipe(l(()=>!1))).pipe(V(e.matches))}function zr(e,t){return e.pipe(g(r=>r?t():M))}function ur(e,t={credentials:"same-origin"}){return ue(fetch(`${e}`,t)).pipe(fe(()=>M),g(r=>r.status!==200?Ot(()=>new Error(r.statusText)):k(r)))}function We(e,t){return ur(e,t).pipe(g(r=>r.json()),X(1))}function uo(e,t){let r=new DOMParser;return ur(e,t).pipe(g(n=>n.text()),l(n=>r.parseFromString(n,"text/xml")),X(1))}function pr(e){let t=_("script",{src:e});return $(()=>(document.head.appendChild(t),L(b(t,"load"),b(t,"error").pipe(g(()=>Ot(()=>new ReferenceError(`Invalid script: ${e}`))))).pipe(l(()=>{}),R(()=>document.head.removeChild(t)),ge(1))))}function po(){return{x:Math.max(0,scrollX),y:Math.max(0,scrollY)}}function lo(){return L(b(window,"scroll",{passive:!0}),b(window,"resize",{passive:!0})).pipe(l(po),V(po()))}function mo(){return{width:innerWidth,height:innerHeight}}function ho(){return b(window,"resize",{passive:!0}).pipe(l(mo),V(mo()))}function bo(){return G([lo(),ho()]).pipe(l(([e,t])=>({offset:e,size:t})),X(1))}function lr(e,{viewport$:t,header$:r}){let n=t.pipe(ee("size")),o=G([n,r]).pipe(l(()=>Xe(e)));return G([r,t,o]).pipe(l(([{height:i},{offset:s,size:a},{x:f,y:c}])=>({offset:{x:s.x-f,y:s.y-c+i},size:a})))}(()=>{function e(n,o){parent.postMessage(n,o||"*")}function t(...n){return n.reduce((o,i)=>o.then(()=>new Promise(s=>{let a=document.createElement("script");a.src=i,a.onload=s,document.body.appendChild(a)})),Promise.resolve())}var r=class extends EventTarget{constructor(n){super(),this.url=n,this.m=i=>{i.source===this.w&&(this.dispatchEvent(new MessageEvent("message",{data:i.data})),this.onmessage&&this.onmessage(i))},this.e=(i,s,a,f,c)=>{if(s===`${this.url}`){let u=new ErrorEvent("error",{message:i,filename:s,lineno:a,colno:f,error:c});this.dispatchEvent(u),this.onerror&&this.onerror(u)}};let o=document.createElement("iframe");o.hidden=!0,document.body.appendChild(this.iframe=o),this.w.document.open(),this.w.document.write(` + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Command-line Flags

+

The following flags can be provided to bottom in the command line to change the behaviour of the program. You can also +see information on these flags by running btm -h, or run btm --help to display more detailed information on each flag:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
FlagBehaviour
--autohide_timeTemporarily shows the time scale in graphs.
-b, --basicHides graphs and uses a more basic look.
--batteryShows the battery widget.
-S, --case_sensitiveEnables case sensitivity by default.
-c, --celsiusSets the temperature type to Celsius.
--color Use a color scheme, use --help for info.
-C, --config Sets the location of the config file.
-u, --current_usageSets process CPU% to be based on current CPU%.
-t, --default_time_value Default time value for graphs.
--default_widget_count Sets the n'th selected widget type as the default.
--default_widget_type Sets the default widget type, use --help for info.
--disable_advanced_killHides advanced process killing.
--disable_clickDisables mouse clicks.
-m, --dot_markerUses a dot marker for graphs.
--enable_cache_memoryEnable collecting and displaying cache and buffer memory.
--enable_gpu_memoryEnable collecting and displaying GPU memory usage.
-e, --expandedExpand the default widget upon starting the app.
-f, --fahrenheitSets the temperature type to Fahrenheit.
-g, --groupGroups processes with the same name by default.
-a, --hide_avg_cpuHides the average CPU usage.
--hide_table_gapHides spacing between table headers and entries.
--hide_timeHides the time scale.
-k, --kelvinSets the temperature type to Kelvin.
-l, --left_legendPuts the CPU chart legend to the left side.
--mem_as_valueDefaults to showing process memory usage by value.
--network_use_binary_prefixDisplays the network widget with binary prefixes.
--network_use_bytesDisplays the network widget using bytes.
--network_use_logDisplays the network widget with a log scale.
--process_commandShow processes as their commands by default.
-r, --rate Sets the data refresh rate.
-R, --regexEnables regex by default.
--retention The timespan of data stored.
--show_table_scroll_positionShows the scroll position tracker in table widgets.
-d, --time_delta The amount of time changed upon zooming.
-T, --treeDefaults the process widget be in tree mode.
-n, --unnormalized_cpuShow process CPU% usage without normalizing over the number of cores.
--use_old_network_legendDEPRECATED - uses a separate network legend.
-V, --versionPrints version information.
-W, --whole_wordEnables whole-word matching by default.
-h, --helpPrint help (see more with '--help')
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/configuration/config-file/data-filtering/index.html b/0.9.6/configuration/config-file/data-filtering/index.html new file mode 100644 index 00000000..f8ac9fff --- /dev/null +++ b/0.9.6/configuration/config-file/data-filtering/index.html @@ -0,0 +1,1122 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Data Filtering - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Data Filtering

+
+

Warning

+

This section is in progress, and is just copied from the old documentation.

+
+

You can hide specific disks, temperature sensors, and networks by name in the config file via disk_filter and mount_filter, temp_filter, and net_filter respectively. Regex (regex = true), case-sensitivity (case_sensitive = true), and matching only if the entire word matches (whole_word = true) are supported, but are off by default. Filters default to denying entries that match and can be toggled by setting is_list_ignored to false in the config file.

+

For example, here's the disk widget with no filter:

+

Disk no filter

+

The following in the config file would filter out some entries by disk name:

+
[disk_filter]
+is_list_ignored = true
+list = ["/dev/sda"]
+regex = true
+case_sensitive = false
+whole_word = false
+
+

Disk widget with just disk name filter

+

If there are two potentially conflicting filters (i.e. when you are using both a disk and mount filter), the filter that explicitly allows an entry takes precedence over a filter that explicitly denies one. So for example, let's say we set a disk filter accepting anything with /dev/sda, but deny anything with /mnt/.* or /. So to do so, we write in the config file:

+
[disk_filter]
+is_list_ignored = false
+list = ["/dev/sda"]
+regex = true
+case_sensitive = false
+whole_word = false
+
+[mount_filter]
+is_list_ignored = true
+list = ["/mnt/.*", "/"]
+regex = true
+case_sensitive = false
+whole_word = true
+
+

This gives us:

+

Disk widget with disk name and mount filter

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/configuration/config-file/default-config/index.html b/0.9.6/configuration/config-file/default-config/index.html new file mode 100644 index 00000000..8f878c85 --- /dev/null +++ b/0.9.6/configuration/config-file/default-config/index.html @@ -0,0 +1,1113 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Default Config - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Default Config

+

A default config file is automatically generated at the following locations that bottom checks by default:

+ + + + + + + + + + + + + + + + + + + + + +
OSDefault Config Location
macOS$HOME/Library/Application Support/bottom/bottom.toml
~/.config/bottom/bottom.toml
$XDG_CONFIG_HOME/bottom/bottom.toml
Linux~/.config/bottom/bottom.toml
$XDG_CONFIG_HOME/bottom/bottom.toml
WindowsC:\Users\<USER>\AppData\Roaming\bottom\bottom.toml
+

Furthermore, if a custom config path that does not exist is given (using -C or --config), bottom will attempt to create a default config file at that location.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/configuration/config-file/flags/index.html b/0.9.6/configuration/config-file/flags/index.html new file mode 100644 index 00000000..9de30b6c --- /dev/null +++ b/0.9.6/configuration/config-file/flags/index.html @@ -0,0 +1,1271 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Flags - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Flags

+
+

Warning

+

This section is in progress, and is just copied from the old documentation.

+
+

Most of the command line flags have config file equivalents to avoid having to type them out +each time:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
FieldTypeFunctionality
hide_avg_cpuBooleanHides the average CPU usage.
dot_markerBooleanUses a dot marker for graphs.
left_legendBooleanPuts the CPU chart legend to the left side.
current_usageBooleanSets process CPU% to be based on current CPU%.
group_processesBooleanGroups processes with the same name by default.
case_sensitiveBooleanEnables case sensitivity by default.
whole_wordBooleanEnables whole-word matching by default.
regexBooleanEnables regex by default.
basicBooleanHides graphs and uses a more basic look.
use_old_network_legendBooleanDEPRECATED - uses the older network legend.
batteryBooleanShows the battery widget.
rateUnsigned Int (represents milliseconds) or String (represents human time)Sets a refresh rate in ms.
default_time_valueUnsigned Int (represents milliseconds) or String (represents human time)Default time value for graphs in ms.
time_deltaUnsigned Int (represents milliseconds) or String (represents human time)The amount in ms changed upon zooming.
hide_timeBooleanHides the time scale.
temperature_typeString (one of ["k", "f", "c", "kelvin", "fahrenheit", "celsius"])Sets the temperature unit type.
default_widget_typeString (one of ["cpu", "proc", "net", "temp", "mem", "disk"], same as layout options)Sets the default widget type, use --help for more info.
default_widget_countUnsigned Int (represents which default_widget_type)Sets the n'th selected widget type as the default.
disable_clickBooleanDisables mouse clicks.
colorString (one of ["default", "default-light", "gruvbox", "gruvbox-light", "nord", "nord-light"])Use a color scheme, use --help for supported values.
enable_cache_memoryBooleanEnable collecting and displaying cache and buffer memory (not available on Windows).
mem_as_valueBooleanDefaults to showing process memory usage by value.
treeBooleanDefaults to showing the process widget in tree mode.
show_table_scroll_positionBooleanShows the scroll position tracker in table widgets.
process_commandBooleanShow processes as their commands by default.
disable_advanced_killBooleanHides advanced options to stop a process on Unix-like systems.
network_use_binary_prefixBooleanDisplays the network widget with binary prefixes.
network_use_bytesBooleanDisplays the network widget using bytes.
network_use_logBooleanDisplays the network widget with a log scale.
enable_gpu_memoryBooleanShows the GPU memory widget.
retentionString (human readable time, such as "10m", "1h", etc.)How much data is stored at once in terms of time.
unnormalized_cpuBooleanShow process CPU% without normalizing over the number of cores.
expanded_on_startupBooleanExpand the default widget upon starting the app.
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/configuration/config-file/layout/index.html b/0.9.6/configuration/config-file/layout/index.html new file mode 100644 index 00000000..eeed8129 --- /dev/null +++ b/0.9.6/configuration/config-file/layout/index.html @@ -0,0 +1,1164 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Layout - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Layout

+
+

Warning

+

This section is in progress, and is just copied from the old documentation.

+
+

bottom supports customizable layouts via the config file. Currently, layouts are controlled by using TOML objects and arrays.

+

For example, given the sample layout:

+
[[row]]
+  [[row.child]]
+  type="cpu"
+[[row]]
+    ratio=2
+    [[row.child]]
+      ratio=4
+      type="mem"
+    [[row.child]]
+      ratio=3
+      [[row.child.child]]
+        type="temp"
+      [[row.child.child]]
+        type="disk"
+
+

This would give a layout that has two rows, with a 1:2 ratio. The first row has only the CPU widget. +The second row is split into two columns with a 4:3 ratio. The first column contains the memory widget. +The second column is split into two rows with a 1:1 ratio. The first is the temperature widget, the second is the disk widget.

+

This is what the layout would look like when run:

+

Sample layout

+

Each [[row]] represents a row in the layout. A row can have any number of child values. Each [[row.child]] +represents either a column or a widget. A column can have any number of child values as well. Each [[row.child.child]] +represents a widget. A widget is represented by having a type field set to a string.

+

The following type values are supported:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
"cpu"CPU chart and legend
"mem", "memory"Memory chart
"net", "network"Network chart and legend
"proc", "process", "processes"Process table and search
"temp", "temperature"Temperature table
"disk"Disk table
"empty"An empty space
"batt", "battery"Battery statistics
+

Each component of the layout accepts a ratio value. If this is not set, it defaults to 1.

+

Furthermore, you can have duplicate widgets.

+

For an example, look at the default config, which contains the default layout.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/configuration/config-file/processes/index.html b/0.9.6/configuration/config-file/processes/index.html new file mode 100644 index 00000000..d76be63d --- /dev/null +++ b/0.9.6/configuration/config-file/processes/index.html @@ -0,0 +1,1126 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Processes - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Processes

+

Columns

+

You can configure which columns are shown by the process widget by setting the columns setting:

+
[processes]
+# Pick which columns you want to use in any order.
+columns = ["cpu%", "mem%", "pid", "name", "read", "write", "Tread", "twrite", "state", "user", "time"]
+
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/configuration/config-file/theming/index.html b/0.9.6/configuration/config-file/theming/index.html new file mode 100644 index 00000000..65e4e2ab --- /dev/null +++ b/0.9.6/configuration/config-file/theming/index.html @@ -0,0 +1,1211 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Theming - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Theming

+
+

Warning

+

This section is in progress, and is just copied from the old documentation.

+
+

The config file can be used to set custom colours for parts of the application under the [colors] object. The following labels are customizable with strings that are hex colours, RGB colours, or specific named colours.

+

Supported named colours are one of the following strings: Reset, Black, Red, Green, Yellow, Blue, Magenta, Cyan, Gray, DarkGray, LightRed, LightGreen, LightYellow, LightBlue, LightMagenta, LightCyan, White.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
LabelsDetailsExample
Table header coloursColour of table headerstable_header_color="255, 255, 255"
CPU colour per coreColour of each core. Read in order.cpu_core_colors=["#ffffff", "white", "255, 255, 255"]
Average CPU colourThe average CPU coloravg_cpu_color="White"
All CPUs colourThe colour for the "All" CPU labelall_cpu_color="White"
RAMThe colour RAM will useram_color="#ffffff"
SWAPThe colour SWAP will useswap_color="#ffffff"
RXThe colour rx will userx_color="#ffffff"
TXThe colour tx will usetx_color="#ffffff"
Widget title colourThe colour of the label each widget haswidget_title_color="#ffffff"
Border colourThe colour of the border of unselected widgetsborder_color="#ffffff"
Selected border colourThe colour of the border of selected widgetshighlighted_border_color="#ffffff"
Text colourThe colour of most texttext_color="#ffffff"
Graph colourThe colour of the lines and text of the graphgraph_color="#ffffff"
Cursor colourThe cursor's colourcursor_color="#ffffff"
Selected text colourThe colour of text that is selectedscroll_entry_text_color="#ffffff"
Selected text background colourThe background colour of text that is selectedscroll_entry_bg_color="#ffffff"
High battery level colourThe colour used for a high battery level (100% to 50%)high_battery_color="green"
Medium battery level colourThe colour used for a medium battery level (50% to 10%)medium_battery_color="yellow"
Low battery level colourThe colour used for a low battery level (10% to 0%)low_battery_color="red"
GPU colour per gpuColour of each gpu. Read in order.gpu_core_colors=["#ffffff", "white", "255, 255, 255"]
ARCThe colour ARC will usearc_color="#ffffff"
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/development/build_process/index.html b/0.9.6/contribution/development/build_process/index.html new file mode 100644 index 00000000..6ebb170a --- /dev/null +++ b/0.9.6/contribution/development/build_process/index.html @@ -0,0 +1,1200 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Build Process - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Build Process

+
+

Warning

+

This section is currently somewhat WIP.

+
+
+

Warning

+

This section is intended for people who wish to work on/build/distribute bottom, not general users.

+
+

Overview

+

bottom manages its own binary builds for nightly and stable release purposes. The core build workflow is handled by build_releases.yml, called by a wrapper workflow for nightly and stable releases. Builds take place via GitHub Actions.

+

The main things built are:

+
    +
  • Binaries for various platforms
  • +
  • MSI installer for Windows
  • +
  • .deb package for Debian and its derivatives
  • +
+

This documentation gives a high-level overview of the build process for each part. For the most up-to-date and detailed reference, definitely refer back to the build_releases.yml file.

+

Binaries

+

Binaries are built currently for various targets. Note that not all of these are officially supported. The following general steps are performed:

+
    +
  • Set up the Rust toolchain for the action runner.
  • +
  • Enable cache.
  • +
  • +

    Build a release build with:

    +
      +
    • --features deploy, which enables only crates needed for release builds.
    • +
    • --locked to lock the dependency versions.
    • +
    • +

      The following env variables set:

      +
        +
      • BTM_GENERATE: true
      • +
      • COMPLETION_DIR: "target/tmp/bottom/completion/"
      • +
      • MANPAGE_DIR: "target/tmp/bottom/manpage/"
      • +
      +

      These generate the manpages and shell completions (see Packaging for some more information).

      +
    • +
    +
  • +
+
    +
  • Bundle the binaries and manpage/completions.
  • +
  • Cleanup.
  • +
+

Some builds use cross to do cross-compilation builds for architectures otherwise not natively supported by the runner.

+

MSI

+

This builds a full Windows installer using cargo-wix. This requires some setup beforehand with some dependencies:

+
    +
  • Net-Framework-Core (handled by Powershell)
  • +
  • wixtoolset (handled by chocolatey)
  • +
  • Rust toolchain
  • +
+

After that, cache is enabled, and cargo wix takes care of the rest.

+

.deb

+

Currently, .deb files are built for x86 and ARM architectures (armv7, aarch64). This is handled by cargo-deb.

+
    +
  • For x86, this is handled natively with just cargo-deb.
  • +
  • For ARM, this uses a Docker container, cargo-deb-arm, which correctly sets the dependencies and architecture for the generated .deb file.
  • +
+

There are additional checks via dpkg to ensure the architecture is correctly set.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/development/deploy_process/index.html b/0.9.6/contribution/development/deploy_process/index.html new file mode 100644 index 00000000..e6b26322 --- /dev/null +++ b/0.9.6/contribution/development/deploy_process/index.html @@ -0,0 +1,1191 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Deploy Process - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Deploy Process

+
+

Warning

+

This section is currently WIP.

+
+
+

Warning

+

This section is intended for people who wish to work on/build/distribute bottom, not general users.

+
+

Overview

+

bottom currently has two main deploy processes to worry about:

+
    +
  • Nightly: a daily (00:00 UTC) GitHub action to build binary/installer files, and upload them to the nightly release. It can also be triggered manually as either a proper nightly release or a mock release.
  • +
  • +

    Stable: a stable deployment, triggered manually or upon creation of a valid tag. This is a GitHub action that builds binary/installer files and uploads them to a new GitHub release.

    +

    Furthermore, this workflow does not handle the following deployments, which must be manually handled:

    + +
  • +
+

Nightly

+

This is, for the most part, automatic, though it can also be used as a way of testing build workflow changes and seeing if binaries can be successfully built at all against all the targets we want to build for.

+

If one does not want to actually update the nightly release, and just want to test the general builds and workflow, one can run the workflow manually on a branch of choice with "mock" set as the parameter. Changing it to anything else will trigger a non-mock run.

+

Stable

+

This can be manually triggered, though the general use-case is setting a tag of the form x.y.z (after checking everything is good, of course). For example:

+
git tag 0.6.9 && git push origin 0.6.9
+
+

This will automatically trigger the deployment workflow, and create a draft release with the files uploaded. One still needs to fill in the details and release it.

+

Furthermore, there are some deployments that are handled by maintainers of bottom that this workflow does not automatically finish. These must be manually handled.

+

Chocolatey

+

Upon releasing on GitHub, choco-bottom will automatically be updated with a new PR with the correct deployment files for Chocolatey. Check the PR, merge it if it is correct, then pull locally and deploy following the instructions in the README. Make sure to test installation and running at least once before deploying!

+

If done correctly, there should be a new build on Chocolatey, which will take some time to validate.

+

crates.io

+

Validate everything builds properly and works (you should have done this before releasing though). If good, then deploying on crates.io is as simple as:

+
cargo publish
+
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/development/dev_env/index.html b/0.9.6/contribution/development/dev_env/index.html new file mode 100644 index 00000000..3c40b4c0 --- /dev/null +++ b/0.9.6/contribution/development/dev_env/index.html @@ -0,0 +1,1097 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Development Environment - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Development Environment

+
+

Warning

+

This section is currently WIP.

+
+
+

Warning

+

This section is intended for people who wish to work on/build/distribute bottom, not general users.

+
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/development/logging/index.html b/0.9.6/contribution/development/logging/index.html new file mode 100644 index 00000000..755480cc --- /dev/null +++ b/0.9.6/contribution/development/logging/index.html @@ -0,0 +1,1097 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Logging - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Logging

+
+

Warning

+

This section is currently WIP.

+
+
+

Warning

+

This section is intended for people who wish to work on/build/distribute bottom, not general users.

+
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/development/testing/index.html b/0.9.6/contribution/development/testing/index.html new file mode 100644 index 00000000..4ecdb280 --- /dev/null +++ b/0.9.6/contribution/development/testing/index.html @@ -0,0 +1,1097 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Testing - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Testing

+
+

Warning

+

This section is currently WIP.

+
+
+

Warning

+

This section is intended for people who wish to work on/build/distribute bottom, not general users.

+
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/documentation/index.html b/0.9.6/contribution/documentation/index.html new file mode 100644 index 00000000..1c2f0fd2 --- /dev/null +++ b/0.9.6/contribution/documentation/index.html @@ -0,0 +1,1192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Documentation - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Documentation

+

When should documentation changes be done?

+
    +
  • Whenever a new feature is added, a bug is fixed, or a breaking change is made, it should be documented where + appropriate (ex: README.md, changelog, etc.)
  • +
  • New methods of installation are always appreciated and should be documented
  • +
+

What pages need documentation?

+

There are a few areas where documentation changes are often needed:

+ +

How should I add/update documentation?

+
    +
  1. +

    Fork the repository to make changes in.

    +
  2. +
  3. +

    Where you're adding documentation will probably affect what you need to do:

    +

    README.md or CHANGELOG.md

    + +

    For changes to README.md and CHANGELOG.md, just follow the formatting provided and use any editor.

    +

    Generally, changes to CHANGELOG.md will be handled + by a maintainer, and changes should follow the Keep a Changelog format, as + well as link to the relevant PR or issue.

    +

    Help menu

    + +

    For changes to the help menu, try to refer to the existing code within src/constants.rs on how the help menu is generated.

    +

    Extended documentation

    + +

    For changes to the extended documentation, you'll probably want Python 3.11 (older versions should be fine though), + MkDocs, Material for MkDocs, + mdx_truly_sane_lists, and optionally Mike installed to provide live reloading + and preview for your changes. They aren't needed but it'll help with validating your changes.

    +

    You can do so through pip or your system's package managers. If you use pip, you can use venv to cleanly install + the documentation dependencies:

    +
    # Change directories to the documentation.
    +cd docs/
    +
    +# Create and activate venv.
    +python -m venv venv
    +source venv/bin/activate
    +
    +# Install requirements
    +pip install -r requirements.txt
    +
    +# Run mkdocs
    +venv/bin/mkdocs serve
    +
    +

    This will serve a local version of the docs that you can open on your browser. It will update as you make changes.

    +
  4. +
  5. +

    Once you have your documentation changes done, submit it as a pull request. For more information regarding that, + refer to Issues, Pull Requests, and Discussions.

    +
  6. +
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/issues-and-pull-requests/index.html b/0.9.6/contribution/issues-and-pull-requests/index.html new file mode 100644 index 00000000..a7409a31 --- /dev/null +++ b/0.9.6/contribution/issues-and-pull-requests/index.html @@ -0,0 +1,1182 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Issues, Pull Requests, and Discussions - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Issues, Pull Requests, and Discussions

+

Discussions

+

Discussions are open in the repo. As for the difference between discussions and issues:

+
    +
  • Open an issue if what you have enough information to properly fill out any details needed for a report or request.
  • +
  • Open a discussion otherwise (e.g. asking a question).
  • +
+

Opening an issue

+

Bug reports

+

When filing a bug report, please use the bug report template and fill in as much as you can. It is incredibly difficult for a maintainer to fix a bug when it cannot be reproduced, and giving as much detail as possible generally helps to make it easier to reproduce the problem!

+

Feature requests

+

Please use the feature request template and fill it out. Remember to give details about what the feature is along with why you think this suggestion will be useful.

+

Also please check whether or not an existing issue has covered your specific feature request!

+

Pull requests

+

The expected workflow for a pull request is:

+
    +
  1. Fork the project.
  2. +
  3. Make your changes.
  4. +
  5. Make any documentation changes if necessary - if you add a new feature, it'll probably need documentation changes. See here for tips on documentation.
  6. +
  7. Commit and create a pull request to merge into the master branch. Please fill out the pull request template.
  8. +
  9. Ask a maintainer to review your pull request.
      +
    • Check if the CI workflow passes. These consist of clippy lints, rustfmt checks, and basic tests. If you are a + first-time contributor, you may need to wait for a maintainer to let CI run.
    • +
    • If changes are suggested or any comments are made, they should probably be addressed.
    • +
    +
  10. +
  11. Once it looks good, it'll be merged! Note that generally, PRs are squashed to maintain repo cleanliness, though + feel free to ask otherwise if that isn't preferable.
  12. +
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/contribution/packaging-and-distribution/index.html b/0.9.6/contribution/packaging-and-distribution/index.html new file mode 100644 index 00000000..74b507b9 --- /dev/null +++ b/0.9.6/contribution/packaging-and-distribution/index.html @@ -0,0 +1,1192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Packaging and Distribution - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Packaging and Distribution

+

Package maintainers are always welcome and appreciated! Here's some info on how one can help with package distribution +and bottom.

+

Pre-built binaries

+

The latest stable release can be found here, where you ca +find pre-built binaries in either a tar.gz or zip format. Binaries here also include automatically generated shell +completion files for zsh, bash, fish, and Powershell, which you may want to also install during the packaging +process.

+

You can also find a nightly build in the releases page, built every +day at 00:00 UTC off of the master branch.

+

In both cases, we use a combination of GitHub Actions and CirrusCI (mainly for FreeBSD and macOS M1) to create our +release binaries. build_releases.yml +contains the GitHub Action workflow used to do both of these, if reference is needed.

+

Building manually

+

If you want to manually build bottom rather than distributing a pre-built binary, you'll need the most recent version +of stable Rust, which you can get with:

+
rustup update stable
+
+

You'll then want to build with:

+
cargo build --release --locked
+
+

Manpage and completion generation

+

bottom uses a build.rs script to automatically generate +a manpage and shell completions for the following shells:

+
    +
  • Bash
  • +
  • Zsh
  • +
  • Fish
  • +
  • Powershell
  • +
  • Elvish
  • +
+

If you want to generate manpages and/or completion files, set the BTM_GENERATE env var to a non-empty value. For +example, run something like this:

+
BTM_GENERATE=true cargo build --release --locked
+
+

This will automatically generate completion and manpage files in target/tmp/bottom/. If you wish to regenerate the +files, modify/delete either these files or set BTM_GENERATE to some other non-empty value to retrigger the build +script.

+

For more information, you may want to look at either the build.rs +file or the binary build CI workflow.

+

Adding an installation source

+

Once you've finished your installation source, if you want to mention it in the main bottom repo, fork the repo and add +the installation method and any details to the README.md +file under the Installation section, as well as a corresponding +table of contents entry. Once that's done, open a pull request - these will usually be approved of very quickly.

+

You can find more info on the contribution process here.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/index.html b/0.9.6/index.html new file mode 100644 index 00000000..466b8c32 --- /dev/null +++ b/0.9.6/index.html @@ -0,0 +1,1156 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + Home - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

bottom

+

A customizable cross-platform graphical process/system monitor for the terminal, supporting Linux, macOS, and Windows. Inspired by other tools like gtop, gotop, and htop.

+
+

This site serves as extended documentation for bottom alongside the README.md.

+
+

Warning

+

Some areas of this site are still in progress and may be missing details. Feel free to suggest/contribute changes!

+
+

Installation

+
+

Tip

+

It is a good idea to first check out the Support page to see if your system is officially supported!

+
+
+

Tip

+

If you're facing some issues during/after installation, check out the Troubleshooting page for some common problems and solutions.

+
+

To install bottom, refer to the installation section of the README.md, +which contains a list of all the installation methods.

+

Usage and configuration

+

You can refer to the usage pages on how to use bottom (e.g. keybinds, some features, a general overview of what each widget does).

+

To configure bottom, refer to the configuration pages (e.g. how it behaves, how it looks).

+

Contribution

+

New contributors are always welcome! See the contribution section for how to contribute to +bottom, whether it be filing issues, writing documentation, creating pull requests, etc.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/overrides/main.html b/0.9.6/overrides/main.html new file mode 100644 index 00000000..94d9808c --- /dev/null +++ b/0.9.6/overrides/main.html @@ -0,0 +1 @@ +{% extends "base.html" %} diff --git a/0.9.6/search/search_index.json b/0.9.6/search/search_index.json new file mode 100644 index 00000000..052da451 --- /dev/null +++ b/0.9.6/search/search_index.json @@ -0,0 +1 @@ +{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"bottom","text":"

A customizable cross-platform graphical process/system monitor for the terminal, supporting Linux, macOS, and Windows. Inspired by other tools like gtop, gotop, and htop.

This site serves as extended documentation for bottom alongside the README.md.

Warning

Some areas of this site are still in progress and may be missing details. Feel free to suggest/contribute changes!

"},{"location":"#installation","title":"Installation","text":"

Tip

It is a good idea to first check out the Support page to see if your system is officially supported!

Tip

If you're facing some issues during/after installation, check out the Troubleshooting page for some common problems and solutions.

To install bottom, refer to the installation section of the README.md, which contains a list of all the installation methods.

"},{"location":"#usage-and-configuration","title":"Usage and configuration","text":"

You can refer to the usage pages on how to use bottom (e.g. keybinds, some features, a general overview of what each widget does).

To configure bottom, refer to the configuration pages (e.g. how it behaves, how it looks).

"},{"location":"#contribution","title":"Contribution","text":"

New contributors are always welcome! See the contribution section for how to contribute to bottom, whether it be filing issues, writing documentation, creating pull requests, etc.

"},{"location":"troubleshooting/","title":"Troubleshooting","text":""},{"location":"troubleshooting/#the-graph-points-look-brokenstrange","title":"The graph points look broken/strange","text":"

It's possible that your graphs won't look great out of the box due to the reliance on braille fonts to draw them. One example of this is seeing a bunch of missing font characters, caused when the terminal isn't configured properly to render braille fonts.

An example of missing braille fonts in Powershell

One alternative is to use the --dot_marker option to render graph charts using dots instead of the braille characters, which generally seems better supported out of the box, at the expense of looking less intricate:

Example using btm --dot_marker

Another (better) alternative is to install a font that supports braille fonts, and configure your terminal emulator to use it. For example, installing something like UBraille or Iosevka and ensuring your terminal uses it should work.

"},{"location":"troubleshooting/#braille-font-issues-on-linuxmacosunix-like","title":"Braille font issues on Linux/macOS/Unix-like","text":"

Generally, the problem comes down to you either not having a font that supports the braille markers, or your terminal emulator is not using the correct font for the braille markers.

See here for possible fixes if you're having font issues on Linux, which may also be helpful for macOS or other Unix-like systems.

If you're still having issues, feel free to open a discussion question about it.

"},{"location":"troubleshooting/#installing-fonts-for-windows-command-promptpowershell","title":"Installing fonts for Windows Command Prompt/PowerShell","text":"

Note: I would advise backing up your registry beforehand if you aren't sure what you are doing!

Let's say you're installing Iosevka. The steps you can take are:

  1. Install the font itself.
  2. Open the registry editor, which you can do either by Win+R and opening regedit, or just opening it from the Start Menu.
  3. In the registry editor, go to

    HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Console\\TrueTypeFont\n
  4. Here, add a new String value, and set the Name to a bunch of 0's (e.g. 000 - make sure the name isn't already used), then set the Data to the font name (e.g. Iosevka).

The last entry is the new entry for Iosevka
  1. Then, open the Command Prompt/PowerShell, and right click on the top bar, and open \"Properties\":
  1. From here, go to \"Font\", and set the font to your new font (so in this example, Iosevka):
"},{"location":"troubleshooting/#why-cant-i-see-all-my-temperature-sensors-on-windows","title":"Why can't I see all my temperature sensors on Windows?","text":"

This is a known limitation, some sensors may require admin privileges to get sensor data.

"},{"location":"troubleshooting/#why-dont-i-see-dual-batteries-on-windows-reported-separately-eg-thinkpads","title":"Why don't I see dual batteries on Windows reported separately? (e.g. Thinkpads)","text":"

This is a known limitation which seems to be with how batteries are being detected on Windows.

"},{"location":"troubleshooting/#why-cant-i-see-all-my-temperature-sensors-on-wsl","title":"Why can't I see all my temperature sensors on WSL?","text":"

This is a known limitation with WSL. Due to how it works, hosts may not expose their temperature sensors and therefore, temperature sensors might be missing.

"},{"location":"troubleshooting/#why-does-wsl2-not-match-task-manager","title":"Why does WSL2 not match Task Manager?","text":"

This is a known limitation with WSL2. Due to how WSL2 works, the two might not match up in terms of reported data.

"},{"location":"troubleshooting/#why-cant-i-see-all-my-processesprocess-data-on-macos","title":"Why can't I see all my processes/process data on macOS?","text":"

This is a known limitation, and you may have to run the program with elevated privileges to work around it - for example:

sudo btm\n

Please note that you should be certain that you trust any software you grant root privileges.

There are measures taken to try to maximize the amount of information obtained without elevated privileges. For example, one can modify the instructions found on the htop wiki on how to run htop without sudo for bottom. However please understand the potential security risks before doing so!

"},{"location":"troubleshooting/#my-configuration-file-isnt-working","title":"My configuration file isn't working","text":"

If your configuration files aren't working, here are a few things to try:

"},{"location":"troubleshooting/#check-the-formatting","title":"Check the formatting","text":"

It may be handy to refer to the automatically generated config files or the sample configuration files. The config files also follow the TOML format.

Also make sure your config options are under the right table - for example, to set your temperature type, you must set it under the [flags] table:

[flags]\ntemperature_type = \"f\"\n

Meanwhile, if you want to set a custom color scheme, it would be under the [colors] table:

[colors]\ntable_header_color=\"LightBlue\"\n
"},{"location":"troubleshooting/#check-the-configuration-file-location","title":"Check the configuration file location","text":"

Make sure bottom is reading the right configuration file. By default, bottom looks for config files at these locations:

OS Default Config Location macOS $HOME/Library/Application Support/bottom/bottom.toml ~/.config/bottom/bottom.toml $XDG_CONFIG_HOME/bottom/bottom.toml Linux ~/.config/bottom/bottom.toml $XDG_CONFIG_HOME/bottom/bottom.toml Windows C:\\Users\\<USER>\\AppData\\Roaming\\bottom\\bottom.toml

If you want to use a config file in another location, use the --config or -C flags along with the path to the configuration file, like so:

btm -C path_to_config\n
"},{"location":"troubleshooting/#my-installation-through-snap-has-some-widgets-that-are-blankshow-no-data","title":"My installation through snap has some widgets that are blank/show no data","text":"

Make sure bottom is given the correct permissions in order to collect data. Snapcraft explains how to do so, but the TL;DR is:

sudo snap connect bottom:mount-observe\nsudo snap connect bottom:hardware-observe\nsudo snap connect bottom:system-observe\nsudo snap connect bottom:process-control\n
"},{"location":"configuration/command-line-flags/","title":"Command-line Flags","text":"

The following flags can be provided to bottom in the command line to change the behaviour of the program. You can also see information on these flags by running btm -h, or run btm --help to display more detailed information on each flag:

Flag Behaviour --autohide_time Temporarily shows the time scale in graphs. -b, --basic Hides graphs and uses a more basic look. --battery Shows the battery widget. -S, --case_sensitive Enables case sensitivity by default. -c, --celsius Sets the temperature type to Celsius. --color Use a color scheme, use --help for info. -C, --config Sets the location of the config file. -u, --current_usage Sets process CPU% to be based on current CPU%. -t, --default_time_value Default time value for graphs. --default_widget_count Sets the n'th selected widget type as the default. --default_widget_type Sets the default widget type, use --help for info. --disable_advanced_kill Hides advanced process killing. --disable_click Disables mouse clicks. -m, --dot_marker Uses a dot marker for graphs. --enable_cache_memory Enable collecting and displaying cache and buffer memory. --enable_gpu_memory Enable collecting and displaying GPU memory usage. -e, --expanded Expand the default widget upon starting the app. -f, --fahrenheit Sets the temperature type to Fahrenheit. -g, --group Groups processes with the same name by default. -a, --hide_avg_cpu Hides the average CPU usage. --hide_table_gap Hides spacing between table headers and entries. --hide_time Hides the time scale. -k, --kelvin Sets the temperature type to Kelvin. -l, --left_legend Puts the CPU chart legend to the left side. --mem_as_value Defaults to showing process memory usage by value. --network_use_binary_prefix Displays the network widget with binary prefixes. --network_use_bytes Displays the network widget using bytes. --network_use_log Displays the network widget with a log scale. --process_command Show processes as their commands by default. -r, --rate Sets the data refresh rate. -R, --regex Enables regex by default. --retention The timespan of data stored. --show_table_scroll_position Shows the scroll position tracker in table widgets. -d, --time_delta The amount of time changed upon zooming. -T, --tree Defaults the process widget be in tree mode. -n, --unnormalized_cpu Show process CPU% usage without normalizing over the number of cores. --use_old_network_legend DEPRECATED - uses a separate network legend. -V, --version Prints version information. -W, --whole_word Enables whole-word matching by default. -h, --help Print help (see more with '--help')"},{"location":"configuration/config-file/data-filtering/","title":"Data Filtering","text":"

Warning

This section is in progress, and is just copied from the old documentation.

You can hide specific disks, temperature sensors, and networks by name in the config file via disk_filter and mount_filter, temp_filter, and net_filter respectively. Regex (regex = true), case-sensitivity (case_sensitive = true), and matching only if the entire word matches (whole_word = true) are supported, but are off by default. Filters default to denying entries that match and can be toggled by setting is_list_ignored to false in the config file.

For example, here's the disk widget with no filter:

The following in the config file would filter out some entries by disk name:

[disk_filter]\nis_list_ignored = true\nlist = [\"/dev/sda\"]\nregex = true\ncase_sensitive = false\nwhole_word = false\n

If there are two potentially conflicting filters (i.e. when you are using both a disk and mount filter), the filter that explicitly allows an entry takes precedence over a filter that explicitly denies one. So for example, let's say we set a disk filter accepting anything with /dev/sda, but deny anything with /mnt/.* or /. So to do so, we write in the config file:

[disk_filter]\nis_list_ignored = false\nlist = [\"/dev/sda\"]\nregex = true\ncase_sensitive = false\nwhole_word = false\n\n[mount_filter]\nis_list_ignored = true\nlist = [\"/mnt/.*\", \"/\"]\nregex = true\ncase_sensitive = false\nwhole_word = true\n

This gives us:

"},{"location":"configuration/config-file/default-config/","title":"Default Config","text":"

A default config file is automatically generated at the following locations that bottom checks by default:

OS Default Config Location macOS $HOME/Library/Application Support/bottom/bottom.toml ~/.config/bottom/bottom.toml $XDG_CONFIG_HOME/bottom/bottom.toml Linux ~/.config/bottom/bottom.toml $XDG_CONFIG_HOME/bottom/bottom.toml Windows C:\\Users\\<USER>\\AppData\\Roaming\\bottom\\bottom.toml

Furthermore, if a custom config path that does not exist is given (using -C or --config), bottom will attempt to create a default config file at that location.

"},{"location":"configuration/config-file/flags/","title":"Flags","text":"

Warning

This section is in progress, and is just copied from the old documentation.

Most of the command line flags have config file equivalents to avoid having to type them out each time:

Field Type Functionality hide_avg_cpu Boolean Hides the average CPU usage. dot_marker Boolean Uses a dot marker for graphs. left_legend Boolean Puts the CPU chart legend to the left side. current_usage Boolean Sets process CPU% to be based on current CPU%. group_processes Boolean Groups processes with the same name by default. case_sensitive Boolean Enables case sensitivity by default. whole_word Boolean Enables whole-word matching by default. regex Boolean Enables regex by default. basic Boolean Hides graphs and uses a more basic look. use_old_network_legend Boolean DEPRECATED - uses the older network legend. battery Boolean Shows the battery widget. rate Unsigned Int (represents milliseconds) or String (represents human time) Sets a refresh rate in ms. default_time_value Unsigned Int (represents milliseconds) or String (represents human time) Default time value for graphs in ms. time_delta Unsigned Int (represents milliseconds) or String (represents human time) The amount in ms changed upon zooming. hide_time Boolean Hides the time scale. temperature_type String (one of [\"k\", \"f\", \"c\", \"kelvin\", \"fahrenheit\", \"celsius\"]) Sets the temperature unit type. default_widget_type String (one of [\"cpu\", \"proc\", \"net\", \"temp\", \"mem\", \"disk\"], same as layout options) Sets the default widget type, use --help for more info. default_widget_count Unsigned Int (represents which default_widget_type) Sets the n'th selected widget type as the default. disable_click Boolean Disables mouse clicks. color String (one of [\"default\", \"default-light\", \"gruvbox\", \"gruvbox-light\", \"nord\", \"nord-light\"]) Use a color scheme, use --help for supported values. enable_cache_memory Boolean Enable collecting and displaying cache and buffer memory (not available on Windows). mem_as_value Boolean Defaults to showing process memory usage by value. tree Boolean Defaults to showing the process widget in tree mode. show_table_scroll_position Boolean Shows the scroll position tracker in table widgets. process_command Boolean Show processes as their commands by default. disable_advanced_kill Boolean Hides advanced options to stop a process on Unix-like systems. network_use_binary_prefix Boolean Displays the network widget with binary prefixes. network_use_bytes Boolean Displays the network widget using bytes. network_use_log Boolean Displays the network widget with a log scale. enable_gpu_memory Boolean Shows the GPU memory widget. retention String (human readable time, such as \"10m\", \"1h\", etc.) How much data is stored at once in terms of time. unnormalized_cpu Boolean Show process CPU% without normalizing over the number of cores. expanded_on_startup Boolean Expand the default widget upon starting the app."},{"location":"configuration/config-file/layout/","title":"Layout","text":"

Warning

This section is in progress, and is just copied from the old documentation.

bottom supports customizable layouts via the config file. Currently, layouts are controlled by using TOML objects and arrays.

For example, given the sample layout:

[[row]]\n[[row.child]]\ntype=\"cpu\"\n[[row]]\nratio=2\n[[row.child]]\nratio=4\ntype=\"mem\"\n[[row.child]]\nratio=3\n[[row.child.child]]\ntype=\"temp\"\n[[row.child.child]]\ntype=\"disk\"\n

This would give a layout that has two rows, with a 1:2 ratio. The first row has only the CPU widget. The second row is split into two columns with a 4:3 ratio. The first column contains the memory widget. The second column is split into two rows with a 1:1 ratio. The first is the temperature widget, the second is the disk widget.

This is what the layout would look like when run:

Each [[row]] represents a row in the layout. A row can have any number of child values. Each [[row.child]] represents either a column or a widget. A column can have any number of child values as well. Each [[row.child.child]] represents a widget. A widget is represented by having a type field set to a string.

The following type values are supported:

\"cpu\" CPU chart and legend \"mem\", \"memory\" Memory chart \"net\", \"network\" Network chart and legend \"proc\", \"process\", \"processes\" Process table and search \"temp\", \"temperature\" Temperature table \"disk\" Disk table \"empty\" An empty space \"batt\", \"battery\" Battery statistics

Each component of the layout accepts a ratio value. If this is not set, it defaults to 1.

Furthermore, you can have duplicate widgets.

For an example, look at the default config, which contains the default layout.

"},{"location":"configuration/config-file/processes/","title":"Processes","text":""},{"location":"configuration/config-file/processes/#columns","title":"Columns","text":"

You can configure which columns are shown by the process widget by setting the columns setting:

[processes]\n# Pick which columns you want to use in any order.\ncolumns = [\"cpu%\", \"mem%\", \"pid\", \"name\", \"read\", \"write\", \"Tread\", \"twrite\", \"state\", \"user\", \"time\"]\n
"},{"location":"configuration/config-file/theming/","title":"Theming","text":"

Warning

This section is in progress, and is just copied from the old documentation.

The config file can be used to set custom colours for parts of the application under the [colors] object. The following labels are customizable with strings that are hex colours, RGB colours, or specific named colours.

Supported named colours are one of the following strings: Reset, Black, Red, Green, Yellow, Blue, Magenta, Cyan, Gray, DarkGray, LightRed, LightGreen, LightYellow, LightBlue, LightMagenta, LightCyan, White.

Labels Details Example Table header colours Colour of table headers table_header_color=\"255, 255, 255\" CPU colour per core Colour of each core. Read in order. cpu_core_colors=[\"#ffffff\", \"white\", \"255, 255, 255\"] Average CPU colour The average CPU color avg_cpu_color=\"White\" All CPUs colour The colour for the \"All\" CPU label all_cpu_color=\"White\" RAM The colour RAM will use ram_color=\"#ffffff\" SWAP The colour SWAP will use swap_color=\"#ffffff\" RX The colour rx will use rx_color=\"#ffffff\" TX The colour tx will use tx_color=\"#ffffff\" Widget title colour The colour of the label each widget has widget_title_color=\"#ffffff\" Border colour The colour of the border of unselected widgets border_color=\"#ffffff\" Selected border colour The colour of the border of selected widgets highlighted_border_color=\"#ffffff\" Text colour The colour of most text text_color=\"#ffffff\" Graph colour The colour of the lines and text of the graph graph_color=\"#ffffff\" Cursor colour The cursor's colour cursor_color=\"#ffffff\" Selected text colour The colour of text that is selected scroll_entry_text_color=\"#ffffff\" Selected text background colour The background colour of text that is selected scroll_entry_bg_color=\"#ffffff\" High battery level colour The colour used for a high battery level (100% to 50%) high_battery_color=\"green\" Medium battery level colour The colour used for a medium battery level (50% to 10%) medium_battery_color=\"yellow\" Low battery level colour The colour used for a low battery level (10% to 0%) low_battery_color=\"red\" GPU colour per gpu Colour of each gpu. Read in order. gpu_core_colors=[\"#ffffff\", \"white\", \"255, 255, 255\"] ARC The colour ARC will use arc_color=\"#ffffff\""},{"location":"contribution/documentation/","title":"Documentation","text":""},{"location":"contribution/documentation/#when-should-documentation-changes-be-done","title":"When should documentation changes be done?","text":"
  • Whenever a new feature is added, a bug is fixed, or a breaking change is made, it should be documented where appropriate (ex: README.md, changelog, etc.)
  • New methods of installation are always appreciated and should be documented
"},{"location":"contribution/documentation/#what-pages-need-documentation","title":"What pages need documentation?","text":"

There are a few areas where documentation changes are often needed:

  • The README.md
  • The help menu inside of the application (located here)
  • The extended documentation (here)
  • The CHANGELOG.md
"},{"location":"contribution/documentation/#how-should-i-addupdate-documentation","title":"How should I add/update documentation?","text":"
  1. Fork the repository to make changes in.

  2. Where you're adding documentation will probably affect what you need to do:

    README.md or CHANGELOG.md

    For changes to README.md and CHANGELOG.md, just follow the formatting provided and use any editor.

    Generally, changes to CHANGELOG.md will be handled by a maintainer, and changes should follow the Keep a Changelog format, as well as link to the relevant PR or issue.

    Help menu

    For changes to the help menu, try to refer to the existing code within src/constants.rs on how the help menu is generated.

    Extended documentation

    For changes to the extended documentation, you'll probably want Python 3.11 (older versions should be fine though), MkDocs, Material for MkDocs, mdx_truly_sane_lists, and optionally Mike installed to provide live reloading and preview for your changes. They aren't needed but it'll help with validating your changes.

    You can do so through pip or your system's package managers. If you use pip, you can use venv to cleanly install the documentation dependencies:

    # Change directories to the documentation.\ncd docs/\n\n# Create and activate venv.\npython -m venv venv\nsource venv/bin/activate\n\n# Install requirements\npip install -r requirements.txt\n\n# Run mkdocs\nvenv/bin/mkdocs serve\n

    This will serve a local version of the docs that you can open on your browser. It will update as you make changes.

  3. Once you have your documentation changes done, submit it as a pull request. For more information regarding that, refer to Issues, Pull Requests, and Discussions.

"},{"location":"contribution/issues-and-pull-requests/","title":"Issues, Pull Requests, and Discussions","text":""},{"location":"contribution/issues-and-pull-requests/#discussions","title":"Discussions","text":"

Discussions are open in the repo. As for the difference between discussions and issues:

  • Open an issue if what you have enough information to properly fill out any details needed for a report or request.
  • Open a discussion otherwise (e.g. asking a question).
"},{"location":"contribution/issues-and-pull-requests/#opening-an-issue","title":"Opening an issue","text":""},{"location":"contribution/issues-and-pull-requests/#bug-reports","title":"Bug reports","text":"

When filing a bug report, please use the bug report template and fill in as much as you can. It is incredibly difficult for a maintainer to fix a bug when it cannot be reproduced, and giving as much detail as possible generally helps to make it easier to reproduce the problem!

"},{"location":"contribution/issues-and-pull-requests/#feature-requests","title":"Feature requests","text":"

Please use the feature request template and fill it out. Remember to give details about what the feature is along with why you think this suggestion will be useful.

Also please check whether or not an existing issue has covered your specific feature request!

"},{"location":"contribution/issues-and-pull-requests/#pull-requests","title":"Pull requests","text":"

The expected workflow for a pull request is:

  1. Fork the project.
  2. Make your changes.
  3. Make any documentation changes if necessary - if you add a new feature, it'll probably need documentation changes. See here for tips on documentation.
  4. Commit and create a pull request to merge into the master branch. Please fill out the pull request template.
  5. Ask a maintainer to review your pull request.
    • Check if the CI workflow passes. These consist of clippy lints, rustfmt checks, and basic tests. If you are a first-time contributor, you may need to wait for a maintainer to let CI run.
    • If changes are suggested or any comments are made, they should probably be addressed.
  6. Once it looks good, it'll be merged! Note that generally, PRs are squashed to maintain repo cleanliness, though feel free to ask otherwise if that isn't preferable.
"},{"location":"contribution/packaging-and-distribution/","title":"Packaging and Distribution","text":"

Package maintainers are always welcome and appreciated! Here's some info on how one can help with package distribution and bottom.

"},{"location":"contribution/packaging-and-distribution/#pre-built-binaries","title":"Pre-built binaries","text":"

The latest stable release can be found here, where you ca find pre-built binaries in either a tar.gz or zip format. Binaries here also include automatically generated shell completion files for zsh, bash, fish, and Powershell, which you may want to also install during the packaging process.

You can also find a nightly build in the releases page, built every day at 00:00 UTC off of the master branch.

In both cases, we use a combination of GitHub Actions and CirrusCI (mainly for FreeBSD and macOS M1) to create our release binaries. build_releases.yml contains the GitHub Action workflow used to do both of these, if reference is needed.

"},{"location":"contribution/packaging-and-distribution/#building-manually","title":"Building manually","text":"

If you want to manually build bottom rather than distributing a pre-built binary, you'll need the most recent version of stable Rust, which you can get with:

rustup update stable\n

You'll then want to build with:

cargo build --release --locked\n
"},{"location":"contribution/packaging-and-distribution/#manpage-and-completion-generation","title":"Manpage and completion generation","text":"

bottom uses a build.rs script to automatically generate a manpage and shell completions for the following shells:

  • Bash
  • Zsh
  • Fish
  • Powershell
  • Elvish

If you want to generate manpages and/or completion files, set the BTM_GENERATE env var to a non-empty value. For example, run something like this:

BTM_GENERATE=true cargo build --release --locked\n

This will automatically generate completion and manpage files in target/tmp/bottom/. If you wish to regenerate the files, modify/delete either these files or set BTM_GENERATE to some other non-empty value to retrigger the build script.

For more information, you may want to look at either the build.rs file or the binary build CI workflow.

"},{"location":"contribution/packaging-and-distribution/#adding-an-installation-source","title":"Adding an installation source","text":"

Once you've finished your installation source, if you want to mention it in the main bottom repo, fork the repo and add the installation method and any details to the README.md file under the Installation section, as well as a corresponding table of contents entry. Once that's done, open a pull request - these will usually be approved of very quickly.

You can find more info on the contribution process here.

"},{"location":"contribution/development/build_process/","title":"Build Process","text":"

Warning

This section is currently somewhat WIP.

Warning

This section is intended for people who wish to work on/build/distribute bottom, not general users.

"},{"location":"contribution/development/build_process/#overview","title":"Overview","text":"

bottom manages its own binary builds for nightly and stable release purposes. The core build workflow is handled by build_releases.yml, called by a wrapper workflow for nightly and stable releases. Builds take place via GitHub Actions.

The main things built are:

  • Binaries for various platforms
  • MSI installer for Windows
  • .deb package for Debian and its derivatives

This documentation gives a high-level overview of the build process for each part. For the most up-to-date and detailed reference, definitely refer back to the build_releases.yml file.

"},{"location":"contribution/development/build_process/#binaries","title":"Binaries","text":"

Binaries are built currently for various targets. Note that not all of these are officially supported. The following general steps are performed:

  • Set up the Rust toolchain for the action runner.
  • Enable cache.
  • Build a release build with:

    • --features deploy, which enables only crates needed for release builds.
    • --locked to lock the dependency versions.
    • The following env variables set:

      • BTM_GENERATE: true
      • COMPLETION_DIR: \"target/tmp/bottom/completion/\"
      • MANPAGE_DIR: \"target/tmp/bottom/manpage/\"

      These generate the manpages and shell completions (see Packaging for some more information).

  • Bundle the binaries and manpage/completions.
  • Cleanup.

Some builds use cross to do cross-compilation builds for architectures otherwise not natively supported by the runner.

"},{"location":"contribution/development/build_process/#msi","title":"MSI","text":"

This builds a full Windows installer using cargo-wix. This requires some setup beforehand with some dependencies:

  • Net-Framework-Core (handled by Powershell)
  • wixtoolset (handled by chocolatey)
  • Rust toolchain

After that, cache is enabled, and cargo wix takes care of the rest.

"},{"location":"contribution/development/build_process/#deb","title":".deb","text":"

Currently, .deb files are built for x86 and ARM architectures (armv7, aarch64). This is handled by cargo-deb.

  • For x86, this is handled natively with just cargo-deb.
  • For ARM, this uses a Docker container, cargo-deb-arm, which correctly sets the dependencies and architecture for the generated .deb file.

There are additional checks via dpkg to ensure the architecture is correctly set.

"},{"location":"contribution/development/deploy_process/","title":"Deploy Process","text":"

Warning

This section is currently WIP.

Warning

This section is intended for people who wish to work on/build/distribute bottom, not general users.

"},{"location":"contribution/development/deploy_process/#overview","title":"Overview","text":"

bottom currently has two main deploy processes to worry about:

  • Nightly: a daily (00:00 UTC) GitHub action to build binary/installer files, and upload them to the nightly release. It can also be triggered manually as either a proper nightly release or a mock release.
  • Stable: a stable deployment, triggered manually or upon creation of a valid tag. This is a GitHub action that builds binary/installer files and uploads them to a new GitHub release.

    Furthermore, this workflow does not handle the following deployments, which must be manually handled:

    • Chocolatey
    • crates.io
"},{"location":"contribution/development/deploy_process/#nightly","title":"Nightly","text":"

This is, for the most part, automatic, though it can also be used as a way of testing build workflow changes and seeing if binaries can be successfully built at all against all the targets we want to build for.

If one does not want to actually update the nightly release, and just want to test the general builds and workflow, one can run the workflow manually on a branch of choice with \"mock\" set as the parameter. Changing it to anything else will trigger a non-mock run.

"},{"location":"contribution/development/deploy_process/#stable","title":"Stable","text":"

This can be manually triggered, though the general use-case is setting a tag of the form x.y.z (after checking everything is good, of course). For example:

git tag 0.6.9 && git push origin 0.6.9\n

This will automatically trigger the deployment workflow, and create a draft release with the files uploaded. One still needs to fill in the details and release it.

Furthermore, there are some deployments that are handled by maintainers of bottom that this workflow does not automatically finish. These must be manually handled.

"},{"location":"contribution/development/deploy_process/#chocolatey","title":"Chocolatey","text":"

Upon releasing on GitHub, choco-bottom will automatically be updated with a new PR with the correct deployment files for Chocolatey. Check the PR, merge it if it is correct, then pull locally and deploy following the instructions in the README. Make sure to test installation and running at least once before deploying!

If done correctly, there should be a new build on Chocolatey, which will take some time to validate.

"},{"location":"contribution/development/deploy_process/#cratesio","title":"crates.io","text":"

Validate everything builds properly and works (you should have done this before releasing though). If good, then deploying on crates.io is as simple as:

cargo publish\n
"},{"location":"contribution/development/dev_env/","title":"Development Environment","text":"

Warning

This section is currently WIP.

Warning

This section is intended for people who wish to work on/build/distribute bottom, not general users.

"},{"location":"contribution/development/logging/","title":"Logging","text":"

Warning

This section is currently WIP.

Warning

This section is intended for people who wish to work on/build/distribute bottom, not general users.

"},{"location":"contribution/development/testing/","title":"Testing","text":"

Warning

This section is currently WIP.

Warning

This section is intended for people who wish to work on/build/distribute bottom, not general users.

"},{"location":"support/official/","title":"Official support","text":"

bottom officially supports the following operating systems and corresponding architectures:

  • macOS (x86_64, aarch64)
  • Linux (x86_64, i686, aarch64)
  • Windows (x86_64, i686)

These platforms are tested to work (with caveats, see below) and issues on these platforms will be fixed if possible.

Furthermore, binaries are expected to be built and tested using the most recent version of stable Rust - if you are manually building bottom from the repo/source, then please try that as well.

"},{"location":"support/official/#known-problems","title":"Known problems","text":""},{"location":"support/official/#linux","title":"Linux","text":"
  • If you're using Linux via WSL or WSL2:
    • You may have issues with getting memory data.
    • Temperature sensors may not be correctly reported.
    • WSL2 will not match Windows' own Task Manager in terms of data.
"},{"location":"support/official/#windows","title":"Windows","text":"
  • The temperature widget seems to require admin privileges in some cases to get data.
  • The battery widget seems to have issues with dual battery systems, like some Thinkpads.
  • If you are using WSL or WSL2:
    • You may have issues with getting memory data.
    • Temperature sensors may not be correctly reported.
    • WSL2 will not match Windows' own Task Manager in terms of data.
"},{"location":"support/official/#macos","title":"macOS","text":"
  • The process widget may require elevated access (ex: sudo btm) to gather all data in some cases. Please note that you should be certain that you trust any software you grant root privileges.
"},{"location":"support/unofficial/","title":"Unofficial support","text":"

Systems and architectures that aren't officially supported may still work, but there are no guarantees on how much will work. For example, it might only compile, or it might run with bugs/broken features. Furthermore, while it will depend on the problem at the end of the day, issues on unsupported platforms are likely to go unfixed.

Unofficially supported platforms known to compile/work:

  • FreeBSD
  • Linux on ARMv7 and ARMv6 (tested to compile in CI)
  • Linux on PowerPC 64 LE (tested to compile in CI)
  • Linux on an RISC-V (tested to compile in CI, tested to run on an Allwinner D1 Nezha)
"},{"location":"support/unofficial/#known-problems","title":"Known problems","text":"

None at the moment.

"},{"location":"usage/basic-mode/","title":"Basic Mode","text":"

Basic mode is a special layout that removes all of the graphs and provides an interface that resembles (a very stripped-down version of) htop.

Basic mode can be enabled either through a command line flag:

btm -b\n\n# or\n\nbtm --basic\n

or through the config:

[flags]\nbasic = true\n
"},{"location":"usage/basic-mode/#notes","title":"Notes","text":"

In this mode, widgets that use tables (temperatures, processes, disks, and batteries) are only shown one at a time. One can switch between these widgets either by clicking the arrow buttons or by using the general widget selection shortcuts (for example, Ctrl+Left or H) to switch which widget is shown.

Also note that in this mode, widget expansion and custom layouts are disabled.

"},{"location":"usage/basic-mode/#key-bindings","title":"Key bindings","text":"

Basic mode follows the same key bindings as normal, barring widget expansion being disabled, and that the % key while selecting the memory widget toggles between total usage and percentage.

"},{"location":"usage/general-usage/","title":"General Usage","text":"

You can run bottom with:

btm\n

For help regarding the command-line flags, use:

# For a simple overview of flags\nbtm -h\n\n# For more details\nbtm --help\n

You can also see keybinds and basic usage details in bottom by pressing ?, which will open a help menu.

"},{"location":"usage/general-usage/#features","title":"Features","text":""},{"location":"usage/general-usage/#expansion","title":"Expansion","text":"

By default, bottom is somewhat like a dashboard - a bunch of different widgets, all showing different things, and they all cram together to fit into one terminal.

If you instead just want to see one widget - maybe you want to look at a graph in more detail, for example - you can \"expand\" the currently selected widget using the e key, which will hide all other widgets and make that widget take up all available terminal space.

You can leave this state by either pressing e again or pressing Esc.

"},{"location":"usage/general-usage/#widget-selection","title":"Widget selection","text":"

To allow for widget-specific keybindings and expansion, there is the idea of widget selection in bottom, where you can focus on a specific widget to work with it. This can be done with the mouse (just click on the widget of interest) or keyboard (ex: Ctrl+Direction, see Key bindings for alternatives).

"},{"location":"usage/general-usage/#key-bindings","title":"Key bindings","text":"

These are global or common keyboard shortcuts for the application, which you can see in-app through the ? shortcut. Note that key bindings are generally case-sensitive.

Binding Action q , Ctrl+c Quit Esc Close dialog windows, search, widgets, or exit expanded mode Ctrl+r Reset display and any collected data f Freeze/unfreeze updating with new data ? Open help menu e Toggle expanding the currently selected widget Ctrl+Up Shift+Up K W Select the widget above Ctrl+Down Shift+Down J S Select the widget below Ctrl+Left Shift+Left H A Select the widget on the left Ctrl+Right Shift+Right L D Select the widget on the right Up , k Move up within a widget Down , j Move down within a widget Left h Alt+h Move left within a widget Right l Alt+l Move right within a widget g+g , Home Jump to the first entry G , End Jump to the last entry Page Up , Page Down Scroll up/down a table by a page Ctrl+u Scroll up a table by half a page Ctrl+d Scroll down a table by half a page"},{"location":"usage/general-usage/#mouse-bindings","title":"Mouse bindings","text":"Binding Action Left Button Selects the widget"},{"location":"usage/widgets/battery/","title":"Battery Widget","text":"

Warning

The battery features are unavailable if the binary is compiled with the battery feature disabled or if there are no batteries on the system!

The battery widget provides information about batteries on the system.

The battery widget can be enabled through either the --battery flag, the battery = true option in a config file, or specifying the widget in a custom layout.

"},{"location":"usage/widgets/battery/#features","title":"Features","text":"

The following data is displayed for batteries:

  • Charge percent
  • Consumption rate
  • Charging state
  • Time to empty/charge, based on the current state
  • Battery health percent

The battery widget also supports devices with multiple batteries, and you can switch between them using the keyboard or the mouse.

"},{"location":"usage/widgets/battery/#key-bindings","title":"Key bindings","text":"

Note that key bindings are generally case-sensitive.

Binding Action Left h Alt+h Moves to the battery entry to the left of the current one Right l Alt+l Moves to the battery entry to the right of the current one"},{"location":"usage/widgets/battery/#mouse-bindings","title":"Mouse bindings","text":"Binding Action Left Button Selects a battery entry"},{"location":"usage/widgets/cpu/","title":"CPU Widget","text":"

The CPU widget displays a visual representation of CPU usage over a time range.

"},{"location":"usage/widgets/cpu/#features","title":"Features","text":"

The CPU widget is composed of two parts: the graph and the legend:

  • The graph displays the usage data for the currently selected entry as a percentage
  • The legend displays all available entries that can be displayed on the graph along with their last recorded use percentage (except for the \"All\" option)

Users can scroll through the legend using either the keyboard or mouse to select which entry to display on the graph. The \"All\" option shows every entry at the same time, though this may get a bit hard to follow if you have a large number of cores/threads.

One can also adjust the displayed time range through either the keyboard or mouse, with a range of 30s to 600s.

"},{"location":"usage/widgets/cpu/#key-bindings","title":"Key bindings","text":"

Note that key bindings are generally case-sensitive.

"},{"location":"usage/widgets/cpu/#graph","title":"Graph","text":"Binding Action + Zoom in on chart (decrease time range) - Zoom out on chart (increase time range) = Reset zoom"},{"location":"usage/widgets/cpu/#legend","title":"Legend","text":"Binding Action Up , k Move up within a widget Down , j Move down within a widget g+g , Home Jump to the first entry in the legend G , End Jump to the last entry in the legend"},{"location":"usage/widgets/cpu/#mouse-bindings","title":"Mouse bindings","text":""},{"location":"usage/widgets/cpu/#graph_1","title":"Graph","text":"Binding Action Scroll Scrolling up or down zooms in or out of the graph respectively"},{"location":"usage/widgets/cpu/#legend_1","title":"Legend","text":"Binding Action Scroll Scroll through options to display in the graph Left Button Selects a CPU thread/average to show in the graph"},{"location":"usage/widgets/disk/","title":"Disk Widget","text":"

The disk widget provides a table of useful disk and partition information, like I/O per second and total usage.

"},{"location":"usage/widgets/disk/#features","title":"Features","text":"

The disk widget provides the following information:

  • Disk name
  • Disk mount location
  • Amount of space used
  • Amount of space left
  • Total amount of space
  • Percentage of space used
  • Read per second
  • Write per second
"},{"location":"usage/widgets/disk/#key-bindings","title":"Key bindings","text":"

Note that key bindings are generally case-sensitive.

Binding Action Up , k Move up within a widget Down , j Move down within a widget g+g , Home Jump to the first entry in the table G , End Jump to the last entry in the table d Sort by disk, press again to reverse sorting order m Sort by mount, press again to reverse sorting order u Sort by amount used, press again to reverse sorting order n Sort by amount free, press again to reverse sorting order t Sort by total space available, press again to reverse sorting order p Sort by percentage used, press again to reverse sorting order r Sort by read rate, press again to reverse sorting order w Sort by write rate, press again to reverse sorting order"},{"location":"usage/widgets/disk/#mouse-bindings","title":"Mouse bindings","text":"Binding Action Left Button Selects an entry in the table"},{"location":"usage/widgets/memory/","title":"Memory Widget","text":"

The memory widget provides a visual representation of RAM and swap usage over time.

"},{"location":"usage/widgets/memory/#features","title":"Features","text":"

The legend displays the current usage in terms of percentage and actual usage in binary units (KiB, MiB, GiB, etc.). If the total RAM or swap available is 0, then it is automatically hidden from the legend and graph.

One can also adjust the displayed time range through either the keyboard or mouse, with a range of 30s to 600s.

This widget can also be configured to display Nvidia GPU memory usage (--enable_gpu_memory) or cache memory usage (--enable_cache_memory).

"},{"location":"usage/widgets/memory/#key-bindings","title":"Key bindings","text":"

Note that key bindings are generally case-sensitive.

Binding Action + Zoom in on chart (decrease time range) - Zoom out on chart (increase time range) = Reset zoom"},{"location":"usage/widgets/memory/#mouse-bindings","title":"Mouse bindings","text":"Binding Action Scroll Scrolling up or down zooms in or out of the graph respectively"},{"location":"usage/widgets/memory/#calculations","title":"Calculations","text":"

Memory usage is calculated using the following formula based on values from /proc/meminfo (based on htop's implementation):

MemTotal - MemFree - Buffers - (Cached + SReclaimable - Shmem)\n

You can find more info on /proc/meminfo and its fields here.

"},{"location":"usage/widgets/network/","title":"Network Widget","text":"

The network widget provides a visual representation of network input and output per second, as well as noting the total amount received and transmitted.

"},{"location":"usage/widgets/network/#features","title":"Features","text":"

The legend displays the current reads and writes per second in bits, as well as the total amount read/written.

The y-axis automatically scales based on shown read/write values, and by default, is a linear scale based on base-10 units (e.x. kilobit, gigabit, etc.). Through configuration, the read/write per second unit can be changed to bytes, while the y-axis can be changed to a log scale and/or use base-2 units (e.x. kibibit, gibibit, etc.).

One can also adjust the displayed time range through either the keyboard or mouse, with a range of 30s to 600s.

"},{"location":"usage/widgets/network/#key-bindings","title":"Key bindings","text":"

Note that key bindings are generally case-sensitive.

Binding Action + Zoom in on chart (decrease time range) - Zoom out on chart (increase time range) = Reset zoom"},{"location":"usage/widgets/network/#mouse-bindings","title":"Mouse bindings","text":"Binding Action Scroll Scrolling up or down zooms in or out of the graph respectively"},{"location":"usage/widgets/process/","title":"Process Widget","text":"

The process widget displays a table containing information regarding a running process, along with sorting, searching, and process control features.

"},{"location":"usage/widgets/process/#features","title":"Features","text":"

The process widget has three main components:

  • The main process table
  • The search sub-widget (opened with Ctrl+f or /)
  • The sort menu sub-widget (opened with s or F6)

By default, the main process table displays the following information for each process:

  • PID
  • Name of the process
  • CPU use percentage (note this is averaged out per available thread by default)
  • Memory use percentage
  • Reads per second
  • Writes per second
  • Total amount read
  • Total amount written
  • User
  • Process state

It can also additionally display the following columns:

  • Process running time

See the processes configuration page on how to customize which columns are shown.

"},{"location":"usage/widgets/process/#sorting","title":"Sorting","text":"

The table can be sorted by clicking on the table headers, which will either sort the table by that column, or if already sorting by that column, reverse the sorting order.

Alternatively, one can sort using the sort menu sub-widget, which is brought up using s or F6, and can be controlled by arrow keys or the mouse.

"},{"location":"usage/widgets/process/#grouping","title":"Grouping","text":"

Pressing Tab in the table will group entries with the same name together. The PID column will be replaced with the number of entries in each group, and usage is added together when displayed.

Note that the process state and user columns are disabled in this mode.

"},{"location":"usage/widgets/process/#process-termination","title":"Process termination","text":"

Pressing d+d or F9 will allow you to terminate the currently selected process/process group. On Unix-like operating systems, you are also able to control which specific signals to send (e.g. SIGKILL, SIGTERM).

The process termination menu on Linux

If you're on Windows, or if the disable_advanced_kill flag is set in the options or command-line, then a simpler termination screen will be shown to confirm whether you want to kill that process/process group.

The process termination menu on Windows"},{"location":"usage/widgets/process/#tree-mode","title":"Tree mode","text":"

Pressing t or F5 in the table toggles tree mode in the process widget, displaying processes in regards to their parent-child process relationships.

A process in tree mode can also be \"collapsed\", hiding its children and any descendants, using either the - or + keys, or double clicking on an entry.

Lastly, note that in tree mode, processes cannot be grouped together due to the behaviour of the two modes somewhat clashing.

"},{"location":"usage/widgets/process/#full-command","title":"Full command","text":"

You can show the full command instead of just the process name by pressing P.

"},{"location":"usage/widgets/process/#search","title":"Search","text":"

Pressing / or Ctrl+f will open up the search sub-widget. By default, just typing in something will search by the process name.

This search can be further enhanced by matching by case, matching the entire word, or by regex.

We are able to also search for multiple things/conditions.

And if our search uses a keyword, we need to use quotation marks around the term to properly search it.

Lastly, we can refine our search even further based on the other columns, like PID, CPU usage, etc., as well as grouping together conditions.

You can also paste search queries (e.g. Shift+Ins, Ctrl+Shift+v).

"},{"location":"usage/widgets/process/#keywords","title":"Keywords","text":"

Note all keywords are case-insensitive. To search for a process/command that collides with a keyword, surround the term with quotes (e.x. \"cpu\").

Keywords Example Description btm Matches by process or command name; supports regex pid pid=1044 Matches by PID; supports regex cpu cpu% cpu > 0.5 Matches the CPU column; supports comparison operators memb memb > 1000 b Matches the memory column in terms of bytes; supports comparison operators mem mem% mem < 0.5 Matches the memory column in terms of percent; supports comparison operators read r/s rps read = 1 mb Matches the read/s column in terms of bytes; supports comparison operators write w/s wps write >= 1 kb Matches the write/s column in terms of bytes; supports comparison operators tread t.read tread <= 1024 gb Matches he total read column in terms of bytes; supports comparison operators twrite t.write twrite > 1024 tb Matches the total write column in terms of bytes; supports comparison operators user user=root Matches by user; supports regex state state=running Matches by state; supports regex () (<COND 1> AND <COND 2>) OR <COND 3> Group together a condition"},{"location":"usage/widgets/process/#comparison-operators","title":"Comparison operators","text":"Keywords Description = Checks if the values are equal > Checks if the left value is strictly greater than the right < Checks if the left value is strictly less than the right >= Checks if the left value is greater than or equal to the right <= Checks if the left value is less than or equal to the right"},{"location":"usage/widgets/process/#logical-operators","title":"Logical operators","text":"

Note all operators are case-insensitive, and the and operator takes precedence over the or operator.

Keywords Usage Description and && <Space> <COND 1> and <COND 2> <COND 1> && <COND 2> <COND 1> <COND 2> Requires both conditions to be true to match or || <COND 1> or <COND 2> <COND 1> &#124;&#124; <COND 2> Requires at least one condition to be true to match"},{"location":"usage/widgets/process/#units","title":"Units","text":"

All units are case-insensitive.

Keywords Description B Bytes KB Kilobytes MB Megabytes GB Gigabytes TB Terabytes KiB Kibibytes MiB Mebibytes GiB Gibibytes TiB Tebibytes"},{"location":"usage/widgets/process/#key-bindings","title":"Key bindings","text":"

Note that key bindings are generally case-sensitive.

"},{"location":"usage/widgets/process/#process-table","title":"Process table","text":"Binding Action Up , k Move up within a widget Down , j Move down within a widget g+g , Home Jump to the first entry in the table G , End Jump to the last entry in the table d+d , F9 Send a kill signal to the selected process c Sort by CPU usage, press again to reverse sorting order m Sort by memory usage, press again to reverse sorting order p Sort by PID name, press again to reverse sorting order n Sort by process name, press again to reverse sorting order Tab Toggle grouping processes with the same name P Toggle between showing the full command or just the process name Ctrl+f , / Toggle showing the search sub-widget s , F6 Toggle showing the sort sub-widget I Invert the current sort % Toggle between values and percentages for memory usage t , F5 Toggle tree mode"},{"location":"usage/widgets/process/#sort-sub-widget","title":"Sort sub-widget","text":"Binding Action Up , k Move up within a widget Down , j Move down within a widget g+g , Home Jump to the first entry in the table G , End Jump to the last entry in the table Esc Close the sort sub-widget Enter Sorts the corresponding process table"},{"location":"usage/widgets/process/#search-sub-widget","title":"Search sub-widget","text":"Binding Action Left h Alt+h Moves the cursor left Right l Alt+l Moves the cursor right Esc Close the search widget (retains the filter) Ctrl+a Skip to the start of the search query Ctrl+e Skip to the end of the search query Ctrl+u Clear the current search query Ctrl+w Delete a word behind the cursor Ctrl+h Delete the character behind the cursor Backspace Delete the character behind the cursor Del Delete the character at the cursor Alt+c , F1 Toggle matching case Alt+w , F2 Toggle matching the entire word Alt+r , F3 Toggle using regex"},{"location":"usage/widgets/process/#mouse-bindings","title":"Mouse bindings","text":""},{"location":"usage/widgets/process/#process-table_1","title":"Process table","text":"Binding Action Scroll Selects a CPU thread/average to show in the graph Left Button Table header: Sorts/reverse sorts the table by the column Table entry: Selects an entry in the table, if in tree mode, collapses/expands the entry's children"},{"location":"usage/widgets/process/#sort-sub-widget_1","title":"Sort sub-widget","text":"Binding Action Left Button Selects an entry in the table"},{"location":"usage/widgets/temperature/","title":"Temperature Widget","text":"

The temperature widget provides a table of temperature sensors and their current temperature.

"},{"location":"usage/widgets/temperature/#features","title":"Features","text":"

The temperature widget provides the sensor name as well as its current temperature.

"},{"location":"usage/widgets/temperature/#key-bindings","title":"Key bindings","text":"

Note that key bindings are generally case-sensitive.

Binding Action Up , k Move up within a widget Down , j Move down within a widget g+g , Home Jump to the first entry in the table G , End Jump to the last entry in the table t Sort by temperature, press again to reverse sorting order s Sort by sensor name, press again to reverse sorting order"},{"location":"usage/widgets/temperature/#mouse-bindings","title":"Mouse bindings","text":"Binding Action Left Button Selects an entry in the table"}]} \ No newline at end of file diff --git a/0.9.6/sitemap.xml b/0.9.6/sitemap.xml new file mode 100644 index 00000000..91ee420e --- /dev/null +++ b/0.9.6/sitemap.xml @@ -0,0 +1,143 @@ + + + + https://clementtsang.github.io/bottom/0.9.6/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/troubleshooting/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/configuration/command-line-flags/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/configuration/config-file/data-filtering/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/configuration/config-file/default-config/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/configuration/config-file/flags/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/configuration/config-file/layout/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/configuration/config-file/processes/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/configuration/config-file/theming/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/documentation/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/issues-and-pull-requests/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/packaging-and-distribution/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/development/build_process/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/development/deploy_process/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/development/dev_env/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/development/logging/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/contribution/development/testing/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/support/official/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/support/unofficial/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/basic-mode/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/general-usage/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/widgets/battery/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/widgets/cpu/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/widgets/disk/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/widgets/memory/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/widgets/network/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/widgets/process/ + 2023-08-27 + daily + + + https://clementtsang.github.io/bottom/0.9.6/usage/widgets/temperature/ + 2023-08-27 + daily + + \ No newline at end of file diff --git a/0.9.6/sitemap.xml.gz b/0.9.6/sitemap.xml.gz new file mode 100644 index 00000000..3d1c86d7 Binary files /dev/null and b/0.9.6/sitemap.xml.gz differ diff --git a/0.9.6/stylesheets/extra.css b/0.9.6/stylesheets/extra.css new file mode 100644 index 00000000..b7e75d05 --- /dev/null +++ b/0.9.6/stylesheets/extra.css @@ -0,0 +1,12 @@ +:root { + --md-primary-fg-color: #268bd2; + --md-accent-fg-color: #81a1c1; +} + +.md-typeset__table { + min-width: 100%; +} + +.md-typeset table:not([class]) { + display: table; +} diff --git a/0.9.6/support/official/index.html b/0.9.6/support/official/index.html new file mode 100644 index 00000000..93084aa0 --- /dev/null +++ b/0.9.6/support/official/index.html @@ -0,0 +1,1181 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Official Support - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Official support

+

bottom officially supports the following operating systems and corresponding architectures:

+
    +
  • macOS (x86_64, aarch64)
  • +
  • Linux (x86_64, i686, aarch64)
  • +
  • Windows (x86_64, i686)
  • +
+

These platforms are tested to work (with caveats, see below) and issues on these platforms will be fixed if possible.

+

Furthermore, binaries are expected to be built and tested using the most recent version of stable Rust - if you are manually building +bottom from the repo/source, then please try that as well.

+

Known problems

+

Linux

+
    +
  • If you're using Linux via WSL or WSL2:
      +
    • You may have issues with getting memory data.
    • +
    • Temperature sensors may not be correctly reported.
    • +
    • WSL2 will not match Windows' own Task Manager in terms of data.
    • +
    +
  • +
+

Windows

+
    +
  • The temperature widget seems to require admin privileges in some cases to get data.
  • +
  • The battery widget seems to have issues with dual battery systems, like some Thinkpads.
  • +
  • If you are using WSL or WSL2:
      +
    • You may have issues with getting memory data.
    • +
    • Temperature sensors may not be correctly reported.
    • +
    • WSL2 will not match Windows' own Task Manager in terms of data.
    • +
    +
  • +
+

macOS

+
    +
  • The process widget may require elevated access (ex: sudo btm) to gather all data in some cases. Please note that you should be certain that you trust any software you grant root privileges.
  • +
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/support/unofficial/index.html b/0.9.6/support/unofficial/index.html new file mode 100644 index 00000000..55633175 --- /dev/null +++ b/0.9.6/support/unofficial/index.html @@ -0,0 +1,1132 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Unofficial Support - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Unofficial support

+

Systems and architectures that aren't officially supported may still work, but there are no guarantees on how much will +work. For example, it might only compile, or it might run with bugs/broken features. Furthermore, while it will depend +on the problem at the end of the day, issues on unsupported platforms are likely to go unfixed.

+

Unofficially supported platforms known to compile/work:

+
    +
  • FreeBSD
  • +
  • Linux on ARMv7 and ARMv6 (tested to compile in CI)
  • +
  • Linux on PowerPC 64 LE (tested to compile in CI)
  • +
  • Linux on an RISC-V (tested to compile in CI, tested to run on an Allwinner D1 Nezha)
  • +
+

Known problems

+

None at the moment.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/troubleshooting/index.html b/0.9.6/troubleshooting/index.html new file mode 100644 index 00000000..efb98e97 --- /dev/null +++ b/0.9.6/troubleshooting/index.html @@ -0,0 +1,1334 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + Troubleshooting - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Troubleshooting

+

The graph points look broken/strange

+

It's possible that your graphs won't look great out of the box due to the reliance on braille fonts to draw them. One +example of this is seeing a bunch of missing font characters, caused when the terminal isn't configured properly to +render braille fonts.

+
+ Example of a terminal with no braille font. +
An example of missing braille fonts in Powershell
+
+ +

One alternative is to use the --dot_marker option to render graph charts using dots instead of the braille characters, +which generally seems better supported out of the box, at the expense of looking less intricate:

+
+ Example of running bottom with the dot marker flag +
Example using btm --dot_marker
+
+ +

Another (better) alternative is to install a font that supports braille fonts, and configure your terminal emulator to use it. +For example, installing something like UBraille or Iosevka +and ensuring your terminal uses it should work.

+

Braille font issues on Linux/macOS/Unix-like

+

Generally, the problem comes down to you either not having a font that supports the braille markers, or your terminal +emulator is not using the correct font for the braille markers.

+

See here for possible fixes if you're having font issues on Linux, which +may also be helpful for macOS or other Unix-like systems.

+

If you're still having issues, feel free to open a discussion +question about it.

+

Installing fonts for Windows Command Prompt/PowerShell

+

Note: I would advise backing up your registry beforehand if you aren't sure what you are doing!

+

Let's say you're installing Iosevka. The steps you can take are:

+
    +
  1. Install the font itself.
  2. +
  3. Open the registry editor, which you can do either by Win+R and opening regedit, or just opening it from the Start Menu.
  4. +
  5. +

    In the registry editor, go to

    +
    HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Console\TrueTypeFont
    +
    +
  6. +
  7. +

    Here, add a new String value, and set the Name to a bunch of 0's (e.g. 000 - make sure the name isn't already used), then set the Data to the font name (e.g. Iosevka).

    +
  8. +
+
+ Regedit menu showing how to add a new font for Command Prompt/PowerShell +
The last entry is the new entry for Iosevka
+
+ +
    +
  1. Then, open the Command Prompt/PowerShell, and right click on the top bar, and open "Properties":
  2. +
+
+ Opening the properties menu in Command Prompt/PowerShell +
+ +
    +
  1. From here, go to "Font", and set the font to your new font (so in this example, Iosevka):
  2. +
+
+ Setting a new font in Command Prompt/PowerShell +
+ +

Why can't I see all my temperature sensors on Windows?

+

This is a known limitation, some sensors may require admin privileges to get sensor data.

+

Why don't I see dual batteries on Windows reported separately? (e.g. Thinkpads)

+

This is a known limitation which seems to be with how batteries are being detected on Windows.

+

Why can't I see all my temperature sensors on WSL?

+

This is a known limitation with WSL. Due to how it works, hosts may not expose their +temperature sensors and therefore, temperature sensors might be missing.

+

Why does WSL2 not match Task Manager?

+

This is a known limitation with WSL2. Due to how WSL2 works, the two might not match +up in terms of reported data.

+

Why can't I see all my processes/process data on macOS?

+

This is a known limitation, and you may have to run the program with elevated +privileges to work around it - for example:

+
sudo btm
+
+

Please note that you should be certain that you trust any software you grant root privileges.

+

There are measures taken to try to maximize the amount of information obtained without elevated privileges. For example, +one can modify the instructions found on the htop wiki +on how to run htop without sudo for bottom. However please understand the potential security risks before doing so!

+

My configuration file isn't working

+

If your configuration files aren't working, here are a few things to try:

+

Check the formatting

+

It may be handy to refer to the automatically generated config files or the sample configuration files. +The config files also follow the TOML format.

+

Also make sure your config options are under the right table - for example, to set your temperature type, you must set it under the [flags] table:

+
[flags]
+temperature_type = "f"
+
+

Meanwhile, if you want to set a custom color scheme, it would be under the [colors] table:

+
[colors]
+table_header_color="LightBlue"
+
+

Check the configuration file location

+

Make sure bottom is reading the right configuration file. By default, bottom looks for config files at these locations:

+ + + + + + + + + + + + + + + + + + + + + +
OSDefault Config Location
macOS$HOME/Library/Application Support/bottom/bottom.toml
~/.config/bottom/bottom.toml
$XDG_CONFIG_HOME/bottom/bottom.toml
Linux~/.config/bottom/bottom.toml
$XDG_CONFIG_HOME/bottom/bottom.toml
WindowsC:\Users\<USER>\AppData\Roaming\bottom\bottom.toml
+

If you want to use a config file in another location, use the --config or -C flags along with the path to the configuration file, like so:

+
btm -C path_to_config
+
+

My installation through snap has some widgets that are blank/show no data

+

Make sure bottom is given the correct permissions in order to collect data. Snapcraft +explains how to do so, but the TL;DR is:

+
sudo snap connect bottom:mount-observe
+sudo snap connect bottom:hardware-observe
+sudo snap connect bottom:system-observe
+sudo snap connect bottom:process-control
+
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/basic-mode/index.html b/0.9.6/usage/basic-mode/index.html new file mode 100644 index 00000000..c8d94451 --- /dev/null +++ b/0.9.6/usage/basic-mode/index.html @@ -0,0 +1,1150 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Basic Mode - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Basic Mode

+

Basic mode is a special layout that removes all of the graphs and provides an interface that resembles (a very stripped-down version of) htop.

+
+ A picture of bottom's basic mode. +
+ +

Basic mode can be enabled either through a command line flag:

+
btm -b
+
+# or
+
+btm --basic
+
+

or through the config:

+
[flags]
+basic = true
+
+

Notes

+

In this mode, widgets that use tables (temperatures, processes, disks, and batteries) are only shown one at a time. +One can switch between these widgets either by clicking the arrow buttons or by using the general widget selection shortcuts (for example, Ctrl+Left or H) +to switch which widget is shown.

+

Also note that in this mode, widget expansion and custom layouts are disabled.

+

Key bindings

+

Basic mode follows the same key bindings as normal, barring widget expansion being disabled, and that the % key while selecting the memory widget toggles between total usage and percentage.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/general-usage/index.html b/0.9.6/usage/general-usage/index.html new file mode 100644 index 00000000..baf26e1a --- /dev/null +++ b/0.9.6/usage/general-usage/index.html @@ -0,0 +1,1278 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + General Usage - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

General Usage

+

You can run bottom with:

+
btm
+
+

For help regarding the command-line flags, use:

+
# For a simple overview of flags
+btm -h
+
+# For more details
+btm --help
+
+

You can also see keybinds and basic usage details in bottom by pressing ?, which will open a help menu.

+

Features

+

Expansion

+

By default, bottom is somewhat like a dashboard - a bunch of different widgets, all showing different things, and they all cram together to fit into one terminal.

+

If you instead just want to see one widget - maybe you want to look at a graph in more detail, for example - you can "expand" the currently selected +widget using the e key, which will hide all other widgets and make that widget take up all available terminal space.

+

You can leave this state by either pressing e again or pressing Esc.

+

Widget selection

+

To allow for widget-specific keybindings and expansion, there is the idea of widget selection in bottom, where you can focus on a specific widget to work with it. +This can be done with the mouse (just click on the widget of interest) or keyboard (ex: Ctrl+Direction, see Key bindings for alternatives).

+

Key bindings

+

These are global or common keyboard shortcuts for the application, which you can see in-app through the ? shortcut. +Note that key bindings are generally case-sensitive.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
BindingAction
q , Ctrl+cQuit
EscClose dialog windows, search, widgets, or exit expanded mode
Ctrl+rReset display and any collected data
fFreeze/unfreeze updating with new data
?Open help menu
eToggle expanding the currently selected widget
Ctrl+Up
Shift+Up
K
W
Select the widget above
Ctrl+Down
Shift+Down
J
S
Select the widget below
Ctrl+Left
Shift+Left
H
A
Select the widget on the left
Ctrl+Right
Shift+Right
L
D
Select the widget on the right
Up , kMove up within a widget
Down , jMove down within a widget
Left
h
Alt+h
Move left within a widget
Right
l
Alt+l
Move right within a widget
g+g , HomeJump to the first entry
G , EndJump to the last entry
Page Up , Page DownScroll up/down a table by a page
Ctrl+uScroll up a table by half a page
Ctrl+dScroll down a table by half a page
+

Mouse bindings

+ + + + + + + + + + + + + +
BindingAction
Left ButtonSelects the widget
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/widgets/battery/index.html b/0.9.6/usage/widgets/battery/index.html new file mode 100644 index 00000000..3f5e00b2 --- /dev/null +++ b/0.9.6/usage/widgets/battery/index.html @@ -0,0 +1,1189 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Battery Widget - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Battery Widget

+
+

Warning

+

The battery features are unavailable if the binary is compiled with the battery feature disabled or if there are no batteries on the system!

+
+

The battery widget provides information about batteries on the system.

+
+ A picture of an expanded battery widget. +
+ +

The battery widget can be enabled through either the --battery flag, the battery = true option in a config file, or specifying the widget in a custom layout.

+

Features

+

The following data is displayed for batteries:

+
    +
  • Charge percent
  • +
  • Consumption rate
  • +
  • Charging state
  • +
  • Time to empty/charge, based on the current state
  • +
  • Battery health percent
  • +
+

The battery widget also supports devices with multiple batteries, and you can switch between them using the keyboard or the mouse.

+

Key bindings

+

Note that key bindings are generally case-sensitive.

+ + + + + + + + + + + + + + + + + +
BindingAction
Left
h
Alt+h
Moves to the battery entry to the left of the current one
Right
l
Alt+l
Moves to the battery entry to the right of the current one
+

Mouse bindings

+ + + + + + + + + + + + + +
BindingAction
Left ButtonSelects a battery entry
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/widgets/cpu/index.html b/0.9.6/usage/widgets/cpu/index.html new file mode 100644 index 00000000..aa6ac6cd --- /dev/null +++ b/0.9.6/usage/widgets/cpu/index.html @@ -0,0 +1,1275 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + CPU Widget - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

CPU Widget

+

The CPU widget displays a visual representation of CPU usage over a time range.

+
+ A picture of an expanded CPU widget showing average CPU usage. +
+ +

Features

+

The CPU widget is composed of two parts: the graph and the legend:

+
    +
  • The graph displays the usage data for the currently selected entry as a percentage
  • +
  • The legend displays all available entries that can be displayed on the graph along with their last recorded use percentage (except for the "All" option)
  • +
+

Users can scroll through the legend using either the keyboard or mouse to select which entry to display on the graph. The "All" option shows every entry +at the same time, though this may get a bit hard to follow if you have a large number of cores/threads.

+

One can also adjust the displayed time range through either the keyboard or mouse, with a range of 30s to 600s.

+

Key bindings

+

Note that key bindings are generally case-sensitive.

+

Graph

+ + + + + + + + + + + + + + + + + + + + + +
BindingAction
+Zoom in on chart (decrease time range)
-Zoom out on chart (increase time range)
=Reset zoom
+

Legend

+ + + + + + + + + + + + + + + + + + + + + + + + + +
BindingAction
Up , kMove up within a widget
Down , jMove down within a widget
g+g , HomeJump to the first entry in the legend
G , EndJump to the last entry in the legend
+

Mouse bindings

+

Graph

+ + + + + + + + + + + + + +
BindingAction
ScrollScrolling up or down zooms in or out of the graph respectively
+

Legend

+ + + + + + + + + + + + + + + + + +
BindingAction
ScrollScroll through options to display in the graph
Left ButtonSelects a CPU thread/average to show in the graph
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/widgets/disk/index.html b/0.9.6/usage/widgets/disk/index.html new file mode 100644 index 00000000..e5fa2ebc --- /dev/null +++ b/0.9.6/usage/widgets/disk/index.html @@ -0,0 +1,1226 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Disk Widget - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Disk Widget

+

The disk widget provides a table of useful disk and partition information, like I/O per second and total usage.

+
+ A picture of an expanded disk widget. +
+ +

Features

+

The disk widget provides the following information:

+
    +
  • Disk name
  • +
  • Disk mount location
  • +
  • Amount of space used
  • +
  • Amount of space left
  • +
  • Total amount of space
  • +
  • Percentage of space used
  • +
  • Read per second
  • +
  • Write per second
  • +
+

Key bindings

+

Note that key bindings are generally case-sensitive.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
BindingAction
Up , kMove up within a widget
Down , jMove down within a widget
g+g , HomeJump to the first entry in the table
G , EndJump to the last entry in the table
dSort by disk, press again to reverse sorting order
mSort by mount, press again to reverse sorting order
uSort by amount used, press again to reverse sorting order
nSort by amount free, press again to reverse sorting order
tSort by total space available, press again to reverse sorting order
pSort by percentage used, press again to reverse sorting order
rSort by read rate, press again to reverse sorting order
wSort by write rate, press again to reverse sorting order
+

Mouse bindings

+ + + + + + + + + + + + + +
BindingAction
Left ButtonSelects an entry in the table
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/widgets/memory/index.html b/0.9.6/usage/widgets/memory/index.html new file mode 100644 index 00000000..cfba498a --- /dev/null +++ b/0.9.6/usage/widgets/memory/index.html @@ -0,0 +1,1195 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Memory Widget - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Memory Widget

+

The memory widget provides a visual representation of RAM and swap usage over time.

+
+ A picture of an expanded memory widget. +
+ +

Features

+

The legend displays the current usage in terms of percentage and actual usage in binary units (KiB, MiB, GiB, etc.). +If the total RAM or swap available is 0, then it is automatically hidden from the legend and graph.

+

One can also adjust the displayed time range through either the keyboard or mouse, with a range of 30s to 600s.

+

This widget can also be configured to display Nvidia GPU memory usage (--enable_gpu_memory) or cache memory usage (--enable_cache_memory).

+

Key bindings

+

Note that key bindings are generally case-sensitive.

+ + + + + + + + + + + + + + + + + + + + + +
BindingAction
+Zoom in on chart (decrease time range)
-Zoom out on chart (increase time range)
=Reset zoom
+

Mouse bindings

+ + + + + + + + + + + + + +
BindingAction
ScrollScrolling up or down zooms in or out of the graph respectively
+

Calculations

+

Memory usage is calculated using the following formula based on values from /proc/meminfo (based on htop's implementation):

+
MemTotal - MemFree - Buffers - (Cached + SReclaimable - Shmem)
+
+

You can find more info on /proc/meminfo and its fields here.

+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/widgets/network/index.html b/0.9.6/usage/widgets/network/index.html new file mode 100644 index 00000000..30012f0d --- /dev/null +++ b/0.9.6/usage/widgets/network/index.html @@ -0,0 +1,1185 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Network Widget - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Network Widget

+

The network widget provides a visual representation of network input and output per second, as well as noting the total amount +received and transmitted.

+
+ A picture of an expanded network widget. +
+ +

Features

+

The legend displays the current reads and writes per second in bits, as well as the total amount read/written.

+

The y-axis automatically scales based on shown read/write values, and by default, is a linear scale based on base-10 units (e.x. kilobit, gigabit, etc.). +Through configuration, the read/write per second unit can be changed to bytes, while the y-axis can be changed to a +log scale and/or use base-2 units (e.x. kibibit, gibibit, etc.).

+

One can also adjust the displayed time range through either the keyboard or mouse, with a range of 30s to 600s.

+

Key bindings

+

Note that key bindings are generally case-sensitive.

+ + + + + + + + + + + + + + + + + + + + + +
BindingAction
+Zoom in on chart (decrease time range)
-Zoom out on chart (increase time range)
=Reset zoom
+

Mouse bindings

+ + + + + + + + + + + + + +
BindingAction
ScrollScrolling up or down zooms in or out of the graph respectively
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/widgets/process/index.html b/0.9.6/usage/widgets/process/index.html new file mode 100644 index 00000000..5ddb9c1a --- /dev/null +++ b/0.9.6/usage/widgets/process/index.html @@ -0,0 +1,1752 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Process Widget - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Process Widget

+

The process widget displays a table containing information regarding a running process, along with sorting, +searching, and process control features.

+
+ A picture of an expanded process widget by default. +
+ +

Features

+

The process widget has three main components:

+
    +
  • The main process table
  • +
  • The search sub-widget (opened with Ctrl+f or /)
  • +
  • The sort menu sub-widget (opened with s or F6)
  • +
+

By default, the main process table displays the following information for each process:

+
    +
  • PID
  • +
  • Name of the process
  • +
  • CPU use percentage (note this is averaged out per available thread by default)
  • +
  • Memory use percentage
  • +
  • Reads per second
  • +
  • Writes per second
  • +
  • Total amount read
  • +
  • Total amount written
  • +
  • User
  • +
  • Process state
  • +
+

It can also additionally display the following columns:

+
    +
  • Process running time
  • +
+

See the processes configuration page on how to customize which columns +are shown.

+

Sorting

+

The table can be sorted by clicking on the table headers, which will either sort the table by that column, or if already +sorting by that column, reverse the sorting order.

+

Alternatively, one can sort using the sort menu sub-widget, which is brought up using s or F6, and can be controlled by arrow keys or the mouse.

+
+ A picture of an expanded process widget with the sort menu open. +
+ +

Grouping

+

Pressing Tab in the table will group entries with the same name together. The PID column will be replaced with the number of entries in each group, and usage +is added together when displayed.

+
+ A picture of grouped mode in a process widget. +
+ +

Note that the process state and user columns are disabled in this mode.

+

Process termination

+

Pressing d+d or F9 will allow you to terminate the currently selected process/process group. On Unix-like +operating systems, you are also able to control which specific signals to send (e.g. SIGKILL, SIGTERM).

+
+ A picture of the process kill menu on Linux. +
The process termination menu on Linux
+
+ +

If you're on Windows, or if the disable_advanced_kill flag is set in the options or command-line, then a simpler termination +screen will be shown to confirm whether you want to kill that process/process group.

+
+ A picture of the process kill menu on Windows. +
The process termination menu on Windows
+
+ +

Tree mode

+

Pressing t or F5 in the table toggles tree mode in the process widget, displaying processes in regards to their parent-child process relationships.

+
+ A picture of tree mode in a process widget. +
+ +

A process in tree mode can also be "collapsed", hiding its children and any descendants, using either the - or + keys, or double clicking on an entry.

+

Lastly, note that in tree mode, processes cannot be grouped together due to the behaviour of the two modes somewhat clashing.

+

Full command

+

You can show the full command instead of just the process name by pressing P.

+
+ A picture of a process widget using full commands. +
+ + +

Pressing / or Ctrl+f will open up the search sub-widget. By default, just typing in something will search by the process name.

+
+ A picture of searching for a process with a simple search. +
+ +

This search can be further enhanced by matching by case, matching the entire word, or by regex.

+
+ A picture of searching for a process with a search condition that uses regex. +
+ +

We are able to also search for multiple things/conditions.

+
+ A picture of searching for a process with a search condition that uses the or operator. +
+ +

And if our search uses a keyword, we need to use quotation marks around the term to properly search it.

+
+ A picture of searching for a process with a search condition that needs quotation marks. +
+ +

Lastly, we can refine our search even further based on the other columns, like PID, CPU usage, etc., as well as grouping together conditions.

+
+ A picture of searching for a process with a search condition that uses the CPU keyword. +
+ +

You can also paste search queries (e.g. Shift+Ins, Ctrl+Shift+v).

+

Keywords

+

Note all keywords are case-insensitive. To search for a process/command that collides with a keyword, surround the term with quotes (e.x. "cpu").

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
KeywordsExampleDescription
btmMatches by process or command name; supports regex
pidpid=1044Matches by PID; supports regex
cpu
cpu%
cpu > 0.5Matches the CPU column; supports comparison operators
membmemb > 1000 bMatches the memory column in terms of bytes; supports comparison operators
mem
mem%
mem < 0.5Matches the memory column in terms of percent; supports comparison operators
read
r/s
rps
read = 1 mbMatches the read/s column in terms of bytes; supports comparison operators
write
w/s
wps
write >= 1 kbMatches the write/s column in terms of bytes; supports comparison operators
tread
t.read
tread <= 1024 gbMatches he total read column in terms of bytes; supports comparison operators
twrite
t.write
twrite > 1024 tbMatches the total write column in terms of bytes; supports comparison operators
useruser=rootMatches by user; supports regex
statestate=runningMatches by state; supports regex
()(<COND 1> AND <COND 2>) OR <COND 3>Group together a condition
+

Comparison operators

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
KeywordsDescription
=Checks if the values are equal
>Checks if the left value is strictly greater than the right
<Checks if the left value is strictly less than the right
>=Checks if the left value is greater than or equal to the right
<=Checks if the left value is less than or equal to the right
+

Logical operators

+

Note all operators are case-insensitive, and the and operator takes precedence over the or operator.

+ + + + + + + + + + + + + + + + + + + + +
KeywordsUsageDescription
and
&&
<Space>
<COND 1> and <COND 2>
<COND 1> && <COND 2>
<COND 1> <COND 2>
Requires both conditions to be true to match
or
||
<COND 1> or <COND 2>
<COND 1> &#124;&#124; <COND 2>
Requires at least one condition to be true to match
+

Units

+

All units are case-insensitive.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
KeywordsDescription
BBytes
KBKilobytes
MBMegabytes
GBGigabytes
TBTerabytes
KiBKibibytes
MiBMebibytes
GiBGibibytes
TiBTebibytes
+

Key bindings

+

Note that key bindings are generally case-sensitive.

+

Process table

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
BindingAction
Up , kMove up within a widget
Down , jMove down within a widget
g+g , HomeJump to the first entry in the table
G , EndJump to the last entry in the table
d+d , F9Send a kill signal to the selected process
cSort by CPU usage, press again to reverse sorting order
mSort by memory usage, press again to reverse sorting order
pSort by PID name, press again to reverse sorting order
nSort by process name, press again to reverse sorting order
TabToggle grouping processes with the same name
PToggle between showing the full command or just the process name
Ctrl+f , /Toggle showing the search sub-widget
s , F6Toggle showing the sort sub-widget
IInvert the current sort
%Toggle between values and percentages for memory usage
t , F5Toggle tree mode
+

Sort sub-widget

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
BindingAction
Up , kMove up within a widget
Down , jMove down within a widget
g+g , HomeJump to the first entry in the table
G , EndJump to the last entry in the table
EscClose the sort sub-widget
EnterSorts the corresponding process table
+

Search sub-widget

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
BindingAction
Left
h
Alt+h
Moves the cursor left
Right
l
Alt+l
Moves the cursor right
EscClose the search widget (retains the filter)
Ctrl+aSkip to the start of the search query
Ctrl+eSkip to the end of the search query
Ctrl+uClear the current search query
Ctrl+wDelete a word behind the cursor
Ctrl+hDelete the character behind the cursor
BackspaceDelete the character behind the cursor
DelDelete the character at the cursor
Alt+c , F1Toggle matching case
Alt+w , F2Toggle matching the entire word
Alt+r , F3Toggle using regex
+

Mouse bindings

+

Process table

+ + + + + + + + + + + + + + + + + +
BindingAction
ScrollSelects a CPU thread/average to show in the graph
Left ButtonTable header: Sorts/reverse sorts the table by the column
Table entry: Selects an entry in the table, if in tree mode, collapses/expands the entry's children
+

Sort sub-widget

+ + + + + + + + + + + + + +
BindingAction
Left ButtonSelects an entry in the table
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/0.9.6/usage/widgets/temperature/index.html b/0.9.6/usage/widgets/temperature/index.html new file mode 100644 index 00000000..13c13ed7 --- /dev/null +++ b/0.9.6/usage/widgets/temperature/index.html @@ -0,0 +1,1192 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Temperature Widget - bottom + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + + + +
+ + +
+ +
+ + + + + + + + + +
+
+ + + +
+
+
+ + + + + + + + +
+
+
+ + + + +
+
+ + + + + + + + + + +

Temperature Widget

+

The temperature widget provides a table of temperature sensors and their current temperature.

+
+ A picture of an expanded temperature widget. +
+ +

Features

+

The temperature widget provides the sensor name as well as its current temperature.

+

Key bindings

+

Note that key bindings are generally case-sensitive.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
BindingAction
Up , kMove up within a widget
Down , jMove down within a widget
g+g , HomeJump to the first entry in the table
G , EndJump to the last entry in the table
tSort by temperature, press again to reverse sorting order
sSort by sensor name, press again to reverse sorting order
+

Mouse bindings

+ + + + + + + + + + + + + +
BindingAction
Left ButtonSelects an entry in the table
+ + + + + + +
+
+ + +
+ + + +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/stable/404.html b/stable/404.html index d47a0d8b..762040cc 100644 --- a/stable/404.html +++ b/stable/404.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../0.9.5/404.html... + Redirecting to ../0.9.6/404.html... \ No newline at end of file diff --git a/stable/configuration/command-line-flags/index.html b/stable/configuration/command-line-flags/index.html index 6cb7f1b7..2b7aa5e5 100644 --- a/stable/configuration/command-line-flags/index.html +++ b/stable/configuration/command-line-flags/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/configuration/command-line-flags/... + Redirecting to ../../../0.9.6/configuration/command-line-flags/... \ No newline at end of file diff --git a/stable/configuration/config-file/data-filtering/index.html b/stable/configuration/config-file/data-filtering/index.html index 44a890cd..67d7e816 100644 --- a/stable/configuration/config-file/data-filtering/index.html +++ b/stable/configuration/config-file/data-filtering/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/configuration/config-file/data-filtering/... + Redirecting to ../../../../0.9.6/configuration/config-file/data-filtering/... \ No newline at end of file diff --git a/stable/configuration/config-file/default-config/index.html b/stable/configuration/config-file/default-config/index.html index f2010a5e..79b2ddf7 100644 --- a/stable/configuration/config-file/default-config/index.html +++ b/stable/configuration/config-file/default-config/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/configuration/config-file/default-config/... + Redirecting to ../../../../0.9.6/configuration/config-file/default-config/... \ No newline at end of file diff --git a/stable/configuration/config-file/flags/index.html b/stable/configuration/config-file/flags/index.html index f6a23b5a..c96bf41e 100644 --- a/stable/configuration/config-file/flags/index.html +++ b/stable/configuration/config-file/flags/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/configuration/config-file/flags/... + Redirecting to ../../../../0.9.6/configuration/config-file/flags/... \ No newline at end of file diff --git a/stable/configuration/config-file/layout/index.html b/stable/configuration/config-file/layout/index.html index e009f4cb..8078cab0 100644 --- a/stable/configuration/config-file/layout/index.html +++ b/stable/configuration/config-file/layout/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/configuration/config-file/layout/... + Redirecting to ../../../../0.9.6/configuration/config-file/layout/... \ No newline at end of file diff --git a/stable/configuration/config-file/processes/index.html b/stable/configuration/config-file/processes/index.html index f311170f..472f2a77 100644 --- a/stable/configuration/config-file/processes/index.html +++ b/stable/configuration/config-file/processes/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/configuration/config-file/processes/... + Redirecting to ../../../../0.9.6/configuration/config-file/processes/... \ No newline at end of file diff --git a/stable/configuration/config-file/theming/index.html b/stable/configuration/config-file/theming/index.html index 64d4083c..7773fbc8 100644 --- a/stable/configuration/config-file/theming/index.html +++ b/stable/configuration/config-file/theming/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/configuration/config-file/theming/... + Redirecting to ../../../../0.9.6/configuration/config-file/theming/... \ No newline at end of file diff --git a/stable/contribution/development/build_process/index.html b/stable/contribution/development/build_process/index.html index ab066a73..7d42663a 100644 --- a/stable/contribution/development/build_process/index.html +++ b/stable/contribution/development/build_process/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/contribution/development/build_process/... + Redirecting to ../../../../0.9.6/contribution/development/build_process/... \ No newline at end of file diff --git a/stable/contribution/development/deploy_process/index.html b/stable/contribution/development/deploy_process/index.html index 20926319..46eca5e3 100644 --- a/stable/contribution/development/deploy_process/index.html +++ b/stable/contribution/development/deploy_process/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/contribution/development/deploy_process/... + Redirecting to ../../../../0.9.6/contribution/development/deploy_process/... \ No newline at end of file diff --git a/stable/contribution/development/dev_env/index.html b/stable/contribution/development/dev_env/index.html index cd4f30dc..44897a41 100644 --- a/stable/contribution/development/dev_env/index.html +++ b/stable/contribution/development/dev_env/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/contribution/development/dev_env/... + Redirecting to ../../../../0.9.6/contribution/development/dev_env/... \ No newline at end of file diff --git a/stable/contribution/development/logging/index.html b/stable/contribution/development/logging/index.html index 68916921..012cfa10 100644 --- a/stable/contribution/development/logging/index.html +++ b/stable/contribution/development/logging/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/contribution/development/logging/... + Redirecting to ../../../../0.9.6/contribution/development/logging/... \ No newline at end of file diff --git a/stable/contribution/development/testing/index.html b/stable/contribution/development/testing/index.html index 3daed488..f82ecf15 100644 --- a/stable/contribution/development/testing/index.html +++ b/stable/contribution/development/testing/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/contribution/development/testing/... + Redirecting to ../../../../0.9.6/contribution/development/testing/... \ No newline at end of file diff --git a/stable/contribution/documentation/index.html b/stable/contribution/documentation/index.html index 738820f5..94e647a9 100644 --- a/stable/contribution/documentation/index.html +++ b/stable/contribution/documentation/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/contribution/documentation/... + Redirecting to ../../../0.9.6/contribution/documentation/... \ No newline at end of file diff --git a/stable/contribution/issues-and-pull-requests/index.html b/stable/contribution/issues-and-pull-requests/index.html index da0a698c..4ea7603c 100644 --- a/stable/contribution/issues-and-pull-requests/index.html +++ b/stable/contribution/issues-and-pull-requests/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/contribution/issues-and-pull-requests/... + Redirecting to ../../../0.9.6/contribution/issues-and-pull-requests/... \ No newline at end of file diff --git a/stable/contribution/packaging-and-distribution/index.html b/stable/contribution/packaging-and-distribution/index.html index 1531f956..118d30cc 100644 --- a/stable/contribution/packaging-and-distribution/index.html +++ b/stable/contribution/packaging-and-distribution/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/contribution/packaging-and-distribution/... + Redirecting to ../../../0.9.6/contribution/packaging-and-distribution/... \ No newline at end of file diff --git a/stable/index.html b/stable/index.html index ec1d913d..41b1e62e 100644 --- a/stable/index.html +++ b/stable/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../0.9.5/... + Redirecting to ../0.9.6/... \ No newline at end of file diff --git a/stable/overrides/main.html b/stable/overrides/main.html index 2f7b1a08..8c46b0c7 100644 --- a/stable/overrides/main.html +++ b/stable/overrides/main.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../0.9.5/overrides/main.html... + Redirecting to ../../0.9.6/overrides/main.html... \ No newline at end of file diff --git a/stable/support/official/index.html b/stable/support/official/index.html index f7aac130..e018f4d1 100644 --- a/stable/support/official/index.html +++ b/stable/support/official/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/support/official/... + Redirecting to ../../../0.9.6/support/official/... \ No newline at end of file diff --git a/stable/support/unofficial/index.html b/stable/support/unofficial/index.html index 1fbbc973..5fd68490 100644 --- a/stable/support/unofficial/index.html +++ b/stable/support/unofficial/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/support/unofficial/... + Redirecting to ../../../0.9.6/support/unofficial/... \ No newline at end of file diff --git a/stable/troubleshooting/index.html b/stable/troubleshooting/index.html index 6d98411b..f2abc1e6 100644 --- a/stable/troubleshooting/index.html +++ b/stable/troubleshooting/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../0.9.5/troubleshooting/... + Redirecting to ../../0.9.6/troubleshooting/... \ No newline at end of file diff --git a/stable/usage/basic-mode/index.html b/stable/usage/basic-mode/index.html index b02f17cf..c8978a3c 100644 --- a/stable/usage/basic-mode/index.html +++ b/stable/usage/basic-mode/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/usage/basic-mode/... + Redirecting to ../../../0.9.6/usage/basic-mode/... \ No newline at end of file diff --git a/stable/usage/general-usage/index.html b/stable/usage/general-usage/index.html index 9a517feb..451a8899 100644 --- a/stable/usage/general-usage/index.html +++ b/stable/usage/general-usage/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../0.9.5/usage/general-usage/... + Redirecting to ../../../0.9.6/usage/general-usage/... \ No newline at end of file diff --git a/stable/usage/widgets/battery/index.html b/stable/usage/widgets/battery/index.html index f219efb3..a41ae7fc 100644 --- a/stable/usage/widgets/battery/index.html +++ b/stable/usage/widgets/battery/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/usage/widgets/battery/... + Redirecting to ../../../../0.9.6/usage/widgets/battery/... \ No newline at end of file diff --git a/stable/usage/widgets/cpu/index.html b/stable/usage/widgets/cpu/index.html index eb3ef227..d25e0edc 100644 --- a/stable/usage/widgets/cpu/index.html +++ b/stable/usage/widgets/cpu/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/usage/widgets/cpu/... + Redirecting to ../../../../0.9.6/usage/widgets/cpu/... \ No newline at end of file diff --git a/stable/usage/widgets/disk/index.html b/stable/usage/widgets/disk/index.html index dc05ecdb..a83b60ea 100644 --- a/stable/usage/widgets/disk/index.html +++ b/stable/usage/widgets/disk/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/usage/widgets/disk/... + Redirecting to ../../../../0.9.6/usage/widgets/disk/... \ No newline at end of file diff --git a/stable/usage/widgets/memory/index.html b/stable/usage/widgets/memory/index.html index cc85faa7..7b58d2e9 100644 --- a/stable/usage/widgets/memory/index.html +++ b/stable/usage/widgets/memory/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/usage/widgets/memory/... + Redirecting to ../../../../0.9.6/usage/widgets/memory/... \ No newline at end of file diff --git a/stable/usage/widgets/network/index.html b/stable/usage/widgets/network/index.html index 7664b3ec..a327520c 100644 --- a/stable/usage/widgets/network/index.html +++ b/stable/usage/widgets/network/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/usage/widgets/network/... + Redirecting to ../../../../0.9.6/usage/widgets/network/... \ No newline at end of file diff --git a/stable/usage/widgets/process/index.html b/stable/usage/widgets/process/index.html index 89134a5b..c7baf1ae 100644 --- a/stable/usage/widgets/process/index.html +++ b/stable/usage/widgets/process/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/usage/widgets/process/... + Redirecting to ../../../../0.9.6/usage/widgets/process/... \ No newline at end of file diff --git a/stable/usage/widgets/temperature/index.html b/stable/usage/widgets/temperature/index.html index caeb51c9..4793b6e3 100644 --- a/stable/usage/widgets/temperature/index.html +++ b/stable/usage/widgets/temperature/index.html @@ -4,13 +4,13 @@ Redirecting - Redirecting to ../../../../0.9.5/usage/widgets/temperature/... + Redirecting to ../../../../0.9.6/usage/widgets/temperature/... \ No newline at end of file diff --git a/versions.json b/versions.json index c3045aaa..24fa21eb 100644 --- a/versions.json +++ b/versions.json @@ -1 +1 @@ -[{"version": "0.9.5", "title": "0.9.5", "aliases": ["stable"]}, {"version": "0.9.4", "title": "0.9.4", "aliases": []}, {"version": "0.9.3", "title": "0.9.3", "aliases": []}, {"version": "0.9.2", "title": "0.9.2", "aliases": []}, {"version": "0.9.1", "title": "0.9.1", "aliases": []}, {"version": "0.9.0", "title": "0.9.0", "aliases": []}, {"version": "0.8.0", "title": "0.8.0", "aliases": []}, {"version": "0.7.1", "title": "0.7.1", "aliases": []}, {"version": "0.7.0", "title": "0.7.0", "aliases": []}, {"version": "0.6.8", "title": "0.6.8", "aliases": []}, {"version": "0.6.7", "title": "0.6.7", "aliases": []}, {"version": "0.6.6", "title": "0.6.6", "aliases": []}, {"version": "0.6.5", "title": "0.6.5", "aliases": []}, {"version": "0.6.4", "title": "0.6.4", "aliases": []}, {"version": "0.6.3", "title": "0.6.3", "aliases": []}, {"version": "0.6.2", "title": "0.6.2", "aliases": []}, {"version": "0.6.1", "title": "0.6.1", "aliases": []}, {"version": "nightly", "title": "nightly", "aliases": []}] \ No newline at end of file +[{"version": "0.9.6", "title": "0.9.6", "aliases": ["stable"]}, {"version": "0.9.5", "title": "0.9.5", "aliases": []}, {"version": "0.9.4", "title": "0.9.4", "aliases": []}, {"version": "0.9.3", "title": "0.9.3", "aliases": []}, {"version": "0.9.2", "title": "0.9.2", "aliases": []}, {"version": "0.9.1", "title": "0.9.1", "aliases": []}, {"version": "0.9.0", "title": "0.9.0", "aliases": []}, {"version": "0.8.0", "title": "0.8.0", "aliases": []}, {"version": "0.7.1", "title": "0.7.1", "aliases": []}, {"version": "0.7.0", "title": "0.7.0", "aliases": []}, {"version": "0.6.8", "title": "0.6.8", "aliases": []}, {"version": "0.6.7", "title": "0.6.7", "aliases": []}, {"version": "0.6.6", "title": "0.6.6", "aliases": []}, {"version": "0.6.5", "title": "0.6.5", "aliases": []}, {"version": "0.6.4", "title": "0.6.4", "aliases": []}, {"version": "0.6.3", "title": "0.6.3", "aliases": []}, {"version": "0.6.2", "title": "0.6.2", "aliases": []}, {"version": "0.6.1", "title": "0.6.1", "aliases": []}, {"version": "nightly", "title": "nightly", "aliases": []}] \ No newline at end of file