diff options
Diffstat (limited to '.local/share/weechat/python/bufsize.py')
-rw-r--r-- | .local/share/weechat/python/bufsize.py | 247 |
1 files changed, 247 insertions, 0 deletions
diff --git a/.local/share/weechat/python/bufsize.py b/.local/share/weechat/python/bufsize.py new file mode 100644 index 0000000..153c9bc --- /dev/null +++ b/.local/share/weechat/python/bufsize.py @@ -0,0 +1,247 @@ +# -*- coding: utf-8 -*- +# +# Copyright (c) 2012-2017 by nils_2 <weechatter@arcor.de> +# and nesthib <nesthib@gmail.com> +# +# scroll indicator; displaying number of lines below last line, overall lines in buffer, number of current line and percent displayed +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. +# +# 2017-08-17: nils_2 (freenode.#weechat) +# 0.8: add support for buffer_filters_enabled and buffer_filters_disabled (WeeChat ≥ 2.0) +# 2016-12-16: nils_2 (freenode.#weechat) +# 0.7: add option show_scroll (idea by earnestly) +# 2016-04-23: wdbw <tuturu@tutanota.com> +# 0.6.2 : fix: type of filters_enabled +# 2014-02-24: nesthib (freenode.#weechat) +# 0.6.1 : fix: color tags for default format +# 2013-11-19: nils_2 (freenode.#weechat) +# 0.6 : fix: stdout/stderr warning +# 2013-11-02: nils_2 (freenode.#weechat) +# 0.5 : fix refresh on (un)zoomed buffer +# : add option 'count_filtered_lines' and format item "%F" +# 2013-10-15: nils_2 (freenode.#weechat) +# 0.4 : fix bug with root-bar +# : add support of eval_expression (weechat >= 0.4.2) +# 2013-01-25: nils_2 (freenode.#weechat) +# 0.3 : make script compatible with Python 3.x +# : internal changes +# 2012-07-09: nils_2 (freenode.#weechat) +# 0.2 : fix: display bug with more than one window +# : hide item when buffer empty +# 2012-07-08: obiwahn +# 0.1.1 : add hook for switch_buffer +# 2012-01-11: nils_2, nesthib (freenode.#weechat) +# 0.1 : initial release +# +# Development is currently hosted at +# https://github.com/weechatter/weechat-scripts + +try: + import weechat, re + +except Exception: + print("This script must be run under WeeChat.") + print("Get WeeChat now at: http://www.weechat.org/") + quit() + +SCRIPT_NAME = "bufsize" +SCRIPT_AUTHOR = "nils_2 <weechatter@arcor.de>" +SCRIPT_VERSION = "0.8" +SCRIPT_LICENSE = "GPL" +SCRIPT_DESC = "scroll indicator; displaying number of lines below last line, overall lines in buffer, number of current line and percent displayed" + +OPTIONS = { 'format' : ('${color:yellow}%P${color:default}⋅%{${color:yellow}%A${color:default}⇵${color:yellow}%C${color:default}/}${color:yellow}%L', + 'format for items to display in bar, possible items: %P = percent indicator, %A = number of lines below last line, %L = lines counter, %C = current line %F = number of filtered lines (note: using WeeChat >= 0.4.2, content is evaluated, so you can use colors with format \"${color:xxx}\", see /help eval)'), + 'count_filtered_lines': ('on', + 'filtered lines will be count in item.'), + 'show_scroll':('on','always show the scroll indicator number,even if its 0 (item %A), if option is off the scroll indicator will be hidden like the item "scroll"'), + } +# ================================[ weechat item ]=============================== +# regexp to match ${color} tags +regex_color=re.compile('\$\{([^\{\}]+)\}') + +# regexp to match ${optional string} tags +regex_optional_tags=re.compile('%\{[^\{\}]+\}') + +filter_status = 0 + +def show_item (data, item, window): + # check for root input bar! + if not window: + window = weechat.current_window() + + ptr_buffer = weechat.window_get_pointer(window,'buffer') + if ptr_buffer == '': + return '' + + if weechat.buffer_get_string(ptr_buffer,'name') != 'weechat': # not weechat core buffer + if weechat.buffer_get_string(ptr_buffer,'localvar_type') == '': # buffer with free content? + return '' + + lines_after, lines_count, percent, current_line, filtered, filtered_before, filtered_after = count_lines(window,ptr_buffer) + lines_after_bak = lines_after + + if lines_count == 0: # buffer empty? + return '' + + if filtered == 0: + filtered = '' + + if lines_after == 0 and (OPTIONS['show_scroll'].lower() == 'off'): + lines_after = '' + + tags = {'%C': str(current_line), + '%A': str(lines_after), + '%F': str(filtered), + '%L': str(lines_count), + '%P': str(percent)+'%'} + + bufsize_item = substitute_colors(OPTIONS['format']) + + # replace mandatory tags + for tag in list(tags.keys()): +# for tag in tags.keys(): + bufsize_item = bufsize_item.replace(tag, tags[tag]) + + # replace optional tags + # %{…} only if lines after (e.g. %A > 0) + if lines_after_bak > 0: + for regex_tag in regex_optional_tags.findall(bufsize_item): + bufsize_item = bufsize_item.replace(regex_tag, regex_tag.lstrip('%{').rstrip('}')) + else: + bufsize_item = regex_optional_tags.sub('', bufsize_item) + + return bufsize_item + +def substitute_colors(text): + if int(version) >= 0x00040200: + return weechat.string_eval_expression(text,{},{},{}) + # substitute colors in output + return re.sub(regex_color, lambda match: weechat.color(match.group(1)), text) + +def count_lines(ptr_window,ptr_buffer): + global filter_status + + hdata_buf = weechat.hdata_get('buffer') + hdata_lines = weechat.hdata_get('lines') + lines = weechat.hdata_pointer(hdata_buf, ptr_buffer, 'lines') # own_lines, mixed_lines + lines_count = weechat.hdata_integer(hdata_lines, lines, 'lines_count') + + hdata_window = weechat.hdata_get('window') + hdata_winscroll = weechat.hdata_get('window_scroll') + window_scroll = weechat.hdata_pointer(hdata_window, ptr_window, 'scroll') + lines_after = weechat.hdata_integer(hdata_winscroll, window_scroll, 'lines_after') + window_height = weechat.window_get_integer(weechat.current_window(), 'win_chat_height') + + filtered = 0 + filtered_before = 0 + filtered_after = 0 + # if filter is disabled, don't count. + if (OPTIONS['count_filtered_lines'].lower() == 'off') and filter_status == 1: + filtered, filtered_before,filtered_after = count_filtered_lines(ptr_buffer,lines_count,lines_after) + lines_count = lines_count - filtered +# lines_after = lines_after - filtered_after + + if lines_count > window_height: + differential = lines_count - window_height + percent = max(int(round(100. * (differential - lines_after) / differential)), 0) + else: + percent = 100 + + # get current position + current_line = lines_count - lines_after + + return lines_after,lines_count,percent,current_line, filtered, filtered_before, filtered_after + +def count_filtered_lines(ptr_buffer,lines_count,lines_after): + filtered_before = 0 + filtered_after = 0 + filtered = 0 + + lines = weechat.hdata_pointer(weechat.hdata_get('buffer'), ptr_buffer, 'own_lines') + counter = 0 + current_position = lines_count - lines_after + + if lines: + line = weechat.hdata_pointer(weechat.hdata_get('lines'), lines, 'first_line') + hdata_line = weechat.hdata_get('line') + hdata_line_data = weechat.hdata_get('line_data') + + while line: + data = weechat.hdata_pointer(hdata_line, line, 'data') + if data: +# message = weechat.hdata_string(hdata_line_data, data, 'message') + displayed = weechat.hdata_char(hdata_line_data, data, 'displayed') + if displayed == 0: +# weechat.prnt('','%d - %s - %s' % (counter, displayed, message)) + if counter < current_position: + filtered_before += 1 + else: + filtered_after += 1 + counter += 1 + line = weechat.hdata_move(hdata_line, line, 1) + + filtered = filtered_before + filtered_after + return filtered,filtered_before,filtered_after + +def update_cb(data, signal, signal_data): + weechat.bar_item_update(SCRIPT_NAME) + return weechat.WEECHAT_RC_OK + +def filtered_update_cb(data, signal, signal_data): + global filter_status + if signal == 'filters_disabled': + filter_status = 0 + if signal == 'filters_enabled': + filter_status = 1 + weechat.bar_item_update(SCRIPT_NAME) + return weechat.WEECHAT_RC_OK +# ================================[ weechat options and description ]=============================== +def init_options(): + for option,value in OPTIONS.items(): + if not weechat.config_is_set_plugin(option): + weechat.config_set_plugin(option, value[0]) + OPTIONS[option] = value[0] + else: + OPTIONS[option] = weechat.config_get_plugin(option) + weechat.config_set_desc_plugin(option, "%s (default: '%s')" % (value[1], value[0])) + +def toggle_refresh(pointer, name, value): + global OPTIONS + option = name[len('plugins.var.python.' + SCRIPT_NAME + '.'):] # get optionname + OPTIONS[option] = value # save new value + weechat.bar_item_update(SCRIPT_NAME) + return weechat.WEECHAT_RC_OK +# ================================[ main ]=============================== +if __name__ == "__main__": +# global filter_status + if weechat.register(SCRIPT_NAME, SCRIPT_AUTHOR, SCRIPT_VERSION, SCRIPT_LICENSE, SCRIPT_DESC, '', ''): + version = weechat.info_get("version_number", "") or 0 + + if int(version) >= 0x00030600: + filter_status = int(weechat.info_get('filters_enabled','')) + bar_item = weechat.bar_item_new(SCRIPT_NAME, 'show_item','') + weechat.bar_item_update(SCRIPT_NAME) + weechat.hook_signal('buffer_line_added','update_cb','') + weechat.hook_signal('window_scrolled','update_cb','') + weechat.hook_signal('buffer_switch','update_cb','') + weechat.hook_signal('*filters*','filtered_update_cb','') + weechat.hook_command_run('/buffer clear*','update_cb','') + weechat.hook_command_run('/window page*','update_cb','') + weechat.hook_command_run('/input zoom_merged_buffer','update_cb','') + weechat.hook_config( 'plugins.var.python.' + SCRIPT_NAME + '.*', 'toggle_refresh', '' ) + init_options() + else: + weechat.prnt('','%s%s %s' % (weechat.prefix('error'),SCRIPT_NAME,': needs version 0.3.6 or higher')) |