chanmon.pl 38.7 KB
Newer Older
1
#
2
# chanmon.pl - Channel Monitoring for weechat 0.3.0
3
# Version 2.5
4
#
5
# Add 'Channel Monitor' buffer/bar that you can position to show IRC channel
6 7 8 9
# messages in a single location without constantly switching buffers
# i.e. In a seperate window beneath the main channel buffer
#
# Usage:
10
# /chanmon [help] | [monitor [channel [server]]] | [dynmon] | [clean default|orphan|all] | clearbar
11 12
#  Command wrapper for chanmon commands
#
13
# /chmonitor [channel] [server] is used to toggle a channel monitoring on and off, this
14 15
#  can be used in the channel buffer for the channel you wish to toggle, or be given
#  with arguments e.g. /monitor #weechat freenode
16
#
17
# /dynmon is used to toggle 'Dynamic Channel Monitoring' on and off, this
18 19 20 21 22
#  will automagically stop monitoring the current active buffer, without
#  affecting regular settings (Default is off)
#
# /chanclean default|orphan|all will clean the config section of default 'on' entries,
#  channels you are no longer joined, or both
23
#
24 25
# /chanmon clearbar will clear the contents of chanmon's bar output
#
26
# /set plugins.var.perl.chanmon.alignment
27
#  The config setting "alignment" can be changed to;
28
#  "channel", "schannel", "nchannel", "channel,nick", "schannel,nick", "nchannel,nick"
29
#  to change how the monitor appears
30 31 32
#  The 'channel'  value will show: "#weechat"
#  The 'schannel' value will show: "6"
#  The 'nchannel' value will show: "6:#weechat"
33
#
34
# /set plugins.var.perl.chanmon.short_names
35
#  Setting this to 'on' will trim the network name from chanmon, ala buffers.pl
36
#
37 38 39
# /set plugins.var.perl.chanmon.merge_private
#  Setting this to 'on' will merge private messages to chanmon's display
#
40
# /set plugins.var.perl.chanmon.color_buf
41 42
#  This turns colored buffer names on or off, you can also set a single fixed color by using a weechat color name.
#  This *must* be a valid color name, or weechat will likely do unexpected things :)
43 44
#
# /set plugins.var.perl.chanmon.show_aways
45 46 47 48 49 50 51 52 53 54
#  Toggles showing the Weechat away messages
#
# /set plugins.var.perl.chanmon.logging
#  Toggles logging status for chanmon buffer (default: off)
#
# /set plugins.var.perl.chanmon.output
#  Changes where output method of chanmon; takes either "bar" or "buffer" (default; buffer)
# /set plugins.var.perl.chanmon.bar_lines
#  Changes the amount of lines the output bar will hold.
#  (Only appears once output has been set to bar, defaults to 10)
55
#
56 57
# /set plugins.var.perl.chanmon.nick_prefix
# /set plugins.var.perl.chanmon.nick_suffix
58 59
#  Sets the prefix and suffix chars in the chanmon buffer
#  (Defaults to <> if nothing set, and blank if there is)
60
#
61
# servername.#channel
62 63
#  servername is the internal name for the server (set when you use /server add)
#  #channel is the channel name, (where # is whatever channel type that channel happens to be)
64
#
65
# Example set up:
66
# Split the layout 70/30 (or there abouts) horizontally and load
67
# Optionally, hide the status and input lines on chanmon
68
#
69 70 71
# /window splith 70 --> change to chanmon buffer
# /set weechat.bar.status.conditions "${window.buffer.full_name} != perl.chanmon"
# /set weechat.bar.input.conditions "${window.buffer.full_name} != perl.chanmon"
72 73 74
#

# Bugs and feature requests at: https://github.com/KenjiE20/chanmon
75

