This file is indexed.

/usr/bin/refdb-ms is in refdb-clients 1.0.2-3ubuntu1.

This file is owned by root:root, with mode 0o755.

The actual contents of the file can be viewed below.

  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
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
#!/usr/bin/perl

=head1 NAME

refdb-ms - RefDB MakeStyle, a bibliography style generator for RefDB

=head1 Summary

A utility to aid the generation of RefDB bibliography styles for RefDB <refdb.sourceforge.net>.

=head1 Requirements

One of the design goals for this utility was to minimise external dependencies.

=over

=item Refdb::Makestyle

A custom module containing methods and attributes used by this script.

Debian package: libperl-refdb-makestyle.

=back

=cut

use strict;
use RefDB::Makestyle;

$ENV{'CLUI_DIR'} = "OFF"; 

my $ui = UI->new();

die "Fatal errors encountered.\n" if not $ui->startup_checks();

=head1 The program

=head2 Style root

The root element of the style, C<CiteStyle>, is a data member of the user-interface (C<ui>) object.  All other elements of the style are children of the C<CiteStyle> element.

=cut

$ui->set_root( CiteStyle->new() );

=head2 Help system

There is a series of help screens.  See C<refdb-ms.pl> library for details.

=cut

print "RefDB MakeStyle -- generate bibliography styles for RefDB.\n";
$ui->help_system() if $ui->_input_confirm( "Do you require help?" );

=head2 Main entry loop

This is the main part of the program -- where the style itself is created.

It is short as most of the "work" is done by the C<refdb-ms.pl> library.

=cut

my ( $current_element , @choice , $child ) =
	( $ui->get_root()->get_last_incomplete() );
$current_element->add_attributes();
$current_element->enter_value();
while ( 1 ) {
	# Get working element
	$current_element = $ui->get_root()->get_last_incomplete();
	last if not defined $current_element;  # style is complete 
	# Add element attributes and content
	$current_element->add_attributes();
	$current_element->enter_value();
	# Provide feedback
	printf "\nProgress report:\n%s\n" , $ui->get_root()->show_progress();
	printf "Current element: %s\n" , $current_element->get_name();
	# Select next element/action
	@choice = $current_element->select_next_child();
	# Delete element if user selected that option
	if ( @choice[1] eq "[DELETE]" ) {
		$ui->delete_selected_element();
		next;
	}
	# If current element complete, skip next part
	next if not defined $choice[1];  # current element is complete
	printf "\n%s" , @choice[0];
	# Add newly selected element to style
	$child = $ui->create_element( @choice[1] );
	$current_element->add_child( $child );
}
print "\nThe style is now complete.\n";

=head2 Write output

The style is written to an C<xml> file.  If the default name, E<lt>I<stylename>-style.xmlE<gt>, already exists, another is created.

=cut

$ui->write_style();

=head2 Write summary

A summary of the style is written to an C<html> file.  It is meant as an aide memoire when entering references.

=cut

$ui->write_summary();

=head2 Upload style

The style can be uploaded to refdb.  If a pre-existing style of the same name exists it is backed up to file before the new style is added.

=cut

$ui->upload_style();

printf "\nStyle \"%s\" has been created.\nIt has been saved to file <%s>.\nA summary of the style has been written to file <%s>.\n\nRefDB Makestyle is finished.\n" , $ui->get_root()->get_style_name() , $ui->get_style_file() , $ui->get_summary_file();
exit 0;

=head1 AUTHOR

David Nebauer, david E<lt>atE<gt> nebauer E<lt>dotE<gt> org

=head1 COPYRIGHT AND LICENSE

Copyright (C) 2004 by David Nebauer

Distributed under the same license and conditions as the C<Refdb> project E<lt>L<http://refdb.sourceforge.net/>E<gt>.

=cut