aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJulian Hurst <ark@mansus.space>2024-11-15 01:14:07 +0100
committerJulian Hurst <ark@mansus.space>2024-11-15 01:14:07 +0100
commit189c3af4052d543ce816637d97fed926fefa5c47 (patch)
tree3e04183827064e52aeb954c5495a283c9f6ff2c6
parente2bee01af84bc7a6bc191f931f195b3c0b5175cc (diff)
downloadhatask-189c3af4052d543ce816637d97fed926fefa5c47.tar.gz
csv -> tsv
-rw-r--r--cmd.ha16
-rw-r--r--csv/csv.ha30
-rw-r--r--hatask.ha4
-rw-r--r--tsv/tsv.ha22
4 files changed, 32 insertions, 40 deletions
diff --git a/cmd.ha b/cmd.ha
index 6924fa9..3335209 100644
--- a/cmd.ha
+++ b/cmd.ha
@@ -7,7 +7,7 @@ use path;
use os::exec;
use strconv;
use ascii;
-use csv;
+use tsv;
type error = !(!str | io::error | path::error | exec::error | strconv::error);
@@ -40,8 +40,8 @@ const commands: [_]command = [
func = &do,
},
command {
- names = ["c", "csv"],
- func = &csv,
+ names = ["t", "tsv"],
+ func = &tsv,
},
];
@@ -83,11 +83,11 @@ fn show(tasks: []task, a: arguments) (void | task | error) = {
fmt::println(t.content)!;
};
-fn printtaskcsv(t: task, id: size) (void | error) = {
+fn printtasktsv(t: task, id: size) (void | error) = {
const sid = strings::dup(strconv::ztos(id));
defer free(sid);
const spriority = strconv::ztos(t.priority);
- csv::writerecord(os::stdout, [sid, t.name, spriority])!;
+ tsv::writerecord(os::stdout, [sid, t.name, spriority])!;
};
fn printtask(t: task, id: size) (void | error) = {
@@ -155,11 +155,11 @@ fn filter(tasks: []task, a: arguments) (void | task | error) = {
};
};
-fn csv(tasks: []task, a: arguments) (void | task | error) = {
- csv::writerecord(os::stdout, ["id" ,"name", "priority"])!;
+fn tsv(tasks: []task, a: arguments) (void | task | error) = {
+ tsv::writerecord(os::stdout, ["id" ,"name", "priority"])!;
for (let i = 0z; i < len(tasks); i += 1) {
const t = tasks[i];
- printtaskcsv(t, i)?;
+ printtasktsv(t, i)?;
};
};
diff --git a/csv/csv.ha b/csv/csv.ha
deleted file mode 100644
index 40e1e3b..0000000
--- a/csv/csv.ha
+++ /dev/null
@@ -1,30 +0,0 @@
-use io;
-use strings;
-use fmt;
-
-export type error = !(str | io::error);
-
-export fn writerecord(w: io::handle, record: []str, separator: const str = ",", quote: const rune =
- '"') (void | error) = {
- let sep = "";
- for (const field .. record) {
- if (strings::contains(field, separator)) {
- if (strings::contains(field, quote)) {
- return "ERROR: Field contains quote character
- (not supported)";
- };
- fmt::fprintf(w, "{}{}{}{}", sep, quote, field, quote)!;
- } else {
- fmt::fprintf(w, "{}{}", sep, field)!;
- };
- sep = separator;
- };
- fmt::fprintln(w)!;
-};
-
-export fn writerecords(w: io::handle, records: [][]str, separator: const str = ",", quote: const
- rune = '"') (void | error) = {
- for (const record .. records) {
- writerecord(w, record, separator, quote)?;
- };
-};
diff --git a/hatask.ha b/hatask.ha
index 190f82b..c65aff2 100644
--- a/hatask.ha
+++ b/hatask.ha
@@ -130,8 +130,8 @@ export fn main() void = {
("w", ["write a task", "id"]: []getopt::help),
("done", ["delete a task", "id"]: []getopt::help),
("d", ["delete a task", "id"]: []getopt::help),
- ("csv", ["print csv of tasks"]: []getopt::help),
- ("c", ["print csv of tasks"]: []getopt::help),
+ ("tsv", ["print tsv of tasks"]: []getopt::help),
+ ("t", ["print tsv of tasks"]: []getopt::help),
);
defer getopt::finish(&cmd);
diff --git a/tsv/tsv.ha b/tsv/tsv.ha
new file mode 100644
index 0000000..85015a1
--- /dev/null
+++ b/tsv/tsv.ha
@@ -0,0 +1,22 @@
+use io;
+use strings;
+use fmt;
+
+export type error = !(str | io::error);
+
+export fn writerecord(w: io::handle, record: []str) (void | error) = {
+ let sep = "";
+ for (const field .. record) {
+ const pfield = strings::replace(field, "\t", "");
+ defer free(pfield);
+ fmt::fprintf(w, "{}{}", sep, pfield)!;
+ sep = "\t";
+ };
+ fmt::fprintln(w)!;
+};
+
+export fn writerecords(w: io::handle, records: [][]str) (void | error) = {
+ for (const record .. records) {
+ writerecord(w, record)?;
+ };
+};