76
# History:
77 78 79 80 81
# 2014-08-16, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.5:	-add: clearbar command to clear bar output
#			-add: firstrun output prompt to check the help text for set up hints as they were being missed
#			and update hint for conditions to use eval
#			-change: Make all outputs use the date callback for more accurate timestamps (thanks Germainz)
82 83
# 2013-12-04, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.4:	-add: Support for eval style colour codes in time format used for bar output
84 85 86 87
# 2013-10-10, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.3.3.1:	-fix: Typo in closed buffer warning
# 2013-10-07, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.3.3:	-add: Warning and fixer for accidental buffer closes
88 89 90 91
# 2013-01-15, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.3.2:	-fix: Let bar output use the string set in weechat's config option
#			-add: github info
#			-change: Ideal set up -> Example set up
92 93
# 2012-04-15, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.3.1:	-fix: Colour tags in bar timestamp string, bar error fixes from highmon
94 95
# 2012-02-28, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.3:	-feature: Added merge_private option to display private messages (default: off)
96 97
# 2010-12-22, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.2:	-change: Use API instead of config to find channel colours, ready for 0.3.4 and 256 colours
98 99 100 101
# 2010-12-05, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.1.3: -change: /monitor is now /chmonitor to avoid command conflicts (thanks m4v)
#		(/chanmon monitor remains the same)
#		-fix: Add command list to inbuilt help
102 103
# 2010-09-30, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.1.2:	-fix: logging config was not correctly toggling back on (thanks to sleo for noticing)
104 105
# 2010-09-20, m4v <lambdae2@gmail.com>:
#	v2.1.1:	-fix: chanmon wasn't detecting buffers displayed on more than one window
106 107
# 2010-08-27, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.1: -feature: Add 'nchannel' option to alignment to display buffer and name
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
# 2010-04-25, KenjiE20 <longbow@longbowslair.co.uk>:
#	v2.0:	Release as version 2.0
# 2010-04-24, KenjiE20 <longbow@longbowslair.co.uk>:
#		-fix: No longer using hard-coded detection for ACTION and
#			TOPIC messages. Use config settings for ACTION printing
# 2010-04-15, KenjiE20 <longbow@longbowslair.co.uk>:
#	v1.9:	Rewrite for v2.0
#		-feature: /monitor takes arguments
#		-feature: Added /chanclean for config cleanup
#		-feature: Buffer logging option (default: off)
#		-feature: Selectable output (Bar/Buffer (default))
#		-feature: /chanmon is now a command wrapper for all commands
#			/help chanmon gives command help
#			/chanmon help gives config help
#		-code change: Made more subs to shrink the code down in places
#		-fix: Stop chanmon attempting to double load/hook
124 125 126
# 2010-02-10, m4v <lambdae2@gmail.com>:
#	v1.7.1:	-fix: chanmon was leaking infolists, changed how chanmon
#			detects if the buffer is displayed or not.
127
# 2010-01-25, KenjiE20 <longbow@longbowslair.co.uk>:
128 129 130 131 132 133
#	v1.7:	-fixture: Let chanmon be aware of nick_prefix/suffix
#			and allow custom prefix/suffix for chanmon buffer
#			(Defaults to <> if nothing set, and blank if there is)
#		-fix: Make dynamic monitoring aware of multiple windows
#			rather than just the active buffer
#		(Thanks to m4v for these)
134 135 136
# 2009-09-07, KenjiE20 <longbow@longbowslair.co.uk>:
#	v1.6:	-feature: colored buffer names
#		-change: chanmon version sync
137 138
# 2009-09-05, KenjiE20 <longbow@longbowslair.co.uk>:
#	v1.5:	-fix: disable buffer highlight
139 140
# 2009-09-02, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.4.1	-change: Stop unsightly text block on '/help'
141 142 143 144
# 2009-08-10, KenjiE20 <longbow@longbowslair.co.uk>:
#	v1.4:	-feature: In-client help added
#		-fix: Added missing help entries
#			Fix remaining ugly vars
145 146
# 2009-07-09, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.3.3	-fix: highlight on the channel monitor when someone /me highlights
147 148 149 150 151
# 2009-07-04, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.3.2	-fix: use new away_info tag instead of ugly regexp for away detection
#		-code: cleanup old raw callback arguement variables to nice neat named ones
# 2009-07-04, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.3.1	-feature(tte): Hide /away messages by default, change 'show_aways' to get them back
152 153
# 2009-07-01, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.3	-feature(tte): Mimic buffers.pl 'short_names'
154 155
# 2009-06-29, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.2.1	-fix: let the /monitor message respect the alignment setting
156 157 158
# 2009-06-19, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.2	-feature(tte): Customisable alignment
#			Thanks to 'FreakGaurd' for the idea
159 160
# 2009-06-14, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.1.2	-fix: don't assume chanmon buffer needs creating
161
#			fixes crashing with /upgrade
162 163
# 2009-06-13, KenjiE20 <longbow@longbowslair.co.uk>:
#	v.1.1.1	-code: change from True/False to on/off for weechat consistency
164
#			Settings WILL NEED to be changed manually from previous versions
165
# 2009-06-13, KenjiE20 <longbow@longbowslair.co.uk>:
166
#	v1.1:	-feature: Dynamic Channel Monitoring,
167 168 169 170 171 172 173 174 175
#			don't display messages from active channel buffer
#			defaults to Disabled
#			Thanks to 'sjohnson' for the idea
#		-fix: don't set config entries for non-channels
#		-fix: don't assume all channels are #
# 2009-06-12, KenjiE20 <longbow@longbowslair.co.uk>:
#	v1.0.1:	-fix: glitch with tabs in IRC messages
# 2009-06-10, KenjiE20 <longbow@longbowslair.co.uk>:
#	v1.0:	Initial Public Release
176

177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192
# Copyright (c) 2009 by KenjiE20 <longbow@longbowslair.co.uk>
#
# 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/>.
#

193 194
@bar_lines = ();
@bar_lines_time = ();
195
# Replicate info earlier for in-client help
196
$chanmonhelp = weechat::color("bold")."/chanmon [help] | [monitor [channel [server]]] | [dynmon] | [clean default|orphan|all] | clearbar".weechat::color("-bold")."
197 198 199 200 201 202 203 204 205
Command wrapper for chanmon commands

".weechat::color("bold")."/chmonitor [channel] [server]".weechat::color("-bold")." is used to toggle a channel monitoring on and off, this
 can be used in the channel buffer for the channel you wish to toggle, or be given with arguments e.g. /monitor #weechat freenode

".weechat::color("bold")."/dynmon".weechat::color("-bold")." is used to toggle 'Dynamic Channel Monitoring' on and off, this will automagically stop monitoring the current active buffer, without affecting regular settings (Default is off)

".weechat::color("bold")."/chanclean".weechat::color("-bold")." default|orphan|all will clean the config section of default 'on' entries, channels you are no longer joined, or both

206 207
".weechat::color("bold")."/chanmon clearbar".weechat::color("-bold")." will clear the contents of chanmon's bar output

208
".weechat::color("bold")."/set plugins.var.perl.chanmon.alignment".weechat::color("-bold")."
209
 The config setting \"alignment\" can be changed to;
210
 \"channel\", \"schannel\", \"nchannel\", \"channel,nick\", \"schannel,nick\", \"nchannel,nick\"
211
 to change how the monitor appears
212 213 214
 The 'channel'  value will show: \"#weechat\"
 The 'schannel' value will show: \"6\"
 The 'nchannel' value will show: \"6:#weechat\"
215 216

".weechat::color("bold")."/set plugins.var.perl.chanmon.short_names".weechat::color("-bold")."
217
 Setting this to 'on' will trim the network name from chanmon, ala buffers.pl
218

219 220 221
".weechat::color("bold")."/set plugins.var.perl.chanmon.merge_private".weechat::color("-bold")."
 Setting this to 'on' will merge private messages to chanmon's display

222
".weechat::color("bold")."/set plugins.var.perl.chanmon.color_buf".weechat::color("-bold")."
223 224
 This turns colored buffer names on or off, you can also set a single fixed color by using a weechat color name.
 This ".weechat::color("bold")."must".weechat::color("-bold")." be a valid color name, or weechat will likely do unexpected things :)
225

226
".weechat::color("bold")."/set plugins.var.perl.chanmon.show_aways".weechat::color("-bold")."
227 228 229 230 231 232 233 234 235 236
 Toggles showing the Weechat away messages

".weechat::color("bold")."/set plugins.var.perl.chanmon.logging".weechat::color("-bold")."
 Toggles logging status for chanmon buffer (default: off)

