From db917a164fc9f885f817312da49d5c9c451938d2 Mon Sep 17 00:00:00 2001
From: "edouard@lafargue.name"
 <edouard@lafargue.name@ef4ab9da-24cd-11de-8aaa-f3a34680c41f>
Date: Fri, 26 Jun 2009 10:20:55 +0000
Subject: [PATCH] Add the new Linux "cli" command line client, thanks for the
 contribution!

---
 linux/Makefile |  6 +++--
 linux/cli.c    | 61 ++++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 65 insertions(+), 2 deletions(-)
 create mode 100644 linux/cli.c

diff --git a/linux/Makefile b/linux/Makefile
index 7d4b0156..ef764db4 100644
--- a/linux/Makefile
+++ b/linux/Makefile
@@ -13,17 +13,19 @@ else
 QTGUI = guidummy.o
 endif
 
-all: proxmark3 snooper
+all: proxmark3 snooper cli
 
 proxmark3: LDFLAGS+=$(QTLDFLAGS)
 proxmark3: proxmark3.o gui.o command.o usb.o $(QTGUI)
 
 snooper: snooper.o gui.o command.o usb.o guidummy.o
 
+cli: cli.o gui.o command.o usb.o guidummy.o
+
 proxguiqt.moc.cpp: proxguiqt.h
 	$(MOC) -o$@ $^
 
 clean:
-	rm -f proxmark3 snooper *.o *.moc.cpp
+	rm -f cli proxmark3 snooper *.o *.moc.cpp
 
 .PHONY: all clean
diff --git a/linux/cli.c b/linux/cli.c
new file mode 100644
index 00000000..e893a727
--- /dev/null
+++ b/linux/cli.c
@@ -0,0 +1,61 @@
+#include <usb.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <stdlib.h>
+#include <strings.h>
+#include <string.h>
+#include <errno.h>
+
+#include "translate.h"
+#include "../winsrc/prox.h"
+#include "proxmark3.h"
+
+#define HANDLE_ERROR if (error_occured) { \
+	error_occured = 0;\
+	break;\
+}
+
+int main(int argc, char **argv)
+{
+	if(argc != 3 && argc != 4)
+		{
+		printf("\n\tusage: cli <command 1> <command 2> [logfile (default cli.log)]\n");
+		printf("\n");
+		printf("\texample: cli hi14asnoop hi14alist h14a.log\n");
+		printf("\n");
+		return -1;
+		}
+
+	usb_init();
+	if (argc == 4)
+		setlogfilename(argv[3]);
+	else
+		setlogfilename("cli.log");
+
+	return_on_error = 1;
+
+	while(1) {
+		while(!(devh=OpenProxmark(0))) { sleep(1); }
+
+		while(1) {
+			UsbCommand cmdbuf;
+			int i;
+
+			CommandReceived(argv[1]);
+			HANDLE_ERROR
+
+			ReceiveCommand(&cmdbuf);
+			HANDLE_ERROR
+			for (i=0; i<5; i++) {
+				ReceiveCommandP(&cmdbuf);
+			}
+			HANDLE_ERROR
+
+			CommandReceived(argv[2]);
+			HANDLE_ERROR
+		}
+	}
+
+	CloseProxmark();
+	return 0;
+}
-- 
2.39.5