Debug a support for formatted output

This commit is contained in:
Loïc Guégan 2024-04-18 16:18:41 +02:00
parent 256a6932c3
commit b36e130286
4 changed files with 51 additions and 10 deletions

9
example/layout.txt Normal file
View file

@ -0,0 +1,9 @@
Created timestamp: {created}
Created added: {added}
Created on hostname: {hostname}
Created on platform: {platform}
Tags: {tags}
Subpath: {subpath}
Id: {id}
Content:
{content}

View file

@ -85,12 +85,18 @@ class Metadata:
exit(1)
return None
def delete(self,subpath):
def delete(self,subpath, ignore_error=False):
"""
Delete subpath and its associated tags from the metadata.
"""
cur=self.con.cursor()
subpath_id=self.subpathid(subpath, True)
subpath_id=None
if ignore_error:
subpath_id=self.subpathid(subpath, False)
else:
subpath_id=self.subpathid(subpath, True)
if subpath_id is None:
return
cur.execute('DELETE FROM tags WHERE id={}'.format(subpath_id))
cur.execute('DELETE FROM files WHERE id={}'.format(subpath_id))
self.con.commit()

View file

@ -260,7 +260,7 @@ class Project:
print("Empty note file detected => "+f.name)
else:
print("Fixing empty note file => "+f.name)
self.metadata.delete(str(f))
self.metadata.delete(str(f),ignore_error=True)
os.remove(path)
self.metadata.fix_deleted(dry)

View file

@ -1,8 +1,11 @@
from pnote.tools.tool import Tool
import argparse
import argparse, os
class ToolSearch(Tool):
def __init__(self):
self.format_file=None
def add_parser(self,subparsers):
p = subparsers.add_parser("search", description="Perform search operation on your notes")
p.add_argument("-g", "--grep", help="Grep an expression")
@ -13,11 +16,28 @@ class ToolSearch(Tool):
p.add_argument("-s", "--subpath-only", help="Show file subpath only", action='store_true')
p.add_argument("--last-created", help="Get last n created note files")
p.add_argument("--last-added", help="Get last n added note files")
p.add_argument("--format-file", help="Format output according to a format file")
def catsubpath(self,project,subpath):
with open(project.getpath(subpath),"r") as fp:
for line in fp:
print(line,end="")
if self.format_file is not None:
with open(project.getpath(subpath),"r") as noteFile:
with open(self.format_file,"r") as tplFile:
variables={
"content":noteFile.read(),
"created":project.getfileinfo(subpath,"created"),
"added":project.getfileinfo(subpath,"added"),
"id":project.getfileinfo(subpath,"id"),
"hostname":project.getfileinfo(subpath,"hostname"),
"platform":project.getfileinfo(subpath,"platform"),
"tags":project.listtags(subpath),
"subpath":subpath}
for line in tplFile:
print(line.format(**variables),end="")
else:
with open(project.getpath(subpath),"r") as fp:
for line in fp:
print(line,end="")
def catsubpaths(self, project, subpaths, content_only=False, subpath_only=False):
first=True
@ -26,9 +46,10 @@ class ToolSearch(Tool):
print(subpath)
continue
if not content_only:
if not first:
print()
self.printsubpath(subpath)
if self.format_file is not None:
if not first:
print()
self.printsubpath(subpath)
self.catsubpath(project,subpath)
first=False
@ -40,6 +61,11 @@ class ToolSearch(Tool):
if content_only and subpath_only:
print("content and file-path options cannot be used at the same time")
exit(1)
if args.format_file:
if not os.path.exists(args.format_file):
print("Template file not found: {}".format(args.format_file))
exit(1)
self.format_file=args.format_file
if args.grep:
first=True
for entry in project.grep(args.grep, ignore_case):