".weechat::color("bold")."/set plugins.var.perl.chanmon.output".weechat::color("-bold")."
 Changes where output method of chanmon; takes either \"bar\" or \"buffer\" (default; buffer)
".weechat::color("bold")."/set plugins.var.perl.chanmon.bar_lines".weechat::color("-bold")."
 Changes the amount of lines the output bar will hold.
 (Only appears once output has been set to bar, defaults to 10)
237

238 239
".weechat::color("bold")."/set plugins.var.perl.chanmon.nick_prefix".weechat::color("-bold")."
".weechat::color("bold")."/set plugins.var.perl.chanmon.nick_suffix".weechat::color("-bold")."
240 241
 Sets the prefix and suffix chars in the chanmon buffer
 (Defaults to <> if nothing set, and blank if there is)
242

243
".weechat::color("bold")."servername.#channel".weechat::color("-bold")."
244 245
 servername is the internal name for the server (set when you use /server add)
 #channel is the channel name, (where # is whatever channel type that channel happens to be)
246

247
".weechat::color("bold")."Example set up:".weechat::color("-bold")."
248
Split the layout 70/30 (or there abouts) horizontally and load
249
Optionally, hide the status and input lines on chanmon
250

251 252 253
".weechat::color("bold")."/window splith 70".weechat::color("-bold")." --> change to chanmon buffer
".weechat::color("bold")."/set weechat.bar.status.conditions \"\${window.buffer.full_name} != perl.chanmon\"".weechat::color("-bold")."
".weechat::color("bold")."/set weechat.bar.input.conditions \"\${window.buffer.full_name} != perl.chanmon\"".weechat::color("-bold");
254 255 256 257 258 259 260 261 262 263 264 265 266
# Print verbose help
sub print_help
{
	weechat::print("", "\t".weechat::color("bold")."Chanmon Help".weechat::color("-bold")."\n\n");
	weechat::print("", "\t".$chanmonhelp);
	return weechat::WEECHAT_RC_OK;
}

# Bar item build
sub chanmon_bar_build
{
	# Get max lines
	$max_lines = weechat::config_get_plugin("bar_lines");
267
	$max_lines = $max_lines ? $max_lines : 10;
268 269 270 271
	$str = '';
	$align_num = 0;
	$count = 0;
	# Keep lines within max
272
	while ($#bar_lines > $max_lines)
273 274 275 276 277 278 279 280
	{
		shift(@bar_lines);
		shift(@bar_lines_time);
	}
	# So long as we have some lines, build a string
	if (@bar_lines)
	{
		# Build loop
281
		$sep = " ".weechat::config_string(weechat::config_get("weechat.look.prefix_suffix"))." ";
282 283 284
		foreach(@bar_lines)
		{
			# Find max align needed
285
			$prefix_num = (index(weechat::string_remove_color($_, ""), $sep));
286
			$align_num = $prefix_num if ($prefix_num > $align_num);
287
		}
288 289 290
		foreach(@bar_lines)
		{
			# Get align for this line
291 292
			$prefix_num = (index(weechat::string_remove_color($_, ""), $sep));

293 294 295 296 297 298 299 300 301 302 303
			# Make string
			$str = $str.$bar_lines_time[$count]." ".(" " x ($align_num - $prefix_num)).$_."\n";
			# Increment count for sync with time list
			$count++;
		}
	}
	return $str;
}

# Make a new bar
sub chanmon_bar_open
304
{
305 306
	# Make the bar item
	weechat::bar_item_new("chanmon", "chanmon_bar_build", "");
307

308 309 310 311 312 313 314 315 316 317 318 319 320 321
	$chanmon_bar = weechat::bar_new ("chanmon", "off", 100, "root", "", "bottom", "vertical", "vertical", 0, 0, "default", "cyan", "default", "on", "chanmon");

	return weechat::WEECHAT_RC_OK;
}
# Close bar
sub chanmon_bar_close
{
	# Find if bar exists
	$chanmon_bar = weechat::bar_search("chanmon");
	# If is does, close it
	if ($chanmon_bar ne "")
	{
		weechat::bar_remove($chanmon_bar);
	}
322

323 324 325 326 327 328 329
	# Find if bar item exists
	$chanmon_bar_item = weechat::bar_item_search("chanmon_bar");
	# If is does, close it
	if ($chanmon_bar_item ne "")
	{
		weechat::bar_remove($chanmon_bar_item);
	}
330

331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369
	@bar_lines = ();
	return weechat::WEECHAT_RC_OK;
}

# Make a new buffer
sub chanmon_buffer_open
{
	# Search for pre-existing buffer
	$chanmon_buffer = weechat::buffer_search("perl", "chanmon");

	# Make a new buffer
	if ($chanmon_buffer eq "")
	{
		$chanmon_buffer = weechat::buffer_new("chanmon", "chanmon_buffer_input", "", "chanmon_buffer_close", "");
	}

	# Turn off notify, highlights
	if ($chanmon_buffer ne "")
	{
		weechat::buffer_set($chanmon_buffer, "notify", "0");
		weechat::buffer_set($chanmon_buffer, "highlight_words", "-");
		weechat::buffer_set($chanmon_buffer, "title", "Channel Monitor");
		# Set no_log
		if (weechat::config_get_plugin("logging") eq "off")
		{
			weechat::buffer_set($chanmon_buffer, "localvar_set_no_log", "1");
		}
	}
	return weechat::WEECHAT_RC_OK;
}
# Buffer input has no action
sub chanmon_buffer_input
{
	return weechat::WEECHAT_RC_OK;
}
# Close up
sub chanmon_buffer_close
{
	$chanmon_buffer = "";
370 371 372 373 374
	# If user hasn't changed output style warn user
	if (weechat::config_get_plugin("output") eq "buffer")
	{
		weechat::print("", "\tChanmon buffer has been closed but output is still set to buffer, unusual results may occur. To recreate the buffer use ".weechat::color("bold")."/chanmon fix".weechat::color("-bold"));
	}
375 376 377 378 379 380 381 382 383 384 385
	return weechat::WEECHAT_RC_OK;
}

# Chanmon command wrapper
sub chanmon_command_cb
{
	$data = $_[0];
	$buffer = $_[1];
	$args = $_[2];
	my $cmd = '';
	my $arg = '';
386

387 388 389 390 391 392 393 394 395 396 397 398
	if ($args ne "")
	{
		# Split argument up
		@arg_array = split(/ /,$args);
		# Take first as command
		$cmd = shift(@arg_array);
		# Rebuild string to pass to subs
		if (@arg_array)
		{
			$arg = join(" ", @arg_array);
		}
	}
399

400 401 402 403 404 405
	# Help command
	if ($cmd eq "" || $cmd eq "help")
	{
		print_help();
	}
	# /monitor command
406
	elsif ($cmd eq "monitor")
407 408 409 410 411 412 413 414 415 416 417 418 419
	{
		chanmon_toggle($data, $buffer, $arg);
	}
	# /dynmon command
	elsif ($cmd eq "dynmon")
	{
		chanmon_dyn_toggle();
	}
	# /chanclean command
	elsif ($cmd eq "clean")
	{
		chanmon_config_clean($data, $buffer, $arg);
	}
420 421 422 423 424 425 426 427 428
	# clearbar command
	elsif ($cmd eq "clearbar")
	{
		if (weechat::config_get_plugin("output") eq "bar")
		{
			@bar_lines = ();
			weechat::bar_item_update("chanmon");
		}
	}
429 430 431 432 433 434 435 436
	# Fix closed buffer
	elsif ($cmd eq "fix")
	{
		if (weechat::config_get_plugin("output") eq "buffer" && $chanmon_buffer eq "")
		{
			chanmon_buffer_open();
		}
	}
437 438
	return weechat::WEECHAT_RC_OK;
}
439

440 441 442 443 444 445
# Clean up config entries
sub chanmon_config_clean
{
	$data = $_[0];
	$buffer = $_[1];
	$args = $_[2];
446

447 448 449 450 451 452
	# Don't do anything if bad option given
	if ($args ne "default" && $args ne "orphan"  && $args ne "all")
	{
		weechat::print("", "\tchanmon.pl: Unknown option");
		return weechat::WEECHAT_RC_OK;
	}
453

454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527
	@chans = ();
	# Load an infolist of chanmon options
	$infolist = weechat::infolist_get("option", "", "*chanmon*");
	while (weechat::infolist_next($infolist))
	{
		$name = weechat::infolist_string($infolist, "option_name");
		$name =~ s/perl\.chanmon\.(\w*)\.([#&\+!])(.*)/$1.$2$3/;
		if ($name =~ /^(.*)\.([#&\+!])(.*)$/)
		{
			$action = 0;
			# Clean up all 'on's
			if ($args eq "default" || $args eq "all")
			{
				# If value in config is "on"
				if (weechat::config_get_plugin($name) eq "on")
				{
					# Unset and if successful flag as changed
					$rc = weechat::config_unset_plugin($name);
					if ($rc eq weechat::WEECHAT_CONFIG_OPTION_UNSET_OK_REMOVED)
					{
						$action = 1;
					}
				}
			}
			# Clean non joined
			if ($args eq "orphan" || $args eq "all")
			{
				# If we can't find the buffer for this entry
				if (weechat::buffer_search("irc", $name) eq "")
				{
					# Unset and if successful flag as changed
					$rc = weechat::config_unset_plugin($name);
					if ($rc eq weechat::WEECHAT_CONFIG_OPTION_UNSET_OK_REMOVED)
					{
						$action = 1;
					}
				}
			}
			# Add changed entry names to list
			push (@chans, $name) if ($action);
		}
	}
	weechat::infolist_free($infolist);
	# If channels were cleaned from config
	if (@chans)
	{
		# If only one entry
		if (@chans == 1)
		{
			$str = "\tchanmon.pl: Cleaned ".@chans." entry from the config:";
		}
		else
		{
			$str = "\tchanmon.pl: Cleaned ".@chans." entries from the config:";
		}
		# Build a list of channels
		foreach(@chans)
		{
			$str = $str." ".$_;
		}
		# Print what happened
		weechat::print("",$str);
	}
	# Config seemed to be clean
	else
	{
		weechat::print("", "\tchanmon.pl: No entries removed");
	}
	return weechat::WEECHAT_RC_OK;
}

# Check config elements
sub chanmon_config_init
{
528 529 530 531 532 533 534 535 536
	# First run default
	if (!(weechat::config_is_set_plugin ("first_run")))
	{
		if (weechat::config_get_plugin("first_run") ne "true")
		{
			weechat::print("", "\tThis appears to be the first time chanmon has been run. For help and common set up hints see /chanmon help");
			weechat::config_set_plugin("first_run", "true");
		}
	}
537 538 539 540 541 542 543 544 545
	# Alignment default
	if (!(weechat::config_is_set_plugin ("alignment")))
	{
		weechat::config_set_plugin("alignment", "channel");
	}
	if (weechat::config_get_plugin("alignment") eq "")
	{
		weechat::config_set_plugin("alignment", "none");
	}
546

547 548 549 550 551
	# Dynmon default
	if (!(weechat::config_is_set_plugin ("dynamic")))
	{
		weechat::config_set_plugin("dynamic", "off");
	}
552

553 554 555 556 557
	# Short name default
	if (!(weechat::config_is_set_plugin ("short_names")))
	{
		weechat::config_set_plugin("short_names", "off");
	}
558

559 560 561 562 563
	# Coloured names default
	if (!(weechat::config_is_set_plugin ("color_buf")))
	{
		weechat::config_set_plugin("color_buf", "on");
	}
564

565 566 567 568 569 570 571 572 573 574 575
	# Away message default
	if (!(weechat::config_is_set_plugin ("show_aways")))
	{
		weechat::config_set_plugin("show_aways", "off");
	}

	# chanmon log default
	if (!(weechat::config_is_set_plugin ("logging")))
	{
		weechat::config_set_plugin("logging", "off");
	}
576

577 578 579 580 581
	# Output default
	if (!(weechat::config_is_set_plugin ("output")))
	{
		weechat::config_set_plugin("output", "buffer");
	}
582

583 584 585 586 587
	# Private message merging
	if (!(weechat::config_is_set_plugin ("merge_private")))
	{
		weechat::config_set_plugin("merge_private", "off");
	}
588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625

	# Check for exisiting prefix/suffix chars, and setup accordingly
	$prefix = weechat::config_get("irc.look.nick_prefix");
	$prefix = weechat::config_string($prefix);
	$suffix = weechat::config_get("irc.look.nick_suffix");
	$suffix = weechat::config_string($suffix);

	if (!(weechat::config_is_set_plugin("nick_prefix")))
	{
		if ($prefix eq "" && $suffix eq "")
		{
			weechat::config_set_plugin("nick_prefix", "<");
		}
		else
		{
			weechat::config_set_plugin("nick_prefix", "");
		}
	}

	if (!(weechat::config_is_set_plugin("nick_suffix")))
	{
		if ($prefix eq "" && $suffix eq "")
		{
			weechat::config_set_plugin("nick_suffix", ">");
		}
		else
		{
			weechat::config_set_plugin("nick_suffix", "");
		}
	}
}

# Get config updates
sub chanmon_config_cb
{
	$point = $_[0];
	$name = $_[1];
	$value = $_[2];
626

627
	$name =~ s/^plugins\.var\.perl\.chanmon\.//;
628

629 630 631 632 633 634 635 636 637 638 639
	# Set logging on buffer
	if ($name eq "logging")
	{
		# Search for pre-existing buffer
		$chanmon_buffer = weechat::buffer_search("perl", "chanmon");
		if ($value eq "off")
		{
			weechat::buffer_set($chanmon_buffer, "localvar_set_no_log", "1");
		}
		else
		{
640
			weechat::buffer_set($chanmon_buffer, "localvar_del_no_log", "");
641 642 643 644 645 646 647 648 649 650 651 652 653 654
		}
	}
	# Output changer
	elsif ($name eq "output")
	{
		if ($value eq "bar")
		{
			# Search for pre-existing buffer
			$chanmon_buffer = weechat::buffer_search("perl", "chanmon");
			# Close if it exists
			if ($chanmon_buffer ne "")
			{
				weechat::buffer_close($chanmon_buffer)
			}
655

656 657 658 659 660 661 662 663 664 665 666 667 668 669 670
			# Output bar lines default
			if (!(weechat::config_is_set_plugin ("bar_lines")))
			{
				weechat::config_set_plugin("bar_lines", "10");
			}
			# Make a bar if doesn't exist
			chanmon_bar_open();
		}
		elsif ($value eq "buffer")
		{
			# If a bar exists, close it
			chanmon_bar_close();
			# Open buffer
			chanmon_buffer_open();
		}
671 672 673 674 675 676 677 678 679 680

	}
	elsif ($name eq "weechat.look.prefix_suffix")
	{
		if (weechat::config_get_plugin("output") eq "bar")
		{
			@bar_lines = ();
			weechat::print("", "\tchanmon: weechat.look.prefix_suffix changed, clearing chanmon bar");
			weechat::bar_item_update("chanmon");
		}
681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705
	}
	return weechat::WEECHAT_RC_OK;
}

# Toggle dynamic monitoring on/off
sub chanmon_dyn_toggle
{
	if (weechat::config_get_plugin("dynamic") eq "off")
	{
		weechat::config_set_plugin("dynamic", "on");
		chanmon_print("Dynamic Channel Monitoring Enabled");
		return weechat::WEECHAT_RC_OK;
	}
	elsif (weechat::config_get_plugin("dynamic") eq "on")
	{
		weechat::config_set_plugin("dynamic", "off");
		chanmon_print("Dynamic Channel Monitoring Disabled");
		return weechat::WEECHAT_RC_OK;
	}
}

# Set up weechat hooks / commands
sub chanmon_hook
{
	weechat::hook_print("", "", "", 0, "chanmon_new_message", "");
706
	weechat::hook_command("chmonitor", "Toggles monitoring for a channel", "[channel [server]]", " channel: What channel to toggle monitoring for\n  server: Internal server name, if channel is on more than one server", "%(irc_channels) %(irc_servers)", "chanmon_toggle", "");
707 708
	weechat::hook_command("dynmon", "Toggles 'dynamic' monitoring (auto-disable monitoring for current channel)", "", "", "", "chanmon_dyn_toggle", "");
	weechat::hook_command("chanclean", "Chanmon config clean up", "default|orphan|all", " default: Cleans all config entries with the default \"on\" value\n  orphan: Cleans all config entries for channels you aren't currently joined\n     all: Does both defaults and orphan", "default|orphan|all", "chanmon_config_clean", "");
709

710
	weechat::hook_command("chanmon", "Chanmon help", "[help] | [monitor [channel [server]]] | [dynmon] | [clean default|orphan|all] | clearbar", "    help: Print help for chanmon\n monitor: Toggles monitoring for a channel (/chmonitor)\n  dynmon: Toggles 'dynamic' monitoring (auto-disable monitoring for current channel) (/dynmon)\n   clean: Chanmon config clean up (/chanclean)\nclearbar: Clear Chanmon bar", "help || monitor %(irc_channels) %(irc_servers) || dynmon || clean default|orphan|all || clearbar", "chanmon_command_cb", "");
711

712
	weechat::hook_config("plugins.var.perl.chanmon.*", "chanmon_config_cb", "");
713
	weechat::hook_config("weechat.look.prefix_suffix", "chanmon_config_cb", "");
714 715 716
}

# Main body, Callback for hook_print
717 718 719 720 721 722
sub chanmon_new_message
{
	my $net = "";
	my $chan = "";
	my $nick = "";
	my $outstr = "";
723 724
	my $window_displayed = "";
	my $dyncheck = "0";
725 726

#	DEBUG point
727 728
#	$string = "\t"."0: ".$_[0]." 1: ".$_[1]." 2: ".$_[2]." 3: ".$_[3]." 4: ".$_[4]." 5: ".$_[5]." 6: ".$_[6]." 7: ".$_[7];
#	weechat::print("", "\t".$string);
729

730 731 732 733 734 735 736 737 738
	$cb_datap = $_[0];
	$cb_bufferp = $_[1];
	$cb_date = $_[2];
	$cb_tags = $_[3];
	$cb_disp = $_[4];
	$cb_high = $_[5];
	$cb_prefix = $_[6];
	$cb_msg = $_[7];

739
	# Only work on messages and topic notices
740
	if ($cb_tags =~ /irc_privmsg/ || $cb_tags =~ /irc_topic/)
741
	{
742
		# Check buffer name is an IRC channel or private message when enabled
743
		$bufname = weechat::buffer_get_string($cb_bufferp, 'name');
744
		if ($bufname =~ /(.*)\.([#&\+!])(.*)/ || (weechat::config_get_plugin("merge_private") eq "on" && $cb_tags =~ /notify_private/))
745
		{
746 747
			# Are we running on this channel
			if (weechat::config_get_plugin($bufname) ne "off" && $cb_disp eq "1")
748
			{
749
				# Are we running dynamically
750 751
				if (weechat::config_get_plugin("dynamic") eq "on")
				{
752
					# Check if this buffer is shown in a window somewhere
753
					$window_displayed = weechat::buffer_get_integer($cb_bufferp, "num_displayed");
754
					if ($window_displayed ne 0)
755
					{
756 757
						# Stop running
						return weechat::WEECHAT_RC_OK;
758 759 760
					}
				}

761 762 763
				# Format nick
				# Line isn't action or topic notify
				if (!($cb_tags =~ /irc_action/) && !($cb_tags =~ /irc_topic/))
764
				{
765
					# Highlight
766
					if ($cb_high eq "1")
767
					{
768
						# Strip nick colour
769
						$uncolnick = weechat::string_remove_color($cb_prefix, "");
770
						# Format nick
771
						$nick = " ".weechat::config_get_plugin("nick_prefix").weechat::color("chat_highlight").$uncolnick.weechat::color("reset").weechat::config_get_plugin("nick_suffix");
772
					}
773
					# Normal line
774 775
					else
					{
776
						# Format nick
777
						$nick = " ".weechat::config_get_plugin("nick_prefix").$cb_prefix.weechat::color("reset").weechat::config_get_plugin("nick_suffix");
778 779
					}
				}
780 781
				# Topic line
				elsif ($cb_tags =~ /irc_topic/)
782
				{
783

784
					$nick = " ".$cb_prefix.weechat::color("reset");
785
				}
786
				# Action line
787 788
				else
				{
789
					# Highlight
790
					if ($cb_high eq "1")
791 792 793 794
					{
						$uncolnick = weechat::string_remove_color($cb_prefix, "");
						$nick = weechat::color("chat_highlight").$uncolnick.weechat::color("reset");
					}
795
					# Normal line
796 797 798 799
					else
					{
						$nick = $cb_prefix.weechat::color("reset");
					}
800
				}
801
				# Send to output
802
				chanmon_print ($cb_msg, $cb_bufferp, $nick, $cb_date, $cb_tags);
803 804 805
			}
		}
	}
806 807
	# Special outgoing ACTION & away_info catcher
	elsif ($cb_tags eq "" || $cb_tags =~ /away_info/ && weechat::config_get_plugin("show_aways") eq "on" )
808
	{
809
		# Check buffer name is an IRC channel or private message when enabled
810
		$bufname = weechat::buffer_get_string($cb_bufferp, 'name');
811
		if ($bufname =~ /(.*)\.([#&\+!])(.*)/ || (weechat::config_get_plugin("merge_private") eq "on" && $cb_tags =~ /notify_private/))
812
		{
813 814
			# Are we running dynamically
			if (weechat::config_get_plugin("dynamic") eq "on")
815
			{
816 817 818
				# Check if this buffer is shown in a window somewhere
				$window_displayed = weechat::buffer_get_integer($cb_bufferp, "num_displayed");
				if ($window_displayed eq 1)
819
				{
820 821
					# Stop running
					return weechat::WEECHAT_RC_OK;
822
				}
823
			}
824

825 826 827 828 829 830 831 832 833
			$net = $1;
			$mynick = weechat::info_get("irc_nick", $net);
			if ($cb_msg =~ $mynick)
			{
				$action_colour = weechat::color(weechat::config_string(weechat::config_get("weechat.color.chat_prefix_action")));
				$action_prefix = weechat::config_string(weechat::config_get("weechat.look.prefix_action"));
				$nick_self_colour = weechat::color(weechat::config_string(weechat::config_get("weechat.color.chat_nick_self")));
				$nick = $action_colour.$action_prefix.$nick_self_colour.$nick.weechat::color("reset");
				# Send to output
834
				chanmon_print ($cb_msg, $cb_bufferp, $nick, $cb_date, $cb_tags);
835 836 837 838 839 840
			}
		}
	}
	return weechat::WEECHAT_RC_OK;
}

841 842
# Output formatter and printer takes (msg bufpointer nick)
sub chanmon_print
843
{
844 845 846
	$cb_msg = $_[0];
	my $cb_bufferp = $_[1] if ($_[1]);
	my $nick = $_[2] if ($_[2]);
847 848
	my $cb_date = $_[3] if ($_[3]);
	my $cb_tags = $_[4] if ($_[4]);
849

850 851
	#Normal channel message
	if ($cb_bufferp && $nick)
852
	{
853
		# Format buffer name
854 855
		$bufname = format_buffer_name($cb_bufferp);

856 857
		# If alignment is #channel | nick msg
		if (weechat::config_get_plugin("alignment") eq "channel")
858
		{
859 860 861 862 863 864 865 866 867 868 869 870 871
			$nick =~ s/\s(.*)/$1/;
			# Build string
			$outstr = $bufname."\t".$nick." ".$cb_msg;
		}
		# or if it is channel number | nick msg
		elsif (weechat::config_get_plugin("alignment") eq "schannel")
		{
			$nick =~ s/\s(.*)/$1/;
			# Use channel number instead
			$bufname = weechat::color("chat_prefix_buffer").weechat::buffer_get_integer($cb_bufferp, 'number').weechat::color("reset");
			# Build string
			$outstr = $bufname."\t".$nick." ".$cb_msg;
		}
872 873 874 875 876 877 878 879 880
		# or if it is number:#channel | nick msg
		elsif (weechat::config_get_plugin("alignment") eq "nchannel")
		{
			$nick =~ s/\s(.*)/$1/;
			# Place channel number in front of formatted name
			$bufname = weechat::color("chat_prefix_buffer").weechat::buffer_get_integer($cb_bufferp, 'number').":".weechat::color("reset").$bufname;
			# Build string
			$outstr = $bufname."\t".$nick." ".$cb_msg;
		}
881 882 883 884 885 886 887 888 889 890 891 892 893 894
		# or if it is #channel nick | msg
		elsif (weechat::config_get_plugin("alignment") eq "channel,nick")
		{
			# Build string
			$outstr = $bufname.":".$nick."\t".$cb_msg;
		}
		# or if it is channel number nick | msg
		elsif (weechat::config_get_plugin("alignment") eq "schannel,nick")
		{
			# Use channel number instead
			$bufname = weechat::color("chat_prefix_buffer").weechat::buffer_get_integer($cb_bufferp, 'number').weechat::color("reset");
			# Build string
			$outstr = $bufname.":".$nick."\t".$cb_msg;
		}
895 896 897 898 899 900 901 902
		# or if it is number:#channel nick | msg
		elsif (weechat::config_get_plugin("alignment") eq "nchannel,nick")
		{
			# Place channel number in front of formatted name
			$bufname = weechat::color("chat_prefix_buffer").weechat::buffer_get_integer($cb_bufferp, 'number').":".weechat::color("reset").$bufname;
			# Build string
			$outstr = $bufname.":".$nick."\t".$cb_msg;
		}
903 904 905 906 907 908 909 910 911 912 913
		# or finally | #channel nick msg
		else
		{
			# Build string
			$outstr = "\t".$bufname.":".$nick." ".$cb_msg;
		}
	}
	# chanmon channel toggle message
	elsif ($cb_bufferp && !$nick)
	{
		# Format buffer name
914 915
		$bufname = format_buffer_name($cb_bufferp);

916 917 918 919 920 921 922 923 924
		# If alignment is #channel * | *
		if (weechat::config_get_plugin("alignment") =~ /channel/)
		{
			# If it's actually channel number * | *
			if (weechat::config_get_plugin("alignment") =~ /schannel/)
			{
				# Use channel number instead
				$bufname = weechat::color("chat_prefix_buffer").weechat::buffer_get_integer($cb_bufferp, 'number').weechat::color("reset");
			}
925 926 927 928 929 930
			# Or if it's actually number:#channel * | *
			if (weechat::config_get_plugin("alignment") =~ /nchannel/)
			{
				# Place channel number in front of formatted name
			$bufname = weechat::color("chat_prefix_buffer").weechat::buffer_get_integer($cb_bufferp, 'number').":".weechat::color("reset").$bufname;
			}
931 932 933 934 935 936 937 938 939 940 941 942 943
			$outstr = $bufname."\t".$cb_msg;
		}
		# or if alignment is | *
		else
		{
			$outstr = $bufname.": ".$cb_msg;
		}
	}
	# chanmon dynmon
	elsif (!$cb_bufferp && !$nick)
	{
		$outstr = "\t".$cb_msg;
	}
944

945 946 947 948 949 950
	# Send string to buffer
	if (weechat::config_get_plugin("output") eq "buffer")
	{
		# Search for and confirm buffer
		$chanmon_buffer = weechat::buffer_search("perl", "chanmon");
		# Print
951 952 953 954 955 956 957 958
		if ($cb_date)
		{
			weechat::print_date_tags($chanmon_buffer, $cb_date, $cb_tags, $outstr);
		}
		else
		{
			weechat::print($chanmon_buffer, $outstr);
		}
959 960 961 962 963
	}
	elsif (weechat::config_get_plugin("output") eq "bar")
	{
		# Add time string
		use POSIX qw(strftime);
964 965 966 967 968 969 970 971
		if ($cb_date)
		{
			$time = strftime(weechat::config_string(weechat::config_get("weechat.look.buffer_time_format")), localtime($cb_date));
		}
		else
		{
			$time = strftime(weechat::config_string(weechat::config_get("weechat.look.buffer_time_format")), localtime);
		}
972
		# Colourise
973
		if ($time =~ /\$\{(?:color:)?[\w,]+\}/) # Coloured string
974
		{
975
			while ($time =~ /\$\{(?:color:)?([\w,]+)\}/)
976 977
			{
				$color = weechat::color($1);
978
				$time =~ s/\$\{(?:color:)?[\w,]+\}/$color/;
979
			}
980
			$time .= weechat::color("reset");
981 982 983 984 985 986 987
		}
		else # Default string
		{
			$colour = weechat::color(weechat::config_string(weechat::config_get("weechat.color.chat_time_delimiters")));
			$reset = weechat::color("reset");
			$time =~ s/(\d*)(.)(\d*)/$1$colour$2$reset$3/g;
		}
988 989
		# Push updates to bar lists
		push (@bar_lines_time, $time);
990

991
		# Change tab char
992
		$delim = " ".weechat::color(weechat::config_string(weechat::config_get("weechat.color.chat_delimiters"))).weechat::config_string(weechat::config_get("weechat.look.prefix_suffix")).weechat::color("reset")." ";
993
		$outstr =~ s/\t/$delim/;
994

995 996 997 998 999
		push (@bar_lines, $outstr);
		# Trigger update
		weechat::bar_item_update("chanmon");
	}
}
1000

1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012
# Start the output display
sub chanmon_start
{
	if (weechat::config_get_plugin("output") eq "buffer")
	{
		chanmon_buffer_open();
	}
	elsif (weechat::config_get_plugin("output") eq "bar")
	{
		chanmon_bar_open();
	}
}
1013

1014 1015 1016 1017 1018 1019
# Takes two optional args (channel server), toggles monitoring on/off
sub chanmon_toggle
{
	$data = $_[0];
	$buffer = $_[1];
	$args = $_[2];
1020

1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037
	# Check if we've been told what channel to act on
	if ($args ne "")
	{
		# Split argument up
		@arg_array = split(/ /,$args);
		# Check if a server was given
		if ($arg_array[1])
		{
			# Find matching
			$bufp = weechat::buffer_search("irc", $arg_array[1].".".$arg_array[0]);
		}
		else
		{
			$found_chans = 0;
			# Loop through defined servers
			$infolist = weechat::infolist_get("buffer", "", "");
			while (weechat::infolist_next($infolist))
1038
			{
1039 1040
				# Only interesting in IRC buffers
				if (weechat::infolist_string($infolist, "plugin_name") eq "irc")
1041
				{
1042 1043 1044 1045 1046 1047 1048
					# Find buffers that maych
					$sname = weechat::infolist_string($infolist, "short_name");
					if ($sname eq $arg_array[0])
					{
						$found_chans++;
						$bufp = weechat::infolist_pointer($infolist, "pointer");
					}
1049 1050
				}
			}
1051 1052 1053
			weechat::infolist_free($infolist);
			# If the infolist found more than one channel, halt as we need to know which one
			if ($found_chans > 1)
1054
			{
1055 1056
				weechat::print("", "Channel name is not unique, please define server");
				return weechat::WEECHAT_RC_OK;
1057
			}
1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082
		}
		# Something didn't return right
		if ($bufp eq "")
		{
			weechat::print("", "Could not find buffer");
			return weechat::WEECHAT_RC_OK;
		}
	}
	else
	{
		# Get pointer from where we are
		$bufp = weechat::current_buffer();
	}
	# Get buffer name
	$bufname = weechat::buffer_get_string($bufp, 'name');
	# Test if buffer is an IRC channel
	if ($bufname =~ /(.*)\.([#&\+!])(.*)/)
	{
		if (weechat::config_get_plugin($bufname) eq "off")
		{
			# If currently off, set on
			weechat::config_set_plugin($bufname, "on");

			# Send to output formatter
			chanmon_print("Channel Monitoring Enabled", $bufp);
1083 1084 1085 1086
			return weechat::WEECHAT_RC_OK;
		}
		elsif (weechat::config_get_plugin($bufname) eq "on" || weechat::config_get_plugin($bufname) eq "")
		{
1087
			# If currently on, set off
1088
			weechat::config_set_plugin($bufname, "off");
1089

1090 1091
			# Send to output formatter
			chanmon_print("Channel Monitoring Disabled", $bufp);
1092 1093 1094 1095 1096
			return weechat::WEECHAT_RC_OK;
		}
	}
}

1097 1098
# Takes a buffer pointer and returns a formatted name
sub format_buffer_name
1099 1100
{
	$cb_bufferp = $_[0];
1101
	$bufname = weechat::buffer_get_string($cb_bufferp, 'name');
1102

1103
	# Set colour from buffer name
1104 1105
	if (weechat::config_get_plugin("color_buf") eq "on")
	{
1106
		# Determine what colour to use
1107 1108
		$color = weechat::info_get("irc_nick_color", $bufname);
		if (!$color)
1109
		{
1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120
			$color = 0;
			@char_array = split(//,$bufname);
			foreach $char (@char_array)
			{
				$color += ord($char);
			}
			$color %= 10;
			$color = sprintf "weechat.color.chat_nick_color%02d", $color+1;
			$color = weechat::config_get($color);
			$color = weechat::config_string($color);
			$color = weechat::color($color);
1121
		}
1122

1123 1124 1125 1126 1127
		# Private message just show network
		if (weechat::config_get_plugin("merge_private") eq "on" && weechat::buffer_get_string($cb_bufferp, "localvar_type") eq "private")
		{
			$bufname = weechat::buffer_get_string($cb_bufferp, "localvar_server");
		}
1128
		# Format name to short or 'nicename'
1129
		elsif (weechat::config_get_plugin("short_names") eq "on")
1130 1131 1132 1133 1134 1135 1136
		{
			$bufname = weechat::buffer_get_string($cb_bufferp, 'short_name');
		}
		else
		{
			$bufname =~ s/(.*)\.([#&\+!])(.*)/$1$2$3/;
		}
1137

1138
		# Build a coloured string
1139
		$bufname = $color.$bufname.weechat::color("reset");
1140
	}
1141
	# User set colour name
1142 1143
	elsif (weechat::config_get_plugin("color_buf") ne "off")
	{
1144 1145 1146 1147 1148
		# Private message just show network
		if (weechat::config_get_plugin("merge_private") eq "on" && weechat::buffer_get_string($cb_bufferp, "localvar_type") eq "private")
		{
			$bufname = weechat::buffer_get_string($cb_bufferp, "localvar_server");
		}
1149
		# Format name to short or 'nicename'
1150
		elsif (weechat::config_get_plugin("short_names") eq "on")
1151 1152 1153 1154 1155 1156 1157
		{
			$bufname = weechat::buffer_get_string($cb_bufferp, 'short_name');
		}
		else
		{
			$bufname =~ s/(.*)\.([#&\+!])(.*)/$1$2$3/;
		}
1158

1159 1160 1161
		$color = weechat::config_get_plugin("color_buf");
		$bufname = weechat::color($color).$bufname.weechat::color("reset");
	}
1162 1163
	# Stick with default colour
	else
1164
	{
1165 1166 1167 1168 1169
		# Private message just show network
		if (weechat::config_get_plugin("merge_private") eq "on" && weechat::buffer_get_string($cb_bufferp, "localvar_type") eq "private")
		{
			$bufname = weechat::buffer_get_string($cb_bufferp, "localvar_server");
		}
1170
		# Format name to short or 'nicename'
1171
		elsif (weechat::config_get_plugin("short_names") eq "on")
1172 1173 1174 1175 1176 1177 1178
		{
			$bufname = weechat::buffer_get_string($cb_bufferp, 'short_name');
		}
		else
		{
			$bufname =~ s/(.*)\.([#&\+!])(.*)/$1$2$3/;
		}
1179
	}
1180

1181
	return $bufname;
1182 1183
}

1184
# Check result of register, and attempt to behave in a sane manner
1185
if (!weechat::register("chanmon", "KenjiE20", "2.5", "GPL3", "Channel Monitor", "", ""))
1186
{
1187 1188
	# Double load
	weechat::print ("", "\tChanmon is already loaded");
1189 1190
	return weechat::WEECHAT_RC_OK;
}
1191
else
1192
{
1193 1194 1195 1196
	# Start everything
	chanmon_hook();
	chanmon_config_init();
	chanmon_start();
1197
}