public inbox for network@lists.ipfire.org
 help / color / mirror / Atom feed
From: Jonatan Schlag <jonatan.schlag@ipfire.org>
To: network@lists.ipfire.org
Subject: [PATCH v2 2/5] util: add new function copy
Date: Mon, 17 Jul 2017 20:19:39 +0200	[thread overview]
Message-ID: <1500315582-17181-2-git-send-email-jonatan.schlag@ipfire.org> (raw)
In-Reply-To: <1500315582-17181-1-git-send-email-jonatan.schlag@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 1698 bytes --]

Just one short note, I could also insted of rmoving the destintaion if she exists,
allow fwrite to overired files. I did not do this because it would first maybe break code
when the function fwrite is used. Second it is easier to remove the destintaion and
so allow fwrite writing the content to a plain file, then changing the function so that fwrite override files.
It is easy to remove a file bevore but appending to a file with a function that overried files is not possible.
So I think it is the best to keep this feature of fwrite and when somebody wants to override a file he has to remove it before.

Signed-off-by: Jonatan Schlag <jonatan.schlag(a)ipfire.org>
---
 src/functions/functions.util | 26 ++++++++++++++++++++++++++
 1 file changed, 26 insertions(+)

diff --git a/src/functions/functions.util b/src/functions/functions.util
index 3bcd00f..7f691e0 100644
--- a/src/functions/functions.util
+++ b/src/functions/functions.util
@@ -766,3 +766,29 @@ hex2dec() {
 dec2hex() {
 	printf "%02x\n" "${1}"
 }
+
+copy() {
+	# This function just copy config files
+	assert [ $# -eq 2 ]
+	local src=${1}
+	local dst=${2}
+
+	# Wo do the decleration and the initialisation in two lines to get the return code of fread
+	local data
+	data=$(fread "${src}")
+	if [ ! $? -eq 0 ]; then
+		log ERROR "Could not read data from ${src}"
+		return ${EXIT_ERROR}
+	fi
+
+	# If the file exist we will overwrite it
+	# fwrite would just append the contentet to the end of the file
+	if [ -f ${dst} ]; then
+		rm -f ${dst}
+	fi
+
+	if ! fwrite "${dst}" "${data}"; then
+		log ERROR "Could not write data to ${dst}"
+		return ${EXIT_ERROR}
+	fi
+}
-- 
2.6.3


  reply	other threads:[~2017-07-17 18:19 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-07-17 18:19 [PATCH v2 1/5] util: refactor fwrite Jonatan Schlag
2017-07-17 18:19 ` Jonatan Schlag [this message]
2017-07-17 18:19 ` [PATCH v2 3/5] constants: add new constant NETWORK_SHARE_DIR Jonatan Schlag
2017-07-17 18:19 ` [PATCH v2 4/5] add new feature vpn security policies Jonatan Schlag
2017-07-17 18:19 ` [PATCH v2 5/5] Add vpn security policies to cli Jonatan Schlag

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=1500315582-17181-2-git-send-email-jonatan.schlag@ipfire.org \
    --to=jonatan.schlag@ipfire.org \
    --cc=network@lists.ipfire.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