parent
f32ae4a9d3
commit
453b90d537
@ -0,0 +1,82 @@
|
|||||||
|
(ns cipher-analytical-machine.cli
|
||||||
|
(:require
|
||||||
|
[cipher-analytical-machine.caesar :as caesar]
|
||||||
|
[clojure.string :as cs]
|
||||||
|
[clojure.tools.cli :refer [parse-opts]])
|
||||||
|
(:gen-class))
|
||||||
|
|
||||||
|
(def cipher-options
|
||||||
|
#{"Caesar"})
|
||||||
|
|
||||||
|
(def cli-options
|
||||||
|
[["-m" "--message MESSAGE" "The message will be encrypted or decrypted."]
|
||||||
|
["-k" "--key KEY" "The key will be used to encrypt or decrypt."]
|
||||||
|
["-c" "--cipher CIPHER" "The cipher will be used to encrypt or decrypt a message."
|
||||||
|
:default "Caesar"]
|
||||||
|
["-e" "--encrypt" "Encrypt the message."]
|
||||||
|
["-d" "--decrypt" "Decrypt the message."]
|
||||||
|
["-h" "--help"]])
|
||||||
|
|
||||||
|
(defn usage [options-summary]
|
||||||
|
(->> ["This is cipher-analytical-machine. It can help you to learn how ciphers works."
|
||||||
|
""
|
||||||
|
"Usage: cipher-analytical-machine [options]"
|
||||||
|
""
|
||||||
|
"Options:"
|
||||||
|
options-summary
|
||||||
|
""]
|
||||||
|
(cs/join \newline)))
|
||||||
|
|
||||||
|
(defn error-msg [errors]
|
||||||
|
(str "The following errors occurred while parsing your command:\n\n"
|
||||||
|
(cs/join \newline errors)))
|
||||||
|
|
||||||
|
(defn map-has-keys?
|
||||||
|
"Return true if all keys in the map."
|
||||||
|
[map keys]
|
||||||
|
(every? #(contains? map %) keys))
|
||||||
|
|
||||||
|
(defn validate-args
|
||||||
|
"Validate command line arguments. Either return a map indicating the program
|
||||||
|
should exit (with an error message, and optional ok status), or a map
|
||||||
|
indicating the action the program should take and the options provided."
|
||||||
|
[args]
|
||||||
|
(let [{:keys [options arguments errors summary]} (parse-opts args cli-options)]
|
||||||
|
(cond
|
||||||
|
(:help options)
|
||||||
|
{:exit-message (usage summary) :ok? true}
|
||||||
|
|
||||||
|
errors
|
||||||
|
{:exit-message (error-msg errors)}
|
||||||
|
|
||||||
|
(map-has-keys? options [:encrypt, :decrypt])
|
||||||
|
{:exit-message (error-msg ["You can't use enctypt and decrypt mode at the same time!!!"])}
|
||||||
|
|
||||||
|
(and (map-has-keys? options [:cipher, :key])
|
||||||
|
(contains? options :message)
|
||||||
|
(or (contains? options :encrypt)
|
||||||
|
(contains? options :decrypt)))
|
||||||
|
{:options options :arguments arguments}
|
||||||
|
|
||||||
|
:else
|
||||||
|
{:exit-message (usage summary)})))
|
||||||
|
|
||||||
|
(defn exit
|
||||||
|
[exit-message status]
|
||||||
|
(println exit-message)
|
||||||
|
(System/exit (if status 0 1)))
|
||||||
|
|
||||||
|
(defn actions
|
||||||
|
[options arguments]
|
||||||
|
(println (str options arguments))
|
||||||
|
(let [message (:message options)
|
||||||
|
key (Integer/parseInt (:key options))
|
||||||
|
symbols "abc"]
|
||||||
|
(println
|
||||||
|
(cond
|
||||||
|
(contains? options :encrypt)
|
||||||
|
(caesar/encrypt-message message key symbols)
|
||||||
|
|
||||||
|
(contains? options :decrypt)
|
||||||
|
(caesar/decrypt-message message key symbols)))))
|
||||||
|
|
@ -1,7 +1,12 @@
|
|||||||
(ns cipher-analytical-machine.core
|
(ns cipher-analytical-machine.core
|
||||||
|
(:require
|
||||||
|
[cipher-analytical-machine.cli :as cli])
|
||||||
(:gen-class))
|
(:gen-class))
|
||||||
|
|
||||||
(defn -main
|
(defn -main
|
||||||
"I don't do a whole lot ... yet."
|
|
||||||
[& args]
|
[& args]
|
||||||
(println "Hello, World!"))
|
(let [{:keys [options arguments exit-message ok?]} (cli/validate-args args)]
|
||||||
|
(if exit-message
|
||||||
|
(cli/exit exit-message ok?)
|
||||||
|
(cli/actions options arguments))))
|
||||||
|
|
||||||
|
Loading…
Reference in new issue