author | Pranshu Sharma <pranshu@bauherren.ovh> |
Tue, 07 Jan 2025 00:37:57 +1000 (2 weeks ago) | |
changeset 21 | f61879daacf0 |
parent 20 | ce527668bd78 |
child 22 | dc1add4ee525 |
permissions | -rwxr-xr-x |
0 | 1 |
#!/usr/bin/perl |
1
0b7be2e78d3b
Added more documentation
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
0
diff
changeset
|
2 |
# Author: Pranshu Sharma <pranshu@bauherren.ovh> |
0 | 3 |
|
4 |
use v5.36.0; |
|
5 |
use strict; |
|
6 |
use warnings; |
|
7 |
||
8 |
use XML::LibXML; |
|
9 |
use File::Find; |
|
10 |
use File::Copy qw(copy move); |
|
11 |
use Cwd; |
|
12 |
use experimental qw(declared_refs); |
|
13 |
use Data::Dumper; |
|
5 | 14 |
use POSIX; |
7 | 15 |
# !! Add seperatio between title and identifier |
0 | 16 |
|
17 |
# Fix up CLI interface |
|
18 |
# Add option ro set cache to 0 through command line |
|
19 |
# Print required elisp code it is in $req_config |
|
20 |
# Add config option for $max_rss and $max_cat |
|
8 | 21 |
# Document link to file x from file x no work |
0 | 22 |
# Variable for map_css |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
23 |
# Remove the desc |
0 | 24 |
# Domain thing as well |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
25 |
# 2 articles 1 day better sorting |
7 | 26 |
# cataogry linking |
0 | 27 |
my $cache = 1; |
28 |
||
29 |
my $config_file = "genorg-conf"; |
|
30 |
my $dir = "blog"; |
|
31 |
my $outdir = "out/"; |
|
32 |
my $emacs = "emacs"; |
|
8 | 33 |
my $art_css = "astyle.css"; |
34 |
my $cat_css ="cstyle.css"; |
|
0 | 35 |
my $no_name_dir = "c"; |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
36 |
my $cache_file = "genorg-cache/cache.xml"; |
0 | 37 |
my $domain = "p.bauherren.ovh"; |
38 |
my $max_rss = 30; |
|
39 |
# The first page has one less article. Think of it as a feature. |
|
14 | 40 |
my $max_cat = 30; |
8 | 41 |
my $blog_title = "Pranshu's blog"; |
16 | 42 |
my ($home, $about) = ("index.html", "about.html"); |
9 | 43 |
my $etc_files; |
44 |
my $nav_id = "nav"; |
|
14 | 45 |
my $rdesc = "description"; |
0 | 46 |
|
47 |
my $username = $ENV{LOGNAME} || $ENV{USER} || getpwuid ($<); |
|
48 |
my $template = <<"END"; |
|
49 |
#+title: Test document |
|
50 |
#+subtitle: This is the subtitle |
|
14 | 51 |
#+date: IMPORANT |
0 | 52 |
#+author: $username |
14 | 53 |
#+keywords: tag->thing | rel->a |
0 | 54 |
#+options: html-link-use-abs-url:nil html-postamble:auto |
55 |
#+options: html-preamble:t html-scripts:nil html-style:t |
|
56 |
#+options: html5-fancy:nil tex:t |
|
57 |
#+html_doctype: html5 |
|
58 |
END |
|
59 |
||
60 |
my $req_config = <<"END"; |
|
6
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
61 |
(require 'org) |
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
62 |
(require 'ob) |
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
63 |
(org-link-set-parameters "genorg" |
0 | 64 |
:follow nil |
65 |
:export |
|
66 |
#'(lambda (link desc _ _) |
|
6
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
67 |
(format "<a class=\"rakim\" href=\"%s\">%s</a>" desc link)) |
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
68 |
:store nil) |
0 | 69 |
END |
70 |
||
6
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
71 |
my $custom_code = "(list 1)"; |
5 | 72 |
|
8 | 73 |
my $navbar = <<"END" =~ s/\n\s+//gr; |
74 |
<ul> |
|
9 | 75 |
<li> <a href="LINK">Home</a> </li> |
16 | 76 |
<li> <a href="LINK">Posts</a> </li> |
9 | 77 |
<li> <a href="LINK">About</a> </li> |
8 | 78 |
</ul> |
79 |
END |
|
80 |
||
0 | 81 |
my $elisp_code = <<"END" =~ s/\n\s+//gr; |
20
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
82 |
(let ((ls '(LIST))) |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
83 |
(require 'org) |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
84 |
(mapc |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
85 |
(lambda (b) |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
86 |
(with-current-buffer b |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
87 |
(when (and (not (string-match "^ " (buffer-name b))) |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
88 |
(eq major-mode 'org-mode)) |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
89 |
(org-export-to-file 'html (pop ls))))) |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
90 |
(buffer-list)) |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
91 |
(kill-emacs)) |
0 | 92 |
END |
93 |
||
94 |
||
95 |
my ($h_intro, $h_c_intro, $h_cat_li, $h_chap, $h_en_cat, $h_en, $h_end) |
|
96 |
= split /SPLIT/ ,<<"END" =~ s/\n\s+//gr; |
|
97 |
<!DOCTYPE html> |
|
98 |
<html lang="en"> |
|
99 |
<head> |
|
100 |
<meta charset="UTF-8"> |
|
101 |
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
|
102 |
<title>TITLE</title> |
|
8 | 103 |
<link rel="stylesheet" href="CSS"> |
0 | 104 |
</head> |
8 | 105 |
<body> |
106 |
NAV |
|
107 |
<h1> BTIT </h1> |
|
0 | 108 |
SPLIT |
109 |
<ul id="cataogries"> |
|
110 |
SPLIT |
|
111 |
<li> <a href="LINK"> CATAG (NUMBER)</a> |
|
112 |
SPLIT |
|
113 |
</ul> |
|
114 |
<div> |
|
8 | 115 |
<h2> All articles <a id="rss" href="rss.xml">(rss)</span> </h2> <hr> |
0 | 116 |
SPLIT |
117 |
<a href="LINK"> |
|
8 | 118 |
<strong> TITLE </strong> <span>DATE</span> <i>CATAG</i> |
0 | 119 |
<hr> |
120 |
</a> |
|
121 |
SPLIT |
|
122 |
<a href="LINK"> |
|
123 |
<strong> TITLE </strong> <span>DATE</span> |
|
124 |
<hr> |
|
125 |
</a> |
|
126 |
SPLIT |
|
127 |
</div> |
|
128 |
</body> |
|
129 |
</html> |
|
130 |
END |
|
131 |
||
132 |
my $help = <<"END"; |
|
133 |
genorg [option] [dir|file] |
|
134 |
Option can be: |
|
135 |
-t FILE : Make a template org file at FILE |
|
136 |
-h : Help |
|
137 |
-c FILE : sepcify a new config file instead of genorg-conf |
|
138 |
-r : unconditionally remake org files |
|
139 |
||
140 |
If no option is set, accept a directory to generate. |
|
141 |
||
142 |
$config_file follow the syntax of: |
|
143 |
VAR VALUE |
|
144 |
where VAR can be: |
|
145 |
emacs-path : The value should be path of emacs. 'emacs' by default. |
|
14 | 146 |
acss : The path of the css file to use for articles. |
147 |
ccss : Path of css to use for cataogry pages. |
|
0 | 148 |
in_dir : The directory that contains the files. |
149 |
out_dir : the output directory. |
|
150 |
no_name_dir: The directory for generate files. This means in_dir/no_name_dir |
|
151 |
cannot exist. |
|
12
1be91608b33c
addded way more cusotmisation options and fixed up docu
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
11
diff
changeset
|
152 |
etc_files : Space sperated list of files to be navved up |
1be91608b33c
addded way more cusotmisation options and fixed up docu
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
11
diff
changeset
|
153 |
cache : xml cache file |
1be91608b33c
addded way more cusotmisation options and fixed up docu
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
11
diff
changeset
|
154 |
home : home file |
1be91608b33c
addded way more cusotmisation options and fixed up docu
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
11
diff
changeset
|
155 |
about : about file |
1be91608b33c
addded way more cusotmisation options and fixed up docu
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
11
diff
changeset
|
156 |
domain : domain (for rss) |
1be91608b33c
addded way more cusotmisation options and fixed up docu
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
11
diff
changeset
|
157 |
title : title of the blog |
14 | 158 |
max_rss : max_rss entries |
159 |
max_cat : max catagory entries before next page |
|
13 | 160 |
|
161 |
As soon as config file comes accross '>>---', the rest of the file |
|
162 |
is now the elisp code used in emacs startup. |
|
0 | 163 |
END |
164 |
||
165 |
||
166 |
my $rss_entry = <<"END" =~ s/\n\s+//gr; |
|
167 |
<?xml version=\"1.0\" encoding=\"UTF-8\" ?> |
|
168 |
<rss version=\"2.0\"> |
|
169 |
<channel> |
|
14 | 170 |
<title>TITLE</title> |
18
2db4b55800d3
fixxing up rss glitch
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
17
diff
changeset
|
171 |
<link>BLINK</link> |
0 | 172 |
END |
173 |
||
174 |
my %config_vars = |
|
175 |
( |
|
20
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
176 |
'emacs-path' => \$emacs, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
177 |
acss => \$art_css, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
178 |
ccss => \$cat_css, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
179 |
indir => \$dir, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
180 |
outdir => \$outdir, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
181 |
no_name_dir => \$no_name_dir, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
182 |
etc_files => \$etc_files, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
183 |
cache => \$cache_file, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
184 |
home => \$home, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
185 |
about => \$about, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
186 |
domain => \$domain, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
187 |
title => \$blog_title, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
188 |
rdesc => \$rdesc, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
189 |
max_rss => \$max_rss, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
190 |
max_cat => \$max_cat |
0 | 191 |
); |
192 |
||
6
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
193 |
|
0 | 194 |
sub read_config ($path) { |
195 |
open my $fh, '<', $path or die "Couldn't open config file\n"; |
|
196 |
while (<$fh>) { |
|
197 |
next if /^\s+$/; |
|
6
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
198 |
if (/^>>---+/) { |
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
199 |
local $/; |
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
200 |
$custom_code = <$fh>; |
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
201 |
return; |
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
202 |
} |
0 | 203 |
chomp; |
204 |
my ($directive, $rest) = split /\s+/, $_, 2; |
|
14 | 205 |
if (exists $config_vars{$directive}) { |
0 | 206 |
${$config_vars{$directive}} = $rest; |
207 |
} else { |
|
14 | 208 |
die "Unknown variable $directive\n"; |
0 | 209 |
} |
210 |
} |
|
211 |
close $fh; |
|
212 |
} |
|
213 |
||
214 |
sub help_and_bye { |
|
215 |
print $help; |
|
216 |
exit; |
|
217 |
} |
|
218 |
||
219 |
sub template ($file) { |
|
14 | 220 |
$file // do {print $template; exit(1)}; |
0 | 221 |
$file =~ s/\.org$//; |
222 |
open my $fh, '>', $file . ".org" or die $file . " couldn't be opened\n"; |
|
223 |
print $fh $template; |
|
224 |
close $fh; |
|
225 |
} |
|
226 |
||
227 |
# Reletive file from the perspect of file1, to file2 |
|
228 |
sub prel_path ($from, $to) { |
|
15 | 229 |
return $to =~ s!^/!!r if $from eq $to; |
0 | 230 |
my \(@f1, @f2) = map [m{/[^/]+}g], ($from, $to); |
231 |
# return substr($f1[$#f1], 1) if $from =~ $to; |
|
232 |
while (@f1 && @f2 && $f1[0] =~ $f2[0]) { |
|
233 |
shift @f1; |
|
234 |
shift @f2; |
|
235 |
} |
|
236 |
my $p = @f1-1; |
|
237 |
local $" = ""; |
|
238 |
"../" x ($p > 0 ? $p : 0) . substr("@f2", 1); |
|
239 |
} |
|
240 |
||
241 |
my @org_exps; |
|
242 |
my @files_to_make; |
|
7 | 243 |
my @files_to_move; |
9 | 244 |
my @navify_files; |
0 | 245 |
|
246 |
sub wanted { |
|
247 |
my $n_path = $outdir . prel_path ($dir, "$File::Find::name/"); |
|
248 |
# We need to mirror the direcotry structure |
|
249 |
if (-d) { |
|
250 |
push @files_to_make, $n_path || die "Couldn't make directory $n_path\n" |
|
251 |
unless -d $n_path; |
|
252 |
return; |
|
253 |
} |
|
254 |
if (/\.org$/) { |
|
255 |
push @org_exps, substr $n_path, length($outdir); |
|
256 |
} else { |
|
7 | 257 |
push @files_to_move, $File::Find::name |
0 | 258 |
} |
9 | 259 |
|
0 | 260 |
} |
261 |
||
3 | 262 |
my @modified_files; |
0 | 263 |
|
264 |
# Export @org_exps |
|
265 |
sub conv_files { |
|
266 |
my %changed_files; |
|
267 |
# Remove files that are already converted |
|
268 |
for my $rel_file (@org_exps) { |
|
269 |
# Emacs need the full file path |
|
270 |
my ($file, $to) = map { getcwd . "/$_" . $rel_file} ($dir, $outdir); |
|
271 |
s/org$/html/ for ($to, $rel_file); |
|
272 |
unless ($cache && -f $to && (stat($to))[9] > (stat($file))[9]) { |
|
273 |
$changed_files{$file} = $to; |
|
3 | 274 |
push @modified_files, $rel_file; |
0 | 275 |
} |
20
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
276 |
%changed_files // exit; |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
277 |
$elisp_code =~ s/LIST/join '', map "\"$_\" ", values %changed_files /e; |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
278 |
open my $fh, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
279 |
'-|', |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
280 |
($emacs, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
281 |
'-Q', |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
282 |
'--eval', |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
283 |
"(progn $custom_code)", |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
284 |
keys %changed_files, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
285 |
"--eval", |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
286 |
"$elisp_code"); |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
287 |
close $fh; |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
288 |
\%changed_files |
0 | 289 |
} |
290 |
||
291 |
my $cdir; |
|
292 |
||
293 |
$ARGV[0] // die "No arguments provided\n"; |
|
294 |
while ($_ = shift @ARGV) { |
|
6
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
295 |
/^-c$/ && do { print "$req_config\n"; exit }; |
0 | 296 |
/^(-h|--?help)$/ && help_and_bye; |
297 |
/^-t$/ && do { template shift @ARGV ; exit }; |
|
298 |
/^-c$/ && do { $config_file = shift @ARGV; next }; |
|
299 |
/^-d$/ && do { $cache = 0; next }; |
|
300 |
$cdir = $_; |
|
301 |
} |
|
302 |
$cdir || die "directory not provided\n"; |
|
303 |
main(); |
|
304 |
||
305 |
my %catags; |
|
306 |
my @arts; |
|
3 | 307 |
my $cache_dom; |
0 | 308 |
|
309 |
sub main { |
|
14 | 310 |
-d $cdir or help_and_bye; |
311 |
chdir $cdir or die "Couldn't access $cdir\n"; |
|
312 |
read_config $config_file; |
|
17 | 313 |
mkdir $outdir; |
14 | 314 |
s!/*$!/! for ($outdir, $dir); |
315 |
my @navify_files = map {"$dir$_"} ($about, $home, $etc_files ? split(/[ \t]+/, $etc_files) : ()); |
|
316 |
-d $dir or die "$dir doesn't exist \n"; |
|
317 |
find (\&wanted, $dir); |
|
318 |
for my $f (@files_to_move) { |
|
319 |
my $dest = $f =~ s#$dir/?#$outdir#er; |
|
320 |
if (grep(m#^$f$#, @navify_files)) { |
|
321 |
# YAY we have to sub navbar and copy whoop whoop |
|
322 |
open my $file_tc, '<', $f or die "file no open, grrr!"; |
|
323 |
open my $file_out, '>', $dest; |
|
324 |
local $/; |
|
325 |
print $file_out ((<$file_tc>) =~ s/NAV/nav_up("$dest" =~ s%.+?\/%%r,1)/er); |
|
326 |
map \&close, ($file_tc, $file_out); |
|
327 |
} else { |
|
328 |
copy $f, $dest; |
|
8 | 329 |
} |
14 | 330 |
} |
331 |
mkdir for @files_to_make; |
|
332 |
values %{conv_files()}; |
|
333 |
$cache_dom = XML::LibXML->load_xml(location => $cache_file) if $cache && -f $cache_file; |
|
334 |
chdir $outdir; |
|
335 |
@arts = sort { $b->{date} <=> $a->{date}} map { html_fixup($_) } @org_exps; |
|
336 |
finalise_html(); |
|
337 |
chdir '..'; |
|
338 |
populate_cache(); |
|
3 | 339 |
} |
340 |
||
341 |
sub populate_cache { |
|
342 |
my $dom = XML::LibXML::Document->new('1.0', 'UTF-8'); |
|
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
343 |
my $root = $dom->createElement('root'); |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
344 |
my %c_els; |
3 | 345 |
for my $art (@arts) { |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
346 |
# We need the: related, file, date |
8 | 347 |
my ($art_el, $date, $title, $ca, $related, $utitle) = |
348 |
map {$dom->createElement($_)} ("art", "date", "title", "catag", "related", "utitle"); |
|
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
349 |
$art_el->{path} = $art->{file}; |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
350 |
$ca->appendText($art->{catag}); |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
351 |
$title->appendText($art->{title}); |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
352 |
$date->appendText($art->{date}->text_easy); |
8 | 353 |
$utitle->appendText($art->{utitle}); |
7 | 354 |
my @ll = @{$art->{links}}; |
355 |
if (@ll) { |
|
356 |
my $links = $dom->createElement('links'); |
|
357 |
for (@ll) { |
|
358 |
my $link = $dom->createElement("link"); |
|
359 |
$link->{catag} = $_->[0]; |
|
360 |
$link->appendText($_->[1]); |
|
361 |
$links->appendChild($link); |
|
362 |
} |
|
363 |
$art_el->appendChild($links); |
|
364 |
} |
|
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
365 |
my $rel_str; |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
366 |
for my $thing ($art->{related}) { |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
367 |
for (@{$thing}) { |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
368 |
my ($catag, $artt) = @{$_}; |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
369 |
my $rel_str .= "\"$catag\"" . ($artt && "->\"$artt\""); |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
370 |
$related->appendText("\"$catag\"" . ($artt && "->\"$artt\" ")); |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
371 |
} |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
372 |
} |
8 | 373 |
$art_el->appendChild($_) for ($date, $ca, $related, $title, $utitle); |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
374 |
$root->appendChild($art_el); |
3 | 375 |
} |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
376 |
$root->appendChild($_) for values %c_els; |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
377 |
$dom->setDocumentElement($root); |
5 | 378 |
open my $fh, '>' , $cache_file; |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
379 |
print $fh ($dom->toString(1) =~ s/(.+)/$1\n<!-- Nicley formated :() -->/r); |
3 | 380 |
close $fh; |
0 | 381 |
} |
382 |
||
383 |
sub entry { |
|
384 |
my ($data, $catagory) = @_; |
|
385 |
my $str = defined $catagory |
|
386 |
? ($h_en_cat =~ s/CATAG/$data->{catag}/er) : $h_en; |
|
387 |
my $prel_path = "/$no_name_dir/" . (defined $catagory ? "c" : "c/b"); |
|
388 |
$str =~ s/DATE/$data->{date}->fmt/er |
|
8 | 389 |
=~ s/TITLE/$data->{utitle}/er |
0 | 390 |
=~ s|LINK|prel_path($prel_path, '/'. $data->{file})|er |
391 |
} |
|
392 |
||
393 |
sub rss_en ($data) { |
|
394 |
my $thing = <<"END" =~ s/\n\s+//gr; |
|
5 | 395 |
<item> |
0 | 396 |
<title>TITLE</title> |
397 |
<link>LINK</link> |
|
398 |
</item> |
|
399 |
END |
|
8 | 400 |
$thing |
401 |
=~ s|LINK|"$domain/" . $data->{file}|er |
|
402 |
=~ s/TITLE/$data->{utitle}/er; |
|
0 | 403 |
} |
404 |
||
405 |
sub min ($x, $y) { |
|
406 |
($x, $y)[$x > $y] |
|
407 |
} |
|
408 |
||
2
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
409 |
# @_ has to be in format of [STRING, LINK] |
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
410 |
sub list2paginaiton { |
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
411 |
my $page = shift; |
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
412 |
'<ul>' . join ("", map { |
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
413 |
my ($str, $file) = @{$_}; |
8 | 414 |
$str = "<span class=\"psel\">$str</span>" if $file && ($file == $page); |
2
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
415 |
defined $file ? |
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
416 |
"<li><a href=\"$file.html\">$str</a>" : $str |
20
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
417 |
} ((["←", $page - 1]) x!! ($page - 1), |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
418 |
@_, |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
419 |
(["→", $page + 1]) x ($page != $_[$#_]->[1]))) . '</ul>' |
ce527668bd78
indentation imprevoment
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
19
diff
changeset
|
420 |
} |
2
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
421 |
|
9 | 422 |
sub move_on_if_neccasary ($fh, $art_num, $total_articles, $path, $title, $rp) { |
2
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
423 |
return $fh if $art_num == 0 || $art_num % $max_cat; |
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
424 |
my $cpage = $art_num / $max_cat; |
5 | 425 |
print $fh panigation($cpage, ceil($total_articles / $max_cat), $path); |
2
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
426 |
open $fh, '>', $path . '/' . ($cpage + 1).'.html'; |
9 | 427 |
# ($h_intro . $h_c_intro, $blog_title, "a/c"); |
428 |
print $fh cssbs($h_intro, $title, $rp); |
|
2
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
429 |
$fh; |
0 | 430 |
} |
431 |
||
3 | 432 |
sub panigation ($page, $no_pages, $dir) { |
433 |
if ($no_pages < 9) { |
|
434 |
list2paginaiton ($page, (map [$_, $_], (1..$no_pages))) |
|
435 |
} elsif (4 < $page <= ($no_pages - 4)) { |
|
436 |
list2paginaiton |
|
437 |
($page, |
|
438 |
[1, 1], |
|
439 |
["<li>..."], |
|
440 |
(map [$_, $_], (($page-2)..($page+2))), |
|
441 |
["<li>..."], |
|
442 |
[($no_pages) x 2]) |
|
443 |
} elsif ($page < 6) { |
|
444 |
list2paginaiton $page, |
|
445 |
((map [$_, $_], (1..5)), |
|
446 |
["<li>..."], |
|
447 |
[($no_pages) x 2]) |
|
448 |
} else { |
|
449 |
list2paginaiton $page, |
|
450 |
([1,1], |
|
451 |
["<li>..."], |
|
452 |
(map [$_, $_], (($no_pages - 5)..$no_pages))) |
|
453 |
} |
|
454 |
} |
|
455 |
||
7 | 456 |
sub get_art($cat, $id) { |
457 |
for (@arts) { |
|
458 |
return $_ if $_->{catag} eq $cat && $_->{title} eq $id |
|
459 |
} |
|
5 | 460 |
} |
461 |
||
9 | 462 |
sub nav_up { |
463 |
my ($path) = @_; |
|
464 |
my @links = ($home, 'c/1.html', $about); |
|
14 | 465 |
my $nav = shift ? "<div class=\"$nav_id\">$navbar</div>" : $navbar; |
9 | 466 |
$nav =~ s#LINK#prel_path("/$path", "/". shift @links)#ger; |
467 |
} |
|
468 |
||
8 | 469 |
sub cssbs($s,$t,$p){ |
470 |
$s =~ s|CSS|prel_path("/$p","/$cat_css")|er |
|
471 |
=~ s/TITLE|BTIT/$t/ger |
|
14 | 472 |
=~ s/NAV/nav_up($p,1)/er; |
9 | 473 |
} |
474 |
||
475 |
sub modify_art ($file, $dom) { |
|
476 |
# I guess we can rely on navbar not changed, if it did then user |
|
477 |
# would need to call with -d option |
|
478 |
return $dom unless grep /^$file$/, @modified_files; |
|
479 |
# We add css, navbar |
|
480 |
for ($dom->findnodes('/html/body')) { |
|
481 |
# my @cds = $_->childNodes; |
|
482 |
my $nav_el = $dom->createElement('div'); |
|
14 | 483 |
$nav_el->{class} = $nav_id; |
9 | 484 |
$nav_el->appendWellBalancedChunk(nav_up($file)); |
485 |
$_->insertBefore($nav_el, $_->childNodes->[0]) |
|
486 |
} |
|
487 |
for ($dom->findnodes('/html/head')) { |
|
488 |
my $link = $dom->createElement('link'); |
|
489 |
$link->{rel} = "stylesheet"; |
|
490 |
$link->{href} = prel_path("/$file", "/$art_css"); |
|
491 |
$_->appendChild($link); |
|
492 |
} |
|
493 |
$dom; |
|
8 | 494 |
} |
495 |
||
14 | 496 |
sub rss_st { |
497 |
$rss_entry |
|
498 |
=~ s/TITLE/$blog_title/er |
|
499 |
=~ s/BLINK/$domain/er |
|
500 |
=~ s/RDESC/$rdesc/er; |
|
501 |
} |
|
502 |
||
0 | 503 |
sub finalise_html { |
504 |
mkdir $no_name_dir; |
|
505 |
open my $fh, '>', "$no_name_dir/1.html"; |
|
506 |
open my $mrss, '>', "$no_name_dir/rss.xml"; # The master rss file |
|
14 | 507 |
print $mrss rss_st(); |
8 | 508 |
print $fh cssbs($h_intro . $h_c_intro, $blog_title, "a/c"); |
0 | 509 |
my (%c_files, %r_files); # Cataogry files and rss |
8 | 510 |
|
511 |
for my $cat (sort { $catags{$b} <=> $catags{$a} } keys(%catags)) { |
|
512 |
my $num = $catags{$cat}; |
|
0 | 513 |
# ($h_intro, $h_c_intro, $h_cat_li, $h_chap, $h_en_cat, $h_en, $h_end) |
21 | 514 |
print $fh $h_cat_li |
515 |
=~ s/NUMBER/$num/re |
|
3 | 516 |
=~ s/CATAG/$cat/er |
517 |
=~ s=LINK="$cat/1.html"=er; |
|
0 | 518 |
mkdir "$no_name_dir/$cat"; |
519 |
open $c_files{$cat}, '>', "$no_name_dir/$cat/1.html"; |
|
520 |
open $r_files{$cat}, '>', "$no_name_dir/$cat/rss.xml"; |
|
14 | 521 |
print {$r_files{$cat}} rss_st(); |
8 | 522 |
print {$c_files{$cat}} |
523 |
cssbs($h_intro, "$cat <a id=\"rss\" href=\"rss.xml\">(rss)</span> ", "a/b/c"); |
|
0 | 524 |
} |
525 |
print $fh $h_chap; |
|
526 |
# :-) |
|
527 |
my $total_articles = () = map {(1)x$_} values %catags; |
|
528 |
# Now we iterate through the articles and add their index |
|
529 |
my ($n_fh, $n_mrss, %n_rss) = (0,0); |
|
530 |
my %n_cat; |
|
531 |
for my $art (@arts) { |
|
8 | 532 |
# TODO do we need $title? |
0 | 533 |
my ($catag, $title) = @{$art}{qw(catag title)}; |
534 |
my $rentry = rss_en $art; |
|
535 |
if (($n_rss{$catag} // 0) < $max_rss) { |
|
536 |
print {$r_files{$catag}} $rentry; |
|
537 |
++$n_rss{$catag}; |
|
538 |
} |
|
539 |
if ($n_mrss < $max_rss) { |
|
540 |
print $mrss $rentry; |
|
541 |
++$n_mrss |
|
542 |
} |
|
2
c4ca65113229
Pagination major progress
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
1
diff
changeset
|
543 |
# ($fh, $art_num, $total_articles, $path) |
9 | 544 |
$fh = move_on_if_neccasary |
545 |
$fh, $n_fh, $total_articles, $no_name_dir, "All articles", "a/c"; |
|
0 | 546 |
$n_fh++; |
547 |
print $fh entry $art, 1; |
|
3 | 548 |
my $ncat = \$n_cat{$catag}; |
549 |
++$$ncat; |
|
550 |
my $cfh = \$c_files{$catag}; |
|
9 | 551 |
$$cfh = move_on_if_neccasary |
552 |
$$cfh, $$ncat, $catags{$catag}, "$no_name_dir/$catag", $catag, "a/c/b"; |
|
3 | 553 |
print {$$cfh} entry $art; |
554 |
my $a_file = $art->{file}; |
|
7 | 555 |
if (1 or grep /^$a_file$/, @modified_files) { |
9 | 556 |
my $doom = modify_art($a_file, linkify($art)); |
3 | 557 |
open my $h_file, '>', $a_file; |
7 | 558 |
print $h_file $doom->toStringHTML; |
3 | 559 |
close $h_file; |
560 |
} |
|
0 | 561 |
} |
5 | 562 |
print $fh panigation ((ceil $n_fh / $max_cat) x 2, $no_name_dir) if $max_cat < $total_articles; |
0 | 563 |
print $fh $h_end; |
564 |
close $fh; |
|
565 |
for (values %c_files) { |
|
566 |
print $_ $h_end; |
|
7 | 567 |
close $_; |
0 | 568 |
} |
569 |
print $mrss '</channel> </rss>'; |
|
570 |
for (values %r_files) { |
|
571 |
print $_ '</channel> </rss>';; |
|
7 | 572 |
close $_; |
0 | 573 |
} |
574 |
} |
|
575 |
||
7 | 576 |
sub linkify ($art) { |
577 |
# if $art->{dom} is undefined, we must sadly parse again |
|
578 |
my @links; |
|
579 |
my @olinks = @{$art->{links} //[]}; |
|
580 |
my $bom = $art->{dom} // XML::LibXML->load_html(location => $art->{file}); |
|
581 |
for ($bom->findnodes('//a[@class="rakim"]')) { |
|
582 |
my $key; |
|
583 |
my $link_text; |
|
584 |
if (@olinks) { |
|
585 |
$key = pop @olinks; |
|
586 |
} else { |
|
587 |
($key) = parse_keywords($_->to_literal); |
|
588 |
$link_text = $_->{href}; |
|
589 |
$_->removeChild($_->firstChild()); |
|
590 |
$_->appendText($link_text); |
|
591 |
} |
|
592 |
push @links, $key; |
|
593 |
my $l = get_art(@{$key})->{file} or die "Link not found in $art->{filename}\n"; |
|
594 |
$_->{href} = prel_path("/".$art->{file}, "/$l"); |
|
595 |
} |
|
596 |
$art->{links} = \@links; |
|
597 |
return $bom |
|
598 |
} |
|
599 |
||
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
600 |
# I don't want to prepopulate, as it is not known which ones are |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
601 |
# usless and outdated, and it would be a waste of cycles parsing |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
602 |
# something to know it is not needed |
5 | 603 |
sub getcache ($fn) { |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
604 |
$cache_dom || return 0; |
5 | 605 |
for my $d ($cache_dom->findnodes("/root/art[\@path=\"$fn\"]")) { |
606 |
# TODO related |
|
607 |
my %dome = ('file' => $fn); |
|
8 | 608 |
(@dome{'title', 'catag', 'utitle'}, my $date) = |
5 | 609 |
map |
610 |
{ $d->getChildrenByTagName($_)->[0]->to_literal } |
|
8 | 611 |
qw[title catag utitle date]; |
7 | 612 |
for ($d->getChildrenByTagName("links")) { |
613 |
my @ll = map [$_->{catag}, $_->to_literal], |
|
614 |
($_->getChildrenByTagName('link')); |
|
615 |
$dome{links} = \@ll; |
|
616 |
} |
|
5 | 617 |
$catags{$dome{catag}}++; |
618 |
$dome{date} = PDate->new(split /-/, $date); |
|
619 |
return \%dome; |
|
620 |
} |
|
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
621 |
return 0; |
3 | 622 |
} |
623 |
||
0 | 624 |
sub html_fixup ($filename) { |
8 | 625 |
if ($cache && !grep /^$filename$/, @modified_files) { |
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
626 |
for (getcache($filename)) { |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
627 |
return $_ if $_ |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
628 |
} |
3 | 629 |
} |
0 | 630 |
my $dom = |
8 | 631 |
XML::LibXML->load_html(location => $filename); |
0 | 632 |
my %data = ('file', $filename); |
633 |
||
634 |
# We don't need style or table of contents heading (if exists) |
|
635 |
for my $xpath ('/html/head/style', '/html/body/div/div[@id="table-of-contents"]/h2') { |
|
636 |
$_->parentNode->removeChild($_) for $dom->findnodes($xpath) |
|
637 |
} |
|
638 |
||
639 |
# Info we need |
|
640 |
||
641 |
# Date |
|
642 |
for ($dom->findnodes('/html/body/div[@id="postamble"]/p[@class="date"]')) { |
|
643 |
my $text = $_->to_literal; |
|
644 |
if ($text =~ /^Date: (\d+)-(\d+)-(\d+)/) { |
|
645 |
my $date = PDate->new($1, $2, $3); |
|
646 |
$data{date} = $date; |
|
647 |
my $p = $_->parentNode; |
|
648 |
$p->parentNode->removeChild($p); |
|
649 |
} |
|
650 |
} |
|
8 | 651 |
# Title |
0 | 652 |
for ($dom->findnodes('/html/head/title')) { |
8 | 653 |
$data{utitle} = $_->to_literal; |
0 | 654 |
} |
655 |
# keywords/catogry |
|
656 |
for my $node ($dom->findnodes('/html/head/meta')) { |
|
657 |
(my $cont = $node->getAttribute('content')) || next; |
|
658 |
for ($node->getAttribute('name')) { |
|
5 | 659 |
if (/keywords/) { |
0 | 660 |
my ($key, $rest) = parse_keywords($cont); |
661 |
@data{qw[catag title]} = @{$key}; |
|
662 |
$catags{$data{catag}}++; |
|
663 |
$rest =~ s/\s+\|\s+//; |
|
664 |
while ($rest) { |
|
665 |
(my $t,$rest) = parse_keywords($rest); |
|
666 |
push @{$data{related}}, $t; |
|
667 |
} |
|
668 |
} else { |
|
669 |
next; |
|
670 |
} |
|
671 |
$node->parentNode->removeChild($node); |
|
672 |
} |
|
673 |
} |
|
3 | 674 |
$data{dom} = $dom; |
0 | 675 |
\%data; |
676 |
} |
|
677 |
||
678 |
sub parse_keywords ($str) { |
|
679 |
if ($str =~ s/\s*(?:"(.+?)"|(\w+))\s*->(?:\s*(?:"(.+?)"|(\w+)))//) { |
|
680 |
([$1 // $2, $3 // $4], $str); |
|
681 |
} else { |
|
682 |
die "Keywords not arranged properly\n" |
|
683 |
} |
|
684 |
} |
|
685 |
||
686 |
# I wonder if sean combs has made a similar class |
|
687 |
{ |
|
688 |
package PDate; |
|
689 |
||
690 |
sub new { |
|
691 |
my $class = shift; |
|
692 |
my $self = { year => 0 + shift, |
|
693 |
month => 0 + shift, |
|
694 |
day => 0 + shift, |
|
695 |
}; |
|
696 |
bless $self, $class; |
|
697 |
return $self; |
|
698 |
} |
|
699 |
||
700 |
# $d1 is greater than $d2 |
|
21 | 701 |
sub cmp { |
0 | 702 |
my ($d1, $d2) = @_; |
703 |
for ($d1->{year} <=> $d2->{year}, |
|
704 |
$d1->{month} <=> $d2->{month}, |
|
705 |
$d1->{day} <=> $d2->{day}) { |
|
706 |
return $_ unless $_ == 0 |
|
707 |
} |
|
708 |
0 |
|
709 |
} |
|
710 |
use overload '<=>' => \&cmp; |
|
711 |
||
712 |
sub fmt { |
|
713 |
my $self = shift; |
|
714 |
my @months = |
|
715 |
qw(January Febuary March April May June July August September November October December); |
|
716 |
my $n = $self->{day}; |
|
717 |
if ($n == 1) { $n = '1st' } |
|
718 |
elsif (($n - 2) % 10 == 0) { $n = "${n}nd" } |
|
719 |
elsif (($n - 3) % 10 == 0) { $n = "${n}rd" } |
|
5 | 720 |
else { $n = "${n}th" } |
0 | 721 |
$months[$self->{month} - 1] . " $n, " . $self->{year} |
722 |
} |
|
723 |
||
724 |
sub short_fmt { |
|
725 |
my $self = shift; |
|
726 |
join "-", ($self->{year}, $self->{month}, $self->{day}); |
|
727 |
} |
|
4
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
728 |
sub text_easy { |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
729 |
my $self = shift; |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
730 |
join "-", ($self->{year}, $self->{month}, $self->{day}); |
c98c7c32ab46
Cache output, found the best soltuion
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
3
diff
changeset
|
731 |
} |
0 | 732 |
} |
733 |
||
6
c576e88fef13
It's starting to feel messy now
Pranshu Sharma <pranshu@bauherren.ovh>
parents:
5
diff
changeset
|
734 |