restructuring the folder
This commit is contained in:
66
Qalbum.py
66
Qalbum.py
@@ -27,7 +27,7 @@ from datetime import datetime
|
||||
|
||||
# (c) ville.q.rantanen@gmail.com
|
||||
|
||||
__version__='2.20160906'
|
||||
__version__='2.20161005'
|
||||
|
||||
FILECONFIG=".config"
|
||||
FILEDESC="descriptions.csv"
|
||||
@@ -61,12 +61,12 @@ width: Medium images longer axis in pixels
|
||||
MISSINGICON=""
|
||||
FAVICON=""
|
||||
# python -c 'print open("icon.png", "rb").read().encode("base64").replace("\n","")'
|
||||
webfilesearch=re.compile('.*index.html$|gallerystyle.css$|galleryscript.js$|'+FILEDESC+'$|^'+FILEINFO+'$|\..*',re.I)
|
||||
webfilesearch=re.compile('.*index.html$|'+FILEDESC+'$|^'+FILEINFO+'$|\..*',re.I)
|
||||
imagesearch=re.compile('.*\.jpg$|.*\.jpeg$|.*\.gif$|.*\.png$|.*\.tif$|.*\.svg$|.*\.pdf$',re.I)
|
||||
vectorsearch=re.compile('.*\.svg$|.*\.pdf$',re.I)
|
||||
nonconvertiblesearch=re.compile('.*\.html$|.*\.htm$|.*\.php$',re.I)
|
||||
#gifsearch=re.compile('.*gif$',re.I)
|
||||
excludepaths=re.compile('_med|_tn|\..*')
|
||||
excludepaths=re.compile('_med|_tn|.med|.tn|\..*')
|
||||
doublequotes=re.compile('"')
|
||||
singlequotes=re.compile("'")
|
||||
stripquotes=re.compile('^"|"$')
|
||||
@@ -80,9 +80,12 @@ def getheader(path,parent,title=""):
|
||||
<TITLE>'''+title+'''</TITLE>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
|
||||
<meta name="generator" content="Qalbum '''+__version__+'''">
|
||||
<link rel="stylesheet" type="text/css" href="'''+parent+'''gallerystyle.css">
|
||||
<link rel="stylesheet" type="text/css" href="'''+parent+'''.qalbum/style.css">
|
||||
<link href="'''+FAVICON+'''" rel="icon" type="image/x-icon" />
|
||||
<script language="javascript" src="'''+parent+'''galleryscript.js"></script>
|
||||
<script language="javascript" src="'''+parent+'''.qalbum/jquery.js"></script>
|
||||
<script language="javascript" src="'''+parent+'''.qalbum/jqzoom.js"></script>
|
||||
<script language="javascript" src="'''+parent+'''.qalbum/touch.js"></script>
|
||||
<script language="javascript" src="'''+parent+'''.qalbum/gallery.js"></script>
|
||||
</HEAD>
|
||||
<BODY>
|
||||
'''
|
||||
@@ -184,7 +187,7 @@ def pathscript(path,list):
|
||||
this_str='{ name:"'+unicode(p,encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'", '
|
||||
this_str+='size:'+str(len(imglist)+len(pathlist))+', '
|
||||
if len(imglist)>0:
|
||||
this_str+='image:"'+unicode(p,encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'/_tn/tn_'+unicode(imglist[0],encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'.jpg"}'
|
||||
this_str+='image:"'+unicode(p,encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'/.tn/'+unicode(imglist[0],encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'.jpg"}'
|
||||
else:
|
||||
this_str+='image:"" }'
|
||||
elements.append(this_str)
|
||||
@@ -203,7 +206,7 @@ def pathlinks(path,list):
|
||||
nsum=str(len(imglist))
|
||||
imgstr=""
|
||||
if len(imglist)>0:
|
||||
imgstr='<span class="pathbox" style="background-image:url(\''+urllib.quote(p)+'/_tn/tn_'+urllib.quote(imglist[0])+'.jpg\');">'
|
||||
imgstr='<span class="pathbox" style="background-image:url(\''+urllib.quote(p)+'/.tn/'+urllib.quote(imglist[0])+'.jpg\');">'
|
||||
else:
|
||||
imgstr='<span class="pathbox">'
|
||||
pathstr+='<a title="'+unicode(p,encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'" href="'+urllib.quote(p)+'/index.html">'+imgstr+'<span class="pathlink"><span class="pathlinktext">'+unicode(nice,encoding="utf8").encode('ascii', 'xmlcharrefreplace')+' ('+nsum+')</span></span></span></a>';
|
||||
@@ -248,7 +251,7 @@ def imagelinks(path,list):
|
||||
except:
|
||||
desc=doublequotes.sub('',filter(lambda x: x in string.printable, descriptions[n]).encode('ascii', 'xmlcharrefreplace'))
|
||||
|
||||
strout+='<span class="imagebox thumbbox" id="n'+str(n)+'"><a href="'+urllib.quote(i)+'"><img class="thumbimage" "title="'+desc+'" src="_tn/tn_'+urllib.quote(i)+'.jpg"><br/>'+unicode(nice,encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'</a></span>'
|
||||
strout+='<span class="imagebox thumbbox" id="n'+str(n)+'"><a href="'+urllib.quote(i)+'"><img class="thumbimage" "title="'+desc+'" src=".tn/'+urllib.quote(i)+'.jpg"><br/>'+unicode(nice,encoding="utf8").encode('ascii', 'xmlcharrefreplace')+'</a></span>'
|
||||
n+=1
|
||||
strout+='</noscript></div>'
|
||||
return strout
|
||||
@@ -276,12 +279,12 @@ def filelinks(path,list):
|
||||
return strout
|
||||
|
||||
def cleanthumbs(path):
|
||||
''' clears _med and _tn for unused thumbs '''
|
||||
''' clears .med and .tn for unused thumbs '''
|
||||
print('clearing unused thumbs...')
|
||||
if os.path.exists(os.path.join(path,'_tn')):
|
||||
clearfolder(path,os.path.join(path,'_tn'),re.compile("(^tn_)(.*)(.jpg)"))
|
||||
if os.path.exists(os.path.join(path,'_med')):
|
||||
clearfolder(path,os.path.join(path,'_med'),re.compile("(^med_)(.*)(.jpg)"))
|
||||
if os.path.exists(os.path.join(path,'.tn')):
|
||||
clearfolder(path,os.path.join(path,'.tn'),re.compile("(.*)(.jpg)"))
|
||||
if os.path.exists(os.path.join(path,'.med')):
|
||||
clearfolder(path,os.path.join(path,'.med'),re.compile("(.*)(.jpg)"))
|
||||
return
|
||||
|
||||
def clearfolder(path,tnpath,regex):
|
||||
@@ -290,7 +293,7 @@ def clearfolder(path,tnpath,regex):
|
||||
for i in list:
|
||||
f=regex.match(i)
|
||||
try:
|
||||
if not os.path.exists(os.path.join(path,f.group(2))):
|
||||
if not os.path.exists(os.path.join(path,f.group(1))):
|
||||
print('removing '+i)
|
||||
os.remove(os.path.join(tnpath,i))
|
||||
except:
|
||||
@@ -301,17 +304,17 @@ def createthumbs(path,list,options):
|
||||
''' Runs imagemagick Convert to create medium sized and thumbnail images '''
|
||||
if len(list)==0:
|
||||
return
|
||||
if not os.path.exists(os.path.join(path,'_tn')):
|
||||
os.mkdir(os.path.join(path,'_tn'))
|
||||
if not os.path.exists(os.path.join(path,'_med')):
|
||||
os.mkdir(os.path.join(path,'_med'))
|
||||
if not os.path.exists(os.path.join(path,'.tn')):
|
||||
os.mkdir(os.path.join(path,'.tn'))
|
||||
if not os.path.exists(os.path.join(path,'.med')):
|
||||
os.mkdir(os.path.join(path,'.med'))
|
||||
n=1
|
||||
nsum=len(list)
|
||||
r=str(options.width)
|
||||
res=r+'x'+r+'>'
|
||||
for i in list:
|
||||
outmedium=os.path.join(path,'_med','med_'+i+'.jpg')
|
||||
outthumb=os.path.join(path,'_tn','tn_'+i+'.jpg')
|
||||
outmedium=os.path.join(path,'.med',i+'.jpg')
|
||||
outthumb=os.path.join(path,'.tn',i+'.jpg')
|
||||
inpath=os.path.join(path,i)
|
||||
if (options.force) and os.path.exists(outmedium):
|
||||
os.unlink(outmedium)
|
||||
@@ -445,15 +448,9 @@ def traverse(path,crumbs,inputs,options):
|
||||
header=getheader(path,'../'*(len(crumbs)-1),inputs[0][1])
|
||||
else:
|
||||
header=getheader(path,'../'*(len(crumbs)-1))
|
||||
if not os.path.exists(os.path.join(path,'../'*(len(crumbs)-1),'galleryscript.js')):
|
||||
print('Warning, no (relative path) galleryscript! '+os.path.join(path,'../'*(len(crumbs)-1),'galleryscript.js'))
|
||||
#depth=0
|
||||
#while not os.path.exists(os.path.join(path,'../'*(depth),'galleryscript.js')):
|
||||
# print(os.path.join(path,'../'*(depth)))
|
||||
# depth+=1
|
||||
#header=getheader(path,'../'*(depth))
|
||||
|
||||
#print('Depth: '+str(len(crumbs)))
|
||||
if not os.path.exists(os.path.join(path,'../'*(len(crumbs)-1),'.qalbum','gallery.js')):
|
||||
print('Warning, no (relative path) galleryscript! '+os.path.join(path,'../'*(len(crumbs)-1),'.qalbum','gallery.js'))
|
||||
|
||||
pathlist=getpathlist(path,options)
|
||||
imagelist=getimagelist(path,options)
|
||||
if options.clean:
|
||||
@@ -558,7 +555,7 @@ def setupdefaultoptions(options):
|
||||
if 'reverse' not in options:
|
||||
options.reverse=False
|
||||
if 'style' not in options or options.style is None:
|
||||
options.style=os.path.join(os.path.abspath(os.path.dirname(os.path.realpath(sys.argv[0]))),'gallerystyle.css')
|
||||
options.style=os.path.join(os.path.abspath(os.path.dirname(os.path.realpath(sys.argv[0]))),'lib','style.css')
|
||||
if 'timesort' not in options:
|
||||
options.timesort=False
|
||||
if 'thumbs' not in options:
|
||||
@@ -606,11 +603,14 @@ def execute_plain():
|
||||
# Copy all resources to target folder
|
||||
pathname=os.path.dirname(os.path.realpath(sys.argv[0]))
|
||||
fullpath=os.path.abspath(pathname)
|
||||
libpath=os.path.join(options.startpath,'.qalbum')
|
||||
if not os.path.exists(options.style):
|
||||
raise IOError('File not found: "'+options.style+'"')
|
||||
shutil.copyfile(options.style,os.path.join(options.startpath,'gallerystyle.css'))
|
||||
shutil.copyfile(os.path.join(fullpath,'galleryscript.js'),os.path.join(options.startpath,'galleryscript.js'))
|
||||
|
||||
if not os.path.isdir(libpath):
|
||||
os.mkdir(libpath)
|
||||
shutil.copyfile(options.style,os.path.join(libpath,'style.css'))
|
||||
for jslib in ('gallery.js','jquery.js','jqzoom.js','touch.js'):
|
||||
shutil.copyfile(os.path.join(fullpath,'lib',jslib),os.path.join(libpath,jslib))
|
||||
inputs=[]
|
||||
inputs.append((None,options.gallery,None))
|
||||
|
||||
|
||||
Reference in New Issue
Block a user