From: Sascha Hauer <s.hauer@pengutronix.de>
To: barebox@lists.infradead.org
Subject: [PATCH 2/2] add filetype command support
Date: Tue, 30 Oct 2012 15:46:49 +0100 [thread overview]
Message-ID: <1351608409-9793-3-git-send-email-s.hauer@pengutronix.de> (raw)
In-Reply-To: <1351608409-9793-1-git-send-email-s.hauer@pengutronix.de>
This adds support for a filetype detection command. It can be
used to print a filename on the console or to set a variable
with the detection result for use in shell scripts.
The command also has an option to print the known filetypes
so that a user knows what to match for.
Based on an earlier version from Jean-Christophe.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
---
commands/Kconfig | 5 +++
commands/Makefile | 1 +
commands/filetype.c | 97 +++++++++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 103 insertions(+)
create mode 100644 commands/filetype.c
diff --git a/commands/Kconfig b/commands/Kconfig
index 16706d3..460bc2c 100644
--- a/commands/Kconfig
+++ b/commands/Kconfig
@@ -230,6 +230,11 @@ config CMD_TFTP
barebox can mount tftp as a filesystem. This command is only needed to
preserve backward compatibility to the old tftp command.
+config CMD_FILETYPE
+ tristate
+ select FILETYPE
+ prompt "filetype"
+
endmenu
menu "console "
diff --git a/commands/Makefile b/commands/Makefile
index 610be55..6540802 100644
--- a/commands/Makefile
+++ b/commands/Makefile
@@ -76,3 +76,4 @@ obj-$(CONFIG_CMD_READLINK) += readlink.o
obj-$(CONFIG_CMD_LN) += ln.o
obj-$(CONFIG_CMD_CLK) += clk.o
obj-$(CONFIG_CMD_TFTP) += tftp.o
+obj-$(CONFIG_CMD_FILETYPE) += filetype.o
diff --git a/commands/filetype.c b/commands/filetype.c
new file mode 100644
index 0000000..20d335b
--- /dev/null
+++ b/commands/filetype.c
@@ -0,0 +1,97 @@
+/*
+ * (C) Copyright 2012 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
+ *
+ * Under GPLv2 Only
+ */
+
+#include <common.h>
+#include <command.h>
+#include <fs.h>
+#include <filetype.h>
+#include <environment.h>
+#include <magicvar.h>
+#include <getopt.h>
+#include <linux/stat.h>
+#include <fs.h>
+
+static int do_filetype(int argc, char *argv[])
+{
+ int opt;
+ enum filetype type;
+ char *filename = NULL;
+ int verbose = -1, list = 0;
+ const char *varname = NULL;
+ struct stat s;
+ int ret;
+
+ while ((opt = getopt(argc, argv, "vls:")) > 0) {
+ switch (opt) {
+ case 'v':
+ verbose = 1;
+ break;
+ case 'l':
+ list = 1;
+ break;
+ case 's':
+ varname = optarg;
+ /* in scripting mode default to nonverbose */
+ if (verbose < 0)
+ verbose = 0;
+ break;
+ default:
+ return COMMAND_ERROR_USAGE;
+ }
+ }
+
+ if (verbose < 0)
+ verbose = 1;
+
+ if (list) {
+ int i;
+
+ printf("known filetypes:\n");
+
+ for (i = 1; i < filetype_max; i++)
+ printf("%-16s: %s\n", file_type_to_short_string(i),
+ file_type_to_string(i));
+ return 0;
+ }
+
+ if (argc - optind < 1)
+ return COMMAND_ERROR_USAGE;
+
+ filename = argv[optind];
+
+ ret = stat(filename, &s);
+ if (ret)
+ return ret;
+
+ if (S_ISDIR(s.st_mode))
+ return -EISDIR;
+
+ type = file_name_detect_type(filename);
+
+ if (verbose)
+ printf("%s: %s (%s)\n", filename,
+ file_type_to_string(type),
+ file_type_to_short_string(type));
+
+ if (varname)
+ setenv(varname, file_type_to_short_string(type));
+
+ return 0;
+}
+
+BAREBOX_CMD_HELP_START(filetype)
+BAREBOX_CMD_HELP_USAGE("filetype [OPTIONS] <file>\n")
+BAREBOX_CMD_HELP_SHORT("detect type of a file and export result to a variable\n")
+BAREBOX_CMD_HELP_OPT("-v", "verbose\n")
+BAREBOX_CMD_HELP_OPT("-s <v>", "set <v> to shortname\n")
+BAREBOX_CMD_HELP_OPT("-l", "list known filetypes\n")
+BAREBOX_CMD_HELP_END
+
+BAREBOX_CMD_START(filetype)
+ .cmd = do_filetype,
+ .usage = "detect file type",
+ BAREBOX_CMD_HELP(cmd_filetype_help)
+BAREBOX_CMD_END
--
1.7.10.4
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
prev parent reply other threads:[~2012-10-30 14:47 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-10-30 14:46 [PATCH] " Sascha Hauer
2012-10-30 14:46 ` [PATCH 1/2] filetype: add shortnames Sascha Hauer
2012-10-30 14:46 ` Sascha Hauer [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1351608409-9793-3-git-send-email-s.hauer@pengutronix.de \
--to=s.hauer@pengutronix.de \
--cc=barebox@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox