#! /usr/local/bin/perl
################################################################
###
### impack
###
### Author: Internet Message Group
### Created: Apr 23, 1997
### Revised: Mar 8, 2005
###
BEGIN {
use lib '/usr/local/lib';
use lib '/mnt/gmirror/ports/mail/im/work/im-148'; ###DELETE-ON-INSTALL###
};
$Prog = 'impack';
my $VERSION_DATE = "20050308";
my $VERSION_NUMBER = "148";
my $VERSION = "${Prog} version ${VERSION_DATE}(IM${VERSION_NUMBER})";
my $VERSION_INFORMATION = "${Prog} (IM ${VERSION_NUMBER}) ${VERSION_DATE}
Copyright (C) 1999 IM developing team
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
";
##
## Require packages
##
use IM::Config;
use IM::Folder;
use IM::File;
use IM::Util;
use integer;
use strict;
use vars qw($Prog $EXPLANATION @OptConfig
$opt_src $opt_noharm $opt_verbose
$opt_debug $opt_help $opt_version);
##
## Environments
##
$EXPLANATION = "$VERSION
pack mail/news messages in a folder
Usage: $Prog [OPTIONS] [FOLDER]
";
@OptConfig =(
'src;F;;' => "Set source folder",
'noharm;b;;' => "No packing. Show what will happen",
'verbose;b;;' => 'With verbose messages',
'debug;d;;' => "With debug message",
'help;b;;' => "Display this help and exit",
'version,V;b;;' => "Output version information and exit",
);
##
## Profile and option processing
##
init_opt(\@OptConfig);
read_cfg();
read_opt(\@ARGV); # help?
print("${VERSION_INFORMATION}") && exit $EXIT_SUCCESS if $opt_version;
help($EXPLANATION) && exit $EXIT_SUCCESS if $opt_help;
debug_option($opt_debug) if $opt_debug;
##
## Main
##
impack($opt_src);
exit $EXIT_SUCCESS;
##################################################
##
## Work horse
##
sub impack($) {
my $folder = shift;
my $msg = 1;
my $dst;
chk_folder_existance($folder); # not return in case false.
my @paths = get_impath($folder, 'all');
print "packing messages in $opt_src..." unless $opt_noharm;
flush('STDOUT') unless $opt_noharm;
foreach (@paths) {
$dst = $_;
if (-f $dst) {
do {
$dst =~ s|[^/]+$|$msg++|e;
} while ($_ ne $dst && -e $dst);
if ($_ ne $dst) {
im_rename($_, $dst) || die $@; # XXX
}
}
}
print "done\n" unless $opt_noharm;
touch_folder($folder) unless $opt_noharm;
}
__END__
=head1 NAME
impack - pack mail/news messages in a folder
=head1 SYNOPSIS
B [OPTIONS] [FOLDER]
=head1 DESCRIPTION
The I command packs mail/news messages in a folder.
This command is provided by IM (Internet Message).
=head1 OPTIONS
=over 5
=item I<-s, --src=FOLDER>
Set source folder. Default value is "+inbox".
"--src=+xxx" is equivalent to "+xxx".
=item I<-n, --noharm={on,off}>
No packing. Show what will happen.
=item I<-v, --verbose={on,off}>
Print verbose messages when running.
=item I<--debug=DEBUG_OPTION>
Print debug messages when running.
=item I<-h, --help>
Display help message and exit.
=item I<--version>
Output version information and exit.
=back
=head1 COPYRIGHT
IM (Internet Message) is copyrighted by IM developing team.
You can redistribute it and/or modify it under the modified BSD
license. See the copyright file for more details.
=cut
### Copyright (C) 1997, 1998, 1999 IM developing team
### All rights reserved.
###
### Redistribution and use in source and binary forms, with or without
### modification, are permitted provided that the following conditions
### are met:
###
### 1. Redistributions of source code must retain the above copyright
### notice, this list of conditions and the following disclaimer.
### 2. Redistributions in binary form must reproduce the above copyright
### notice, this list of conditions and the following disclaimer in the
### documentation and/or other materials provided with the distribution.
### 3. Neither the name of the team nor the names of its contributors
### may be used to endorse or promote products derived from this software
### without specific prior written permission.
###
### THIS SOFTWARE IS PROVIDED BY THE TEAM AND CONTRIBUTORS ``AS IS'' AND
### ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
### IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
### PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE TEAM OR CONTRIBUTORS BE
### LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
### CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
### SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
### BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
### WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
### OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
### IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
### Local Variables:
### mode: perl
### End: