Add an option to read a message from a file.
continuous-integration/drone/push Build is passing Details

main 0.3.3
KKlochko 2 years ago
parent 63f55bbc50
commit 617dd34a23

@ -1,5 +1,6 @@
(ns cipher-analytical-machine.cli (ns cipher-analytical-machine.cli
(:require (:require
[cipher-analytical-machine.file :as file]
[cipher-analytical-machine.caesar :as caesar] [cipher-analytical-machine.caesar :as caesar]
[clojure.string :as cs] [clojure.string :as cs]
[clojure.tools.cli :refer [parse-opts]]) [clojure.tools.cli :refer [parse-opts]])
@ -10,6 +11,7 @@
(def cli-options (def cli-options
[["-m" "--message MESSAGE" "The message will be encrypted or decrypted."] [["-m" "--message MESSAGE" "The message will be encrypted or decrypted."]
["-M" "--message-file MESSAGE-FILE" "The file contains the message that will be encrypted or decrypted."]
["-k" "--key KEY" "The key will be used to encrypt or decrypt."] ["-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." ["-c" "--cipher CIPHER" "The cipher will be used to encrypt or decrypt a message."
:default "Caesar"] :default "Caesar"]
@ -52,8 +54,12 @@
(map-has-keys? options [:encrypt, :decrypt]) (map-has-keys? options [:encrypt, :decrypt])
{:exit-message (error-msg ["You can't use enctypt and decrypt mode at the same time!!!"])} {:exit-message (error-msg ["You can't use enctypt and decrypt mode at the same time!!!"])}
(map-has-keys? options [:message, :message-file])
{:exit-message (error-msg ["You can't use message and message-file options at the same time!!!"])}
(and (map-has-keys? options [:cipher, :key]) (and (map-has-keys? options [:cipher, :key])
(contains? options :message) (or (contains? options :message)
(contains? options :message-file))
(or (contains? options :encrypt) (or (contains? options :encrypt)
(contains? options :decrypt))) (contains? options :decrypt)))
{:options options :arguments arguments} {:options options :arguments arguments}
@ -66,10 +72,20 @@
(println exit-message) (println exit-message)
(System/exit (if status 0 1))) (System/exit (if status 0 1)))
(defn get-message
"Return the message"
[options arguments]
(cond
(contains? options :message)
(:message options)
(contains? options :message-file)
(file/read-file (:message-file options))))
(defn actions (defn actions
[options arguments] [options arguments]
(println (str options arguments)) (println (str options arguments))
(let [message (:message options) (let [message (get-message options arguments)
key (Integer/parseInt (:key options)) key (Integer/parseInt (:key options))
symbols "abc"] symbols "abc"]
(println (println

@ -0,0 +1,18 @@
(ns cipher-analytical-machine.file
(:require [clojure.java.io :as io])
(:gen-class))
(defn is-file-exists?
"Checks that a file is exists"
[file-path]
(-> (io/file file-path)
(.exists)))
(defn is-file-not-exists?
"Checks that a file is not exists"
[file-path]
(not (is-file-exists? file-path)))
(defn read-file [file-path]
(slurp file-path))
Loading…
Cancel
Save