X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=dotfiles2html%2Fdotfiles2html.py;h=6bf9e1af7ab95fdfed2641a25f476d98dc9059e5;hb=d68f2dd8fdab1ec22049d14f274ec34a2ed8431f;hp=887eae3f02d75ce0198683ca577a3afaa138adde;hpb=7f84e47a707cd948d8cf83f9a45004c11e21df65;p=phdru.name%2Fphdru.name.git diff --git a/dotfiles2html/dotfiles2html.py b/dotfiles2html/dotfiles2html.py index 887eae3..6bf9e1a 100755 --- a/dotfiles2html/dotfiles2html.py +++ b/dotfiles2html/dotfiles2html.py @@ -13,7 +13,7 @@ from m_lib.m_path import get_homedir home_dir = get_homedir() -def add_headers(fname, prev, next): +def add_headers(fname, first, prev, next, last): head_fname = os.path.join(home_dir, fname + ".head") head_file = open(head_fname, 'r') head = head_file.read() @@ -36,11 +36,13 @@ def add_headers(fname, prev, next): html_file.write("#implements respond\n") html_file.write("#attr $Title = \"%s\"\n" % dot_name) html_file.write("#attr $Copyright = 2003\n") + html_file.write("#attr $First = \"%s.html\"\n" % first) if prev: html_file.write("#attr $Prev = \"%s.html\"\n" % prev) if next: html_file.write("#attr $Next = \"%s.html\"\n" % next) - html_file.write('#attr $alternates = (("text/plain", "Plain text version", "%s"),)' % txt_name) + html_file.write("#attr $Last = \"%s.html\"\n" % last) + html_file.write('#attr $alternates = (("Plain text version", "text/plain", "%s"),)' % txt_name) html_file.write("\n") html_file.write("#def body_html\n") html_file.write("#raw\n") @@ -53,18 +55,21 @@ def add_headers(fname, prev, next): html_file.close() -file_types = (("profile", "sh"), ("shellrc", "sh"), ("fvwm2rc", "fvwm2m4"), +home_file_types = (("profile", "sh"), ("shellrc", "sh"), ("fvwm2rc", "fvwm2m4"), ("mailcap", "conf"), ("mime.types", "conf"), ("muttrc", "muttrc"), ("procmailrc", "procmail"), ("vimrc", "vim"), ("gvimrc", "vim"), - ("init.py", "python"), ("pdbrc", "python"), ("pdbrc.py", "python"), - ("bindings", "conf"), ("menu", "conf")) -ft_len = len(file_types) + ("init.py", "python"), ("pdbrc", "python"), ("pdbrc.py", "python")) -for i, (fname, ftype) in enumerate(file_types): +mc_file_types = (("bindings", "conf"), ("menu", "conf")) + +def process_dotfile(i, fname, ftype, file_types): if os.path.exists('.' + fname) and not os.path.exists(fname): shutil.copy2('.' + fname, fname) + if not os.path.exists(fname): + return + if fname == 'vimrc' and os.path.exists(fname): file = open('vimrc', 'r') text = file.read() @@ -83,21 +88,20 @@ for i, (fname, ftype) in enumerate(file_types): file.write(text) file.close() - if not os.path.exists(fname): - continue - os.system("""exec gvim -f -c "set filetype=%s" -c ":source %s/dotfile2html.vim" "%s" """ % (ftype, home_dir, fname)) - if i == 0: + first = file_types[0][0] + if i==0: prev = None else: prev = file_types[i-1][0] - if i >= ft_len - 1: + if i >= len(file_types) - 1: next = None else: next = file_types[i+1][0] - add_headers(fname, prev, next) + last = file_types[-1][0] + add_headers(fname, first, prev, next, last) if os.path.exists(fname + ".tmpl") and filecmp.cmp(fname + ".html", fname + ".tmpl"): os.remove(fname + ".html") @@ -114,3 +118,10 @@ for i, (fname, ftype) in enumerate(file_types): if os.path.exists(fname): os.chmod(fname, 0644) + +def process_files(file_types): + for i, (fname, ftype) in enumerate(file_types): + process_dotfile(i, fname, ftype, file_types) + +process_files(home_file_types) +process_files(mc_file_types)