|
@@ -1,5 +1,8 @@
|
1
|
1
|
# -*- coding: utf-8 -*-
|
2
|
2
|
|
|
3
|
+from __future__ import print_function
|
|
4
|
+
|
|
5
|
+import sys
|
3
|
6
|
import re
|
4
|
7
|
import itertools
|
5
|
8
|
import email.utils
|
|
@@ -7,11 +10,27 @@ import os.path
|
7
|
10
|
import time
|
8
|
11
|
import codecs
|
9
|
12
|
from datetime import datetime
|
10
|
|
-import urlparse
|
11
|
13
|
|
12
|
14
|
DEFAULT_LANG = "en"
|
13
|
15
|
BASE_URL = "https://www.xythobuz.de"
|
14
|
16
|
|
|
17
|
+# =============================================================================
|
|
18
|
+# Python 2/3 hacks
|
|
19
|
+# =============================================================================
|
|
20
|
+
|
|
21
|
+PY3 = sys.version_info[0] == 3
|
|
22
|
+
|
|
23
|
+if PY3:
|
|
24
|
+ import urllib
|
|
25
|
+ import urllib.request
|
|
26
|
+ def urlparse_foo(link):
|
|
27
|
+ return urllib.parse.parse_qs(urllib.parse.urlparse(link).query)['v'][0]
|
|
28
|
+else:
|
|
29
|
+ import urllib
|
|
30
|
+ import urlparse
|
|
31
|
+ def urlparse_foo(link):
|
|
32
|
+ return urlparse.parse_qs(urlparse.urlparse(link).query)['v'][0]
|
|
33
|
+
|
15
|
34
|
# -----------------------------------------------------------------------------
|
16
|
35
|
# sub page helper macro
|
17
|
36
|
# -----------------------------------------------------------------------------
|
|
@@ -30,24 +49,24 @@ def backToParent():
|
30
|
49
|
# print if any parent link found
|
31
|
50
|
if len(posts) > 0:
|
32
|
51
|
p = posts[0]
|
33
|
|
- print '<span class="listdesc">[...back to ' + p.title + ' overview](' + p.url + ')</span>'
|
|
52
|
+ print('<span class="listdesc">[...back to ' + p.title + ' overview](' + p.url + ')</span>')
|
34
|
53
|
|
35
|
54
|
# -----------------------------------------------------------------------------
|
36
|
55
|
# table helper macro
|
37
|
56
|
# -----------------------------------------------------------------------------
|
38
|
57
|
|
39
|
58
|
def tableHelper(style, header, content):
|
40
|
|
- print "<table>"
|
|
59
|
+ print("<table>")
|
41
|
60
|
if (header != None) and (len(header) == len(style)):
|
42
|
|
- print "<tr>"
|
|
61
|
+ print("<tr>")
|
43
|
62
|
for h in header:
|
44
|
|
- print "<th>" + h + "</th>"
|
45
|
|
- print "</tr>"
|
|
63
|
+ print("<th>" + h + "</th>")
|
|
64
|
+ print("</tr>")
|
46
|
65
|
for ci in range(0, len(content)):
|
47
|
66
|
if len(content[ci]) != len(style):
|
48
|
67
|
# invalid call of table helper!
|
49
|
68
|
continue
|
50
|
|
- print "<tr>"
|
|
69
|
+ print("<tr>")
|
51
|
70
|
for i in range(0, len(style)):
|
52
|
71
|
s = style[i]
|
53
|
72
|
td_style = ""
|
|
@@ -70,17 +89,17 @@ def tableHelper(style, header, content):
|
70
|
89
|
if td_style != "":
|
71
|
90
|
td_args = " style=\"" + td_style + "\""
|
72
|
91
|
|
73
|
|
- print "<td" + td_args + ">"
|
|
92
|
+ print("<td" + td_args + ">")
|
74
|
93
|
|
75
|
94
|
if isinstance(content[ci][i], tuple):
|
76
|
95
|
text, link = content[ci][i]
|
77
|
|
- print "<a href=\"" + link + "\">" + text + "</a>"
|
|
96
|
+ print("<a href=\"" + link + "\">" + text + "</a>")
|
78
|
97
|
else:
|
79
|
98
|
text = content[ci][i]
|
80
|
|
- print text
|
81
|
|
- print "</td>"
|
82
|
|
- print "</tr>"
|
83
|
|
- print "</table>"
|
|
99
|
+ print(text)
|
|
100
|
+ print("</td>")
|
|
101
|
+ print("</tr>")
|
|
102
|
+ print("</table>")
|
84
|
103
|
|
85
|
104
|
# -----------------------------------------------------------------------------
|
86
|
105
|
# menu helper macro
|
|
@@ -112,7 +131,7 @@ def printMenuItem(p, yearsAsHeading = False, showDateSpan = False, showOnlyStart
|
112
|
131
|
if year != lastyear:
|
113
|
132
|
lastyear = year
|
114
|
133
|
if yearsAsHeading:
|
115
|
|
- print "\n\n#### %s\n" % (year)
|
|
134
|
+ print("\n\n#### %s\n" % (year))
|
116
|
135
|
|
117
|
136
|
dateto = ""
|
118
|
137
|
if p.get("date", "" != ""):
|
|
@@ -127,19 +146,19 @@ def printMenuItem(p, yearsAsHeading = False, showDateSpan = False, showOnlyStart
|
127
|
146
|
if nicelyFormatFullDate:
|
128
|
147
|
dateto = " - " + datetime.strptime(p.get("update", p.date), "%Y-%m-%d").strftime("%B %d, %Y")
|
129
|
148
|
|
130
|
|
- print " * **[%s](%s)**%s" % (title, p.url, dateto)
|
|
149
|
+ print(" * **[%s](%s)**%s" % (title, p.url, dateto))
|
131
|
150
|
|
132
|
151
|
if p.get("description", "") != "":
|
133
|
152
|
description = p.get("description", "")
|
134
|
153
|
if lang != "":
|
135
|
154
|
if p.get("description_" + lang, "") != "":
|
136
|
155
|
description = p.get("description_" + lang, "")
|
137
|
|
- print "<br><span class=\"listdesc\">" + description + "</span>"
|
|
156
|
+ print("<br><span class=\"listdesc\">" + description + "</span>")
|
138
|
157
|
|
139
|
158
|
if showLastCommit:
|
140
|
159
|
link = githubCommitBadge(p)
|
141
|
160
|
if len(link) > 0:
|
142
|
|
- print "<br>" + link
|
|
161
|
+ print("<br>" + link)
|
143
|
162
|
|
144
|
163
|
return lastyear
|
145
|
164
|
|
|
@@ -318,14 +337,14 @@ def lightgallery(links):
|
318
|
337
|
for v in videos:
|
319
|
338
|
link, mime, thumb, poster, alt = v
|
320
|
339
|
v_i += 1
|
321
|
|
- print '<div style="display:none;" id="video' + str(v_i) + '_' + str(v_ii) + '">'
|
322
|
|
- print '<video class="lg-video-object lg-html5" controls preload="none">'
|
323
|
|
- print '<source src="' + link + '" type="' + mime + '">'
|
324
|
|
- print '<a href="' + link + '">' + alt + '</a>'
|
325
|
|
- print '</video>'
|
326
|
|
- print '</div>'
|
|
340
|
+ print('<div style="display:none;" id="video' + str(v_i) + '_' + str(v_ii) + '">')
|
|
341
|
+ print('<video class="lg-video-object lg-html5" controls preload="none">')
|
|
342
|
+ print('<source src="' + link + '" type="' + mime + '">')
|
|
343
|
+ print('<a href="' + link + '">' + alt + '</a>')
|
|
344
|
+ print('</video>')
|
|
345
|
+ print('</div>')
|
327
|
346
|
|
328
|
|
- print '<div class="lightgallery">'
|
|
347
|
+ print('<div class="lightgallery">')
|
329
|
348
|
v_i = -1
|
330
|
349
|
for l in links:
|
331
|
350
|
if (len(l) == 3) or (len(l) == 2):
|
|
@@ -337,7 +356,7 @@ def lightgallery(links):
|
337
|
356
|
link, alt = l
|
338
|
357
|
if "youtube.com" in link:
|
339
|
358
|
img = "https://img.youtube.com/vi/"
|
340
|
|
- img += urlparse.parse_qs(urlparse.urlparse(link).query)['v'][0]
|
|
359
|
+ img += urlparse_foo(link)
|
341
|
360
|
img += "/0.jpg" # full size preview
|
342
|
361
|
#img += "/default.jpg" # default thumbnail
|
343
|
362
|
style = ' style="width:300px;"'
|
|
@@ -346,7 +365,7 @@ def lightgallery(links):
|
346
|
365
|
x = link.rfind('.')
|
347
|
366
|
img = link[:x] + '_small' + link[x:]
|
348
|
367
|
lightgallery_check_thumbnail(link, img)
|
349
|
|
- print '<div class="border" style="position:relative;" data-src="' + link + '"><a href="' + link + '"><img class="pic" src="' + img + '" alt="' + alt + '"' + style + '>' + img2 + '</a></div>'
|
|
368
|
+ print('<div class="border" style="position:relative;" data-src="' + link + '"><a href="' + link + '"><img class="pic" src="' + img + '" alt="' + alt + '"' + style + '>' + img2 + '</a></div>')
|
350
|
369
|
elif len(l) == 5:
|
351
|
370
|
v_i += 1
|
352
|
371
|
link, mime, thumb, poster, alt = videos[v_i]
|
|
@@ -357,19 +376,19 @@ def lightgallery(links):
|
357
|
376
|
x = link.rfind('.')
|
358
|
377
|
poster = link[:x] + '_poster.png'
|
359
|
378
|
lightgallery_check_thumbnail_video(link, thumb, poster)
|
360
|
|
- print '<div class="border" data-poster="' + poster + '" data-sub-html="' + alt + '" data-html="#video' + str(v_i) + '_' + str(v_ii) + '"><a href="' + link + '"><img class="pic" src="' + thumb + '"></a></div>'
|
|
379
|
+ print('<div class="border" data-poster="' + poster + '" data-sub-html="' + alt + '" data-html="#video' + str(v_i) + '_' + str(v_ii) + '"><a href="' + link + '"><img class="pic" src="' + thumb + '"></a></div>')
|
361
|
380
|
else:
|
362
|
381
|
raise NameError('Invalid number of arguments for lightgallery')
|
363
|
|
- print '</div>'
|
|
382
|
+ print('</div>')
|
364
|
383
|
|
365
|
384
|
# -----------------------------------------------------------------------------
|
366
|
385
|
# github helper macros
|
367
|
386
|
# -----------------------------------------------------------------------------
|
368
|
387
|
|
369
|
|
-import urllib, json, sys
|
|
388
|
+import json, sys
|
370
|
389
|
|
371
|
390
|
def restRequest(url):
|
372
|
|
- response = urllib.urlopen(url)
|
|
391
|
+ response = urllib.request.urlopen(url) if PY3 else urllib.urlopen(url)
|
373
|
392
|
if response.getcode() != 200:
|
374
|
393
|
sys.stderr.write("\n")
|
375
|
394
|
sys.stderr.write("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n")
|
|
@@ -382,7 +401,7 @@ def restRequest(url):
|
382
|
401
|
sys.stderr.write("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n")
|
383
|
402
|
sys.stderr.write("\n")
|
384
|
403
|
return ""
|
385
|
|
- data = json.loads(response.read())
|
|
404
|
+ data = json.loads(response.read().decode("utf-8"))
|
386
|
405
|
return data
|
387
|
406
|
|
388
|
407
|
def restReleases(user, repo):
|
|
@@ -430,11 +449,11 @@ def printLatestRelease(user, repo):
|
430
|
449
|
print("</ul></div>")
|
431
|
450
|
|
432
|
451
|
def include_url(url):
|
433
|
|
- response = urllib.urlopen(url)
|
|
452
|
+ response = urllib.request.urlopen(url) if PY3 else urllib.urlopen(url)
|
434
|
453
|
if response.getcode() != 200:
|
435
|
454
|
raise Exception("invalid response code", response.getcode())
|
436
|
|
- data = response.read()
|
437
|
|
- print data,
|
|
455
|
+ data = response.read().decode("utf-8")
|
|
456
|
+ print(data, end="")
|
438
|
457
|
|
439
|
458
|
# -----------------------------------------------------------------------------
|
440
|
459
|
# preconvert hooks
|
|
@@ -457,7 +476,7 @@ def hook_preconvert_anotherlang():
|
457
|
476
|
[lang.strip() for lang in text_lang[1::2]], \
|
458
|
477
|
text_lang[::2]))
|
459
|
478
|
|
460
|
|
- for lang, text in text_grouped.iteritems():
|
|
479
|
+ for lang, text in (iter(text_grouped.items()) if PY3 else text_grouped.iteritems()):
|
461
|
480
|
spath = p.fname.split(os.path.sep)
|
462
|
481
|
langs.append(lang)
|
463
|
482
|
|
|
@@ -469,19 +488,19 @@ def hook_preconvert_anotherlang():
|
469
|
488
|
vp = Page(filename, virtual=text)
|
470
|
489
|
# Copy real page attributes to the virtual page
|
471
|
490
|
for attr in p:
|
472
|
|
- if not vp.has_key(attr):
|
|
491
|
+ if not ((attr in vp) if PY3 else vp.has_key(attr)):
|
473
|
492
|
vp[attr] = p[attr]
|
474
|
493
|
# Define a title in the proper language
|
475
|
494
|
vp["title"] = p["title_%s" % lang] \
|
476
|
|
- if p.has_key("title_%s" % lang) \
|
|
495
|
+ if ((("title_%s" % lang) in p) if PY3 else p.has_key("title_%s" % lang)) \
|
477
|
496
|
else p["title"]
|
478
|
497
|
# Keep track of the current lang of the virtual page
|
479
|
498
|
vp["lang"] = lang
|
480
|
499
|
page_vpages[lang] = vp
|
481
|
500
|
|
482
|
501
|
# Each virtual page has to know about its sister vpages
|
483
|
|
- for lang, vpage in page_vpages.iteritems():
|
484
|
|
- vpage["lang_links"] = dict([(l, v["url"]) for l, v in page_vpages.iteritems()])
|
|
502
|
+ for lang, vpage in (iter(page_vpages.items()) if PY3 else page_vpages.iteritems()):
|
|
503
|
+ vpage["lang_links"] = dict([(l, v["url"]) for l, v in (iter(page_vpages.items()) if PY3 else page_vpages.iteritems())])
|
485
|
504
|
vpage["other_lang"] = langs # set other langs and link
|
486
|
505
|
|
487
|
506
|
vpages += page_vpages.values()
|
|
@@ -719,7 +738,7 @@ def hook_postconvert_size():
|
719
|
738
|
else:
|
720
|
739
|
return "<a href=\"%s\">%s</a> (%d Byte)" % (matchobj.group(1), matchobj.group(3), size)
|
721
|
740
|
except:
|
722
|
|
- print "Unable to estimate file size for %s" % matchobj.group(1)
|
|
741
|
+ print("Unable to estimate file size for %s" % matchobj.group(1))
|
723
|
742
|
return '<a href=\"%s\">%s</a>' % (matchobj.group(1), matchobj.group(3))
|
724
|
743
|
_re_url = '<a href=\"([^\"]*?\.(%s))\">(.*?)<\/a>' % file_ext
|
725
|
744
|
for p in pages:
|