File: backup-blocks

package info (click to toggle)
slash 2.2.6-8etch1
  • links: PTS
  • area: main
  • in suites: etch
  • size: 3,672 kB
  • ctags: 1,915
  • sloc: perl: 23,113; sql: 1,878; sh: 433; makefile: 233
file content (71 lines) | stat: -rwxr-xr-x 1,663 bytes parent folder | download | duplicates (3)
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
#!/usr/bin/perl -w
# This code is a part of Slash, and is released under the GPL.
# Copyright 1997-2001 by Open Source Development Network. See README
# and COPYING for more information, or see http://slashcode.com/.
# $Id: backup-blocks,v 1.2.2.1 2001/06/05 11:51:44 pudge Exp $

# First version by Brian, brian@tangent.org

use strict;
use File::Basename;
use Getopt::Std;
use DBIx::Password;

(my $VERSION) = ' $Revision: 1.2.2.1 $ ' =~ /\$Revision:\s+([^\s]+)/;
my $PROGNAME = basename($0);

my %opts;
# Remember to doublecheck these match usage()!
usage() unless getopts('hvu:', \%opts);
usage() if ($opts{'h'} || !keys %opts);
version() if $opts{'v'};
$opts{'u'} ||= 'slash';

{
	my $dbh = DBIx::Password->connect($opts{'u'});

	my $get = $dbh->prepare("SELECT bid,block FROM blocks");
	my $delete = $dbh->prepare("DELETE FROM backup_blocks");
	my $insert  = $dbh->prepare("INSERT INTO backup_blocks (bid,block) VALUES (?,?)");

	$get->execute();
	$delete->execute();
	while (my @row = $get->fetchrow_array){
		$insert->execute(@row);
	}

	$dbh->disconnect();
}

sub usage {
	print "*** $_[0]\n" if $_[0];
	# Remember to doublecheck these match getopts()!
	print <<EOT;

Usage: $PROGNAME [OPTIONS]

Populate the backup_blocks table.  Will delete existing data
and insert the data from the blocks table.

	-h	Help (this message)
	-v	Version
	-u	Virtual user (default is "slash")

EOT
	exit;
}

sub version {
	print <<EOT;

$PROGNAME $VERSION

This code is a part of Slash, and is released under the GPL.
Copyright 1997-2001 by Open Source Development Network. See README
and COPYING for more information, or see http://slashcode.com/.

EOT
	exit;
}

__END__