File: README

package info (click to toggle)
cthumb 4.2-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,744 kB
  • sloc: sh: 2,010; makefile: 75
file content (355 lines) | stat: -rw-r--r-- 11,522 bytes parent folder | download | duplicates (5)
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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
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
cthumb - a themable web picture album generator
===============================================

	Home Page:	http://cthumb.sourceforge.net/
	Project Page:	http://sourceforge.net/projects/cthumb/

	Ideas and contributions: cthumb-devel@nospam.lists.sourceforge.net

Quick Intro
===========

suppose you have some pictures in a directory, say *.jpg. to
get going quickly, you do this:

	bash$ cthumb -c *.jpg > starter.album
	bash$ mkdir thumb/
	bash$ cthumb starter.album
	bash$ vi starter.album
	      (edit at will)
	bash$ cthumb starter.album
	      (view)
	bash$ vi starter.album
	      (edit at will)
	bash$ cthumb starter.album
	      (view)
	bash$ ...etc., releat until you are happy with the result

Introduction
============

You have a digital camera. You have lots of pictures. You have family
and friends who speak, say, two languages, but not both. This program
was written because I urgently needed to organize my online pictures
in a sane manner and wanted two sets of friends to enjoy them, with
captions in their own languages. See an example in

	Home Page:	http://cthumb.sourceforge.net/
	Project Page:	http://sourceforge.net/projects/cthumb/

cthumb is a command-line program that allows you to create an web
picture album, with an index and several pages, each with thumbnails
of your pictures. It optionally generates otherwise identical pages
but in several languages, simultaneously. It automatically generates
thumbnails of the pictures. It attempts to be nice in the look of the
pages it generates.

It is geared towards people that have ton of digital images that need
to be labeled, grouped, captioned and sorted out. All you need is the
pictures and a text editor to put all the captions for the picture in
a simple "album" textfile.


The .album Input Files
======================

The "input file" for cthumb is called an "album file", something like
"trip-to-cancun.album" which is a simple text file, formatted in a
very simple way. You invoke cthumb with that album file and it
generates HTML pages with the contents of the web album:

	bash$ cthumb trip-to-cancun.album
	cthumb 3.2, running in ....
		generating thumbnail for cancun1.jpg ... done.
		generating thumbnail for cancun2.jpg ... done.
		generating thumbnail for cancun3.jpg ... done.
		generating thumbnail for cancun4.jpg ... done.
	Creating page:	page-1.shtml
	Creating page:	page-2.shtml
	Index for trip-to-cancun.album in: trip-to-cancun-index.shtml
	bash$ 

Now, "how do I come up with the '.album' file?", you are probably
wondering...

Rather than explaining the format for .album files here, we can
actually use cthumb for generating default-looking album files for a
bunch of pictures, which you can modify to put your captions and make
it look like you want.

cthumb actually has two modes of operation: "Album creation mode" and
"Regular mode". With the album creation mode you can come up with a
.album file, then tweak it, add the captions you want, and then, using
cthumb in regular mode, you can create a web album from the .album
file. The purpose of the first phase is to avoid having to write the
whole .album file by hand.

1.- Album Creation Mode
-----------------------

You could write a .album file by hand, but cthumb can help you
come up with one to work with automatically, given your pictures.

To create a default-looking album file, you can use the -c command
line option, which asks cthumb to run in album creation mode, followed
by the files you want displayed in the album. The resulting album file
is sent via the standard output. e.g.:

	bash$ cthumb -c *.gif *.jpg *.png > trip-to-cancun.album
	bash$

now, you can inspect and hack the trip-to-cancun.album, which is a
text file with a sime format and go from there.

2.- Regular Mode
----------------

When you are happy, and from then on, you then generate the HTML with
the actual web album:

	bash$ cthumb trip-to-cancun.album
	...
	bash$ <edit trip-to-cancun.album>
	bash$ cthumb trip-to-cancun.album
	...
	bash$ edit again ... repeat..

Where to put the Images and Thumbnails
======================================

Given an image called, say,

	cancun1.jpg

a thumbnail called

	cancun1-thumb.jpg

would be generated in the same directory that the image is in. If
a directory called "thumb" exists, then it is placed inside
that directory:

	thumb/cancun1-thumb.jpg

Note that you can group images in directories (with thumb/
subdirectories optionally in each one). e.g. you can have
images listed in the album file as:

	001205-cancun-trip/cancun1.jpg

and the thumbnail will be:

	001205-cancun-trip/cancun1-thumb.jpg

(or 001205-cancun-trip/thumb/cancun1-thumb.jpg if thumb/ exists).

Usage note: option -t will force cthumb to look at the tumbnails's
width and height and generate html IMG references that contain
HEIGHT=... and WIDTH=....  The purpose of this is that for large and
very large pages, knowing this information makes the rendering of the
thumbnail pages much faster. It makes cthumb much slower, because it
has to open and parse each and every thumbnail. This is a reasonable
step for the final pass before making the web pages available for a
while.

The .album Format
=================

To go a bit in detail, lines starting with a "#" are comments. Empty
lines are generally ignored.

Note that empty lines are ignored, unless they are following the Page
or filename lines (in which case the title of the page or caption of
the picture will be empty).

Notice that cthumb only generates html files that are needed,
i.e. pages that would be generated identical to existing pages are not
re-generated (to avoid unnecessary html cache reloads). Same thing
with images and thumbnails. See the example included, along with
pictures.

