summaryrefslogtreecommitdiff
path: root/lib/Text/Tabs.pm
blob: 2481d81ec6b22f160fe5e141dd45c386c4f62dbf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#
# expand and unexpand tabs as per the unix expand and 
# unexpand programs.
#
# expand and unexpand operate on arrays of lines.  Do not
# feed strings that contain newlines to them.
#
# David Muir Sharnoff <muir@idiom.com>
# 
# Version: 9/21/95
#

=head1 NAME

Text::Tabs -- expand and unexpand tabs

=head1 SYNOPSIS

	use Text::Tabs;
	
	#$tabstop = 8; # Defaults
	print expand("Hello\tworld");
	print unexpand("Hello,        world");
	$tabstop = 4;
	print join("\n",expand(split(/\n/,
		"Hello\tworld,\nit's a nice day.\n"
		)));

=head1 DESCRIPTION

This module expands and unexpands tabs into spaces, as per the unix expand
and unexpand programs. Either function should be passed an array of strings
(newlines may I<not> be included, and should be used to split an incoming
string into separate elements.) which will be processed and returned.

=head1 AUTHOR

David Muir Sharnoff <muir@idiom.com>

=cut

package Text::Tabs;

require Exporter;

@ISA = (Exporter);
@EXPORT = qw(expand unexpand $tabstop);

$tabstop = 8;

sub expand
{
	my @l = @_;
	for $_ (@l) {
		1 while s/^([^\t]*)(\t+)/
			$1 . (" " x 
				($tabstop * length($2)
				- (length($1) % $tabstop)))
			/e;
	}
	return @l if wantarray;
	return @l[0];
}

sub unexpand
{
	my @l = &expand(@_);
	my @e;
	for $x (@l) {
		@e = split(/(.{$tabstop})/,$x);
		for $_ (@e) {
			s/  +$/\t/;
		}
		$x = join('',@e);
	}
	return @l if wantarray;
	return @l[0];
}

1;