cthumb options and the ~/.cthumbrc file
=======================================

cthumb takes options in three possible ways, with this priority (most
first):

	command line flags	- at run time
	album file		- each album file its own 
	~/.cthumbrc		- personal to a user
	cthumb script		- defaults across users

For a list of command line options, invoke

	cthumb -h

The syntax in the album files can be gleaned from the sample album
file or from an album generated with the -c flag.

The syntax for the cthumbrc is that of Perl. The variables you can put
in there are these below (listed at the top of the cthumb script), and
listed here with their defaults at the time of writing this README
file. check the top of the cthumb script to see (or change) the
defaults:

	@Languages = ("English", "Espaol", "Valencian");
	$NLanguages = 3;    		# default number of "languages" to use

So, for example, you could have:

	bash$ cat ~/.cthumbrc
	$PicturesPerRow = 6;
	$Theme = neat-round
	bash$

to generate .album files or create web albums with 6 pictures per row.

Finally, note that when cthumb is invoked with -c to create an album,
it picks up the settings from ~/.cthumbrc because there is no album as
input. BTW, the -c option is only available in command line mode,
obviously.

Headers and Footers
===================

HTML files generated are now with the extension ".shtml". What this
does is allow server-side includes to happen. cthumb now autodetects a
header.html and footer.html file for all pages generated. If a header
(or footer) is detected when cthumb is run, a server-side include is
generated that includes the header at the top of the file and the
footer at the bottom. Files having includes have to be ".shtml".
Works on my default Linux/apache setting.

Starting in version 3.5.2, headers and footers can be inlined with the
InlineFiles. The motivation is that some ISPs do not provide server
side includes, so the header/footer feature with server side includes
cannot be used.

This new feature allows to inline the header/footer file instead of
using a server side include. One can use it from the command line or
from inside an album file or a ~/.cthumbrc

 - command line parameter "cthumb -s <dir>"
 - album file variable:

	InlineFiles: <dir>

It checks the given directory for header.html and footer.html and
includes their content instead of the server side include directive.

Automatic Slide Shows
=====================

To turn on automatic generation of slide shows, either turn

   AutoSlideShow: 1

in the album, or set AutoSlideShow 1 in your ~/.cthumbrc, or in the script, etc.
This makes automatic slide shows that change image every few seconds.

Picture Captions
===============

The album file allows one line of caption per language per picture, which
looks like this:

        - image001.jpg
                This is my first language
                This is my second language

        - image002.jpg
                ...

To annotate a picture with an additional longer text, create a text file in
the same directory as the picture file with the following schema:

	picturename.language

Using the example above, the name would be "image001.jpg.english", if
the first language is English. Please note, that the language is
always in lower case. To activate this feature, use the following
setting: StoryOn=1

Requirements
============

This program requires:
	
	perl, with the following:
		use URI::Escape;
		use HTML::Entities;
		use IO::Handle;
		use POSIX;
		use Getopt::Std;
	djpeg, cjpeg	(rpm: libjpeg-*.rpm)
	pnmscale	(rpm: libgr-progs-*.rpm)

Installing the Perl Modules
===========================

This is hard to do, unfortunately.

The perl modules are available in the project web page, however, here
are some instructions on how to use CPAN from the command line. This
would get you the latest (I *have* tried this myself and it works):

	bash$ perl -MCPAN -e shell
	shell> install HTML::Parser

Now, if you are like me, you don't like to do things like root or to
install things on top of rpms, screwing with your dependencies. I install
this modules in /opt/perl-modules, where I have permission as a user:

	bash$ echo $PERL5LIB
	/opt/perl-modules/lib/site_perl
	bash$

after running the perl -MCPAN -e shell once, you need to add these lines
to your ~/.cpan/CPAN/MyConfig.pm file:

'makepl_arg' => q[LIB=/opt/perl-modules/lib/site_perl
            INSTALLMAN1DIR=/opt/perl-modules/lib/site_perl/man/man1
            INSTALLMAN3DIR=/opt/perl-modules/lib/site_perl/man/man3],

all in one line. in my case, an empty line (just q[]) was there for
makepl_arg, so just add it there. All this, courtesy of Alexander Kourakos,
thanks!

CVS INFO
========

Get the directions at sourceforge on how to check out the latest
and greatest from the sourceforge server at:

	http://sourceforge.net/projects/cthumb/

In essence, you can checkout the sources this way:

	cvs -d:pserver:anonymous@cvs.cthumb.sourceforge.net:/cvsroot/cthumb login
	  (when prompted for a password for anonymous, simply press the Enter key)
	cvs -z3 -d:pserver:anonymous@cvs.cthumb.sourceforge.net:/cvsroot/cthumb co cthumb
	cvs -z3 -d:pserver:anonymous@cvs.cthumb.sourceforge.net:/cvsroot/cthumb co cthumb-examples

HOW TO HELP
===========

If you have some suggestions and improvements, please checkout the
latest cvs version and do a

	cvs diff -cN > your.diff

and then _attach_ the file your.diff to
cthumb-devel@lists.sourceforge.net for discussion.

Show me the code!! :-)

License
=======

This program is released under the GNU GPL license, v2.0 or later.
http://www.gnu.org/copyleft/gpl.html

(C) 1999-2002, Carlos Puchol, cpg+cthumb@nospam.puchol.com

	Home Page:	http://cthumb.sourceforge.net/
	Project Page:	http://sourceforge.net/projects/cthumb/