Rocksolid Light

News from da outaworlds

mail  files  register  groups  login

Message-ID:  

You are fairminded, just and loving.


comp / comp.unix.programmer / Re: how copy file on linux?

SubjectAuthor
* Re: how copy file on linux?Thiago Adams
+* Re: how copy file on linux?Scott Lurndal
|+- Re: how copy file on linux?Kaz Kylheku
|+- Re: how copy file on linux?Paul
|`- Re: how copy file on linux?candycanearter07
`- Re: how copy file on linux?Janis Papanagnou

1
Subject: Re: how copy file on linux?
From: Thiago Adams
Newsgroups: comp.unix.programmer
Organization: A noiseless patient Spider
Date: Thu, 27 Jun 2024 00:40 UTC
References: 1 2 3
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: thiago.adams@gmail.com (Thiago Adams)
Newsgroups: comp.unix.programmer
Subject: Re: how copy file on linux?
Date: Wed, 26 Jun 2024 21:40:06 -0300
Organization: A noiseless patient Spider
Lines: 43
Message-ID: <v5icd7$2d3iu$1@dont-email.me>
References: <v5huk1$2anbd$1@dont-email.me>
<87v81vs57v.fsf@nosuchdomain.example.com> <v5i7vu$28id7$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Thu, 27 Jun 2024 02:40:07 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="95346367adb7016ac45f84428f65517e";
logging-data="2526814"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+OWrhKWrxWEtlPUl8bKX7yXcZZte+xVn4="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:sK6B6Rt9oizh8teQYeNKmLV9S0o=
In-Reply-To: <v5i7vu$28id7$1@dont-email.me>
Content-Language: en-GB
View all headers

Em 6/26/2024 8:24 PM, Lew Pitcher escreveu:
> (Followup set to comp.unix.programmer)
>
> On Wed, 26 Jun 2024 15:35:00 -0700, Keith Thompson wrote:
>
>> Thiago Adams <thiago.adams@gmail.com> writes:
>>> How to copy a file on linux keeping the original file information?
>>> timestamp etc?
>>>
>>> Or in other words the equivalent of CopyFileA from windows.
>>
>> comp.unix.programmer is likely to give you better answers. I don't
>> think POSIX defines any functions that copy files.
>
> No, AFAIK, POSIX doesn't define an "all-in-one" file copy function.
> However, Linux (the OS Thiago asks about) defines a number of them.
>
>> If I uunderstand correctly, you want to do the equivalent of "cp -p",
>
> Which /can/ be accomplished with POSIX calls
> - the standard I/O functions (fopen()/open(), fread()/read(),
> fwrite()/write(), fclose()/close() ) to copy the file data
> - stat() to obtain the "original file information", and
> - utime() to set the copy timestamps,
> - chmod() to set the copy file permissions
> - chown() to set the file ownership
>
> But, perhaps Thiago would be satisfied with just a hardlinked file.
>
>> but from C rather than from a shell. You might consider using system(),
>> but that has some drawbacks, and there are probably better ways.
>
>

I am using this to create a "deploy" folder with all files necessary to
run a program. So on windows I am coping dlls and I think it is a good
idea to keep the original file attributes . (I am not sure if zip files
keep that.. I need to check)

On linux I may need to copy some files and I think is is a good idea to
keep the original attributes as well.

Subject: Re: how copy file on linux?
From: Scott Lurndal
Newsgroups: comp.unix.programmer
Organization: UsenetServer - www.usenetserver.com
Date: Thu, 27 Jun 2024 01:14 UTC
References: 1 2 3 4
Path: eternal-september.org!news.eternal-september.org!feeder3.eternal-september.org!news.mixmin.net!news.swapon.de!news.in-chemnitz.de!3.eu.feeder.erje.net!feeder.erje.net!npeer.as286.net!npeer-ng0.as286.net!usenet.blueworldhosting.com!diablo1.usenet.blueworldhosting.com!peer01.iad!feed-me.highwinds-media.com!news.highwinds-media.com!fx13.iad.POSTED!not-for-mail
X-newsreader: xrn 9.03-beta-14-64bit
Sender: scott@dragon.sl.home (Scott Lurndal)
From: scott@slp53.sl.home (Scott Lurndal)
Reply-To: slp53@pacbell.net
Subject: Re: how copy file on linux?
Newsgroups: comp.unix.programmer
References: <v5huk1$2anbd$1@dont-email.me> <87v81vs57v.fsf@nosuchdomain.example.com> <v5i7vu$28id7$1@dont-email.me> <v5icd7$2d3iu$1@dont-email.me>
Lines: 54
Message-ID: <D13fO.92832$G9_a.42787@fx13.iad>
X-Complaints-To: abuse@usenetserver.com
NNTP-Posting-Date: Thu, 27 Jun 2024 01:14:11 UTC
Organization: UsenetServer - www.usenetserver.com
Date: Thu, 27 Jun 2024 01:14:11 GMT
X-Received-Bytes: 2812
View all headers

Thiago Adams <thiago.adams@gmail.com> writes:
>Em 6/26/2024 8:24 PM, Lew Pitcher escreveu:
>> (Followup set to comp.unix.programmer)
>>
>> On Wed, 26 Jun 2024 15:35:00 -0700, Keith Thompson wrote:
>>
>>> Thiago Adams <thiago.adams@gmail.com> writes:
>>>> How to copy a file on linux keeping the original file information?
>>>> timestamp etc?
>>>>
>>>> Or in other words the equivalent of CopyFileA from windows.
>>>
>>> comp.unix.programmer is likely to give you better answers. I don't
>>> think POSIX defines any functions that copy files.
>>
>> No, AFAIK, POSIX doesn't define an "all-in-one" file copy function.
>> However, Linux (the OS Thiago asks about) defines a number of them.
>>
>>> If I uunderstand correctly, you want to do the equivalent of "cp -p",
>>
>> Which /can/ be accomplished with POSIX calls
>> - the standard I/O functions (fopen()/open(), fread()/read(),
>> fwrite()/write(), fclose()/close() ) to copy the file data
>> - stat() to obtain the "original file information", and
>> - utime() to set the copy timestamps,
>> - chmod() to set the copy file permissions
>> - chown() to set the file ownership
>>
>> But, perhaps Thiago would be satisfied with just a hardlinked file.
>>
>>> but from C rather than from a shell. You might consider using system(),
>>> but that has some drawbacks, and there are probably better ways.
>>
>>
>
>I am using this to create a "deploy" folder with all files necessary to
>run a program. So on windows I am coping dlls and I think it is a good
>idea to keep the original file attributes . (I am not sure if zip files
>keep that.. I need to check)

Both the tar(1) and cpio(1) utilities can be used to create a
compressed deployable archive. They're the most portable way
to distribute anything and they keep and restore the attributes
(although the ownership attributes uid and gid can only be
restored by root if they differ from the current users).

Windows, well 'nuf said.

>
>On linux I may need to copy some files and I think is is a good idea to
>keep the original attributes as well.
>
>

Subject: Re: how copy file on linux?
From: Kaz Kylheku
Newsgroups: comp.unix.programmer
Organization: A noiseless patient Spider
Date: Thu, 27 Jun 2024 03:32 UTC
References: 1 2 3 4 5
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: 643-408-1753@kylheku.com (Kaz Kylheku)
Newsgroups: comp.unix.programmer
Subject: Re: how copy file on linux?
Date: Thu, 27 Jun 2024 03:32:10 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 22
Message-ID: <20240626202923.259@kylheku.com>
References: <v5huk1$2anbd$1@dont-email.me>
<87v81vs57v.fsf@nosuchdomain.example.com> <v5i7vu$28id7$1@dont-email.me>
<v5icd7$2d3iu$1@dont-email.me> <D13fO.92832$G9_a.42787@fx13.iad>
Injection-Date: Thu, 27 Jun 2024 05:32:10 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="896e96bc6ca4b9b95967627cb0a5ddb2";
logging-data="2702832"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1++mIaLYQn72mB9YXv3SbJ+LUqCbqpWAYw="
User-Agent: slrn/pre1.0.4-9 (Linux)
Cancel-Lock: sha1:w3YrzdtkJ1bWCxrKX/b9jxABHCs=
View all headers

On 2024-06-27, Scott Lurndal <scott@slp53.sl.home> wrote:
> Thiago Adams <thiago.adams@gmail.com> writes:
>>I am using this to create a "deploy" folder with all files necessary to
>>run a program. So on windows I am coping dlls and I think it is a good
>>idea to keep the original file attributes . (I am not sure if zip files
>>keep that.. I need to check)
>
> Both the tar(1) and cpio(1) utilities can be used to create a
> compressed deployable archive. They're the most portable way
> to distribute anything and they keep and restore the attributes
> (although the ownership attributes uid and gid can only be
> restored by root if they differ from the current users).
>
>
> Windows, well 'nuf said.

On Windows, use an installer generator like NSIS.

--
TXR Programming Language: http://nongnu.org/txr
Cygnal: Cygwin Native Application Library: http://kylheku.com/cygnal
Mastodon: @Kazinator@mstdn.ca

Subject: Re: how copy file on linux?
From: Paul
Newsgroups: comp.unix.programmer
Organization: A noiseless patient Spider
Date: Thu, 27 Jun 2024 04:11 UTC
References: 1 2 3 4 5
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: nospam@needed.invalid (Paul)
Newsgroups: comp.unix.programmer
Subject: Re: how copy file on linux?
Date: Thu, 27 Jun 2024 00:11:43 -0400
Organization: A noiseless patient Spider
Lines: 122
Message-ID: <v5iopv$2is1f$1@dont-email.me>
References: <v5huk1$2anbd$1@dont-email.me>
<87v81vs57v.fsf@nosuchdomain.example.com> <v5i7vu$28id7$1@dont-email.me>
<v5icd7$2d3iu$1@dont-email.me> <D13fO.92832$G9_a.42787@fx13.iad>
MIME-Version: 1.0
Content-Type: text/plain; charset=utf-8
Content-Transfer-Encoding: 7bit
Injection-Date: Thu, 27 Jun 2024 06:11:43 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="b08c1b6acb35ea0413dd882e414693be";
logging-data="2715695"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/U8eRBIQdGEr9Fy92aF4bz+cwn7016bLo="
User-Agent: Ratcatcher/2.0.0.25 (Windows/20130802)
Cancel-Lock: sha1:FqIkq5K3XvOJTVTMxlb4mwOeo7k=
Content-Language: en-US
In-Reply-To: <D13fO.92832$G9_a.42787@fx13.iad>
View all headers

On 6/26/2024 9:14 PM, Scott Lurndal wrote:
> Thiago Adams <thiago.adams@gmail.com> writes:
>> Em 6/26/2024 8:24 PM, Lew Pitcher escreveu:
>>> (Followup set to comp.unix.programmer)
>>>
>>> On Wed, 26 Jun 2024 15:35:00 -0700, Keith Thompson wrote:
>>>
>>>> Thiago Adams <thiago.adams@gmail.com> writes:
>>>>> How to copy a file on linux keeping the original file information?
>>>>> timestamp etc?
>>>>>
>>>>> Or in other words the equivalent of CopyFileA from windows.
>>>>
>>>> comp.unix.programmer is likely to give you better answers. I don't
>>>> think POSIX defines any functions that copy files.
>>>
>>> No, AFAIK, POSIX doesn't define an "all-in-one" file copy function.
>>> However, Linux (the OS Thiago asks about) defines a number of them.
>>>
>>>> If I uunderstand correctly, you want to do the equivalent of "cp -p",
>>>
>>> Which /can/ be accomplished with POSIX calls
>>> - the standard I/O functions (fopen()/open(), fread()/read(),
>>> fwrite()/write(), fclose()/close() ) to copy the file data
>>> - stat() to obtain the "original file information", and
>>> - utime() to set the copy timestamps,
>>> - chmod() to set the copy file permissions
>>> - chown() to set the file ownership
>>>
>>> But, perhaps Thiago would be satisfied with just a hardlinked file.
>>>
>>>> but from C rather than from a shell. You might consider using system(),
>>>> but that has some drawbacks, and there are probably better ways.
>>>
>>>
>>
>> I am using this to create a "deploy" folder with all files necessary to
>> run a program. So on windows I am coping dlls and I think it is a good
>> idea to keep the original file attributes . (I am not sure if zip files
>> keep that.. I need to check)
>
> Both the tar(1) and cpio(1) utilities can be used to create a
> compressed deployable archive. They're the most portable way
> to distribute anything and they keep and restore the attributes
> (although the ownership attributes uid and gid can only be
> restored by root if they differ from the current users).
>
>
> Windows, well 'nuf said.

For Windows, you need more than a USENETter.

I know of some programmers who have "carved out a niche", but, they
haven't tried all the packaging methods. They may not make good
candidates for bootstrapping (they may not know the absolute best
install method). It is difficult to find people "who have tried it all".

In the past, these guys were FOSS and they only did enough Windows
to get by. This is their page. MSI is a semi-popular option for
packaging (pretty complicated), and MSIX is the latest version
(not all that popular, only Windows might ship materials like that).

"NSIS"

https://firefox-source-docs.mozilla.org/browser/installer/windows/installer/index.html

That's not going to teach you very much. I don't know whether the installer
scripts are in the Firefox tarball or not. Some of their materials
are kept private.

When msiexec installs the materials in an MSI file, the dates and so on
would be preserved. If you compiled in 2015, the 2015 date is going to be
on the file when it is installed on my machine.

An example of a preservative copy routine, would be the Windows-bundled "robocopy.exe",
which was an employee programming effort that eventually went from
hobby-ware, to being fully supported in the OS. The "DATSO" option
would make a verbatim copy of a 2015 executable for example, nicely
stamped as 2015.

But these folders, these are owned by TrustedInstaller:

C:\Program Files
C:\Program Files (x86)

and you have to copy the TrustedInstaller token from a running "msiexec",
to have TrustedInstaller privileges and write to those folders. You can
attempt to write there, and your writes are "redirected". Without going
into more detail, "bootleg" copying really isn't supported, and even if
you developed a recipe, it could be broken tomorrow because it is not
supported. Nobody does installs using Robocopy.

I have a program that used to be able to make a program
"trusted installer", but that program as well as psexec, no longer work.
Similarly, some of the easy holes that allowed you to hack administrator,
no longer work (I helped one guy on USENET regain his administrator
account using one of those holes -- users can erase Administrator and
lose control!). That is a very nice thing for tech support purposes,
for remote work, but they've been steadily whittling away at the holes.
It means, if I know of one that still works, I have
to be careful to not "advertise it". Or they'll close the hole.

This is why installer packages are popular, as they grind down the
sharp edges for you. Using an actual installer, a popular installer,
Microsoft likely try not to break those.

My mention of Robocopy, is only so you can see a program make
a verbatim copy for you. Robocopy is really a folder-copying program,
so you have to be aware of the purpose, to craft a good syntax.
Be very careful with options such as /MIR (mirror), as mirror has
been used to erase the destination folder. It can do terrible damage,
and do it quickly, with a mis-crafted command.

Manual page:

https://ss64.com/nt/robocopy.html

Actually using it:

https://serverfault.com/questions/420105/robocopy-and-permissions

Paul

Subject: Re: how copy file on linux?
From: Janis Papanagnou
Newsgroups: comp.unix.programmer
Organization: A noiseless patient Spider
Date: Thu, 27 Jun 2024 06:05 UTC
References: 1 2 3 4
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: janis_papanagnou+ng@hotmail.com (Janis Papanagnou)
Newsgroups: comp.unix.programmer
Subject: Re: how copy file on linux?
Date: Thu, 27 Jun 2024 08:05:20 +0200
Organization: A noiseless patient Spider
Lines: 54
Message-ID: <v5ivf2$2jv6s$1@dont-email.me>
References: <v5huk1$2anbd$1@dont-email.me>
<87v81vs57v.fsf@nosuchdomain.example.com> <v5i7vu$28id7$1@dont-email.me>
<v5icd7$2d3iu$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=utf-8
Content-Transfer-Encoding: 7bit
Injection-Date: Thu, 27 Jun 2024 08:05:23 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="15a42d73fd31ef7c7dd6b2f5b41468ba";
logging-data="2751708"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18Pnl1M0BVYlsHUMjJLVdDW"
User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101
Thunderbird/45.8.0
Cancel-Lock: sha1:A/aTY0hywGHDMFeCrnf3xBAmJE0=
X-Enigmail-Draft-Status: N1110
In-Reply-To: <v5icd7$2d3iu$1@dont-email.me>
View all headers

On 27.06.2024 02:40, Thiago Adams wrote:
> Em 6/26/2024 8:24 PM, Lew Pitcher escreveu:
>> (Followup set to comp.unix.programmer)
>>
>> On Wed, 26 Jun 2024 15:35:00 -0700, Keith Thompson wrote:
>>
>>> Thiago Adams <thiago.adams@gmail.com> writes:
>>>> How to copy a file on linux keeping the original file information?
>>>> timestamp etc?
>>>>
>>>> Or in other words the equivalent of CopyFileA from windows.
>>>
>>> comp.unix.programmer is likely to give you better answers. I don't
>>> think POSIX defines any functions that copy files.
>>
>> No, AFAIK, POSIX doesn't define an "all-in-one" file copy function.
>> However, Linux (the OS Thiago asks about) defines a number of them.
>>
>>> If I uunderstand correctly, you want to do the equivalent of "cp -p",
>>
>> Which /can/ be accomplished with POSIX calls
>> - the standard I/O functions (fopen()/open(), fread()/read(),
>> fwrite()/write(), fclose()/close() ) to copy the file data
>> - stat() to obtain the "original file information", and
>> - utime() to set the copy timestamps,
>> - chmod() to set the copy file permissions
>> - chown() to set the file ownership
>>
>> But, perhaps Thiago would be satisfied with just a hardlinked file.
>>
>>> but from C rather than from a shell. You might consider using system(),
>>> but that has some drawbacks, and there are probably better ways.
>>
>>
>
> I am using this to create a "deploy" folder with all files necessary to
> run a program. So on windows I am coping dlls and I think it is a good
> idea to keep the original file attributes . (I am not sure if zip files
> keep that.. I need to check)
>
> On linux I may need to copy some files and I think is is a good idea to
> keep the original attributes as well.

This sounds like you want some shell command line tool or shell script.

IME, to "deploy" a package I have an own directory structure. So 'cp -p'
is the key command (or 'cp -a' if you also have whole directories to be
copied with all contents); this will preserve attributes on the file
system. To preserve them in the bundled package I use the 'tar' command
(that also preserves attributes, as far as possible); e.g. 'tar cvzf'
(see man page for details on options).

Janis

Subject: Re: how copy file on linux?
From: candycanearter07
Newsgroups: comp.unix.programmer
Organization: the-candyden-of-code
Date: Thu, 27 Jun 2024 06:20 UTC
References: 1 2 3 4 5
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: candycanearter07@candycanearter07.nomail.afraid (candycanearter07)
Newsgroups: comp.unix.programmer
Subject: Re: how copy file on linux?
Date: Thu, 27 Jun 2024 06:20:03 -0000 (UTC)
Organization: the-candyden-of-code
Lines: 63
Message-ID: <slrnv7q128.3939.candycanearter07@candydeb.host.invalid>
References: <v5huk1$2anbd$1@dont-email.me>
<87v81vs57v.fsf@nosuchdomain.example.com> <v5i7vu$28id7$1@dont-email.me>
<v5icd7$2d3iu$1@dont-email.me> <D13fO.92832$G9_a.42787@fx13.iad>
Injection-Date: Thu, 27 Jun 2024 08:20:03 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="e4a8255fc3f682775845a775dca336bd";
logging-data="2755924"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19mXIRXnt+/ZiLaXJYSKGrAbWCH4JONbJaEjEUx5wDdlg=="
User-Agent: slrn/1.0.3 (Linux)
Cancel-Lock: sha1:QiJoFG7GNl2t1uIObTb8x7A/JrM=
X-Face: b{dPmN&%4|lEo,wUO\"KLEOu5N_br(N2Yuc5/qcR5i>9-!^e\.Tw9?/m0}/~:UOM:Zf]%
b+ V4R8q|QiU/R8\|G\WpC`-s?=)\fbtNc&=/a3a)r7xbRI]Vl)r<%PTriJ3pGpl_/B6!8pe\btzx
`~R! r3.0#lHRE+^Gro0[cjsban'vZ#j7,?I/tHk{s=TFJ:H?~=]`O*~3ZX`qik`b:.gVIc-[$t/e
ZrQsWJ >|l^I_[pbsIqwoz.WGA]<D
View all headers

Scott Lurndal <scott@slp53.sl.home> wrote at 01:14 this Thursday (GMT):
> Thiago Adams <thiago.adams@gmail.com> writes:
>>Em 6/26/2024 8:24 PM, Lew Pitcher escreveu:
>>> (Followup set to comp.unix.programmer)
>>>
>>> On Wed, 26 Jun 2024 15:35:00 -0700, Keith Thompson wrote:
>>>
>>>> Thiago Adams <thiago.adams@gmail.com> writes:
>>>>> How to copy a file on linux keeping the original file information?
>>>>> timestamp etc?
>>>>>
>>>>> Or in other words the equivalent of CopyFileA from windows.
>>>>
>>>> comp.unix.programmer is likely to give you better answers. I don't
>>>> think POSIX defines any functions that copy files.
>>>
>>> No, AFAIK, POSIX doesn't define an "all-in-one" file copy function.
>>> However, Linux (the OS Thiago asks about) defines a number of them.
>>>
>>>> If I uunderstand correctly, you want to do the equivalent of "cp -p",
>>>
>>> Which /can/ be accomplished with POSIX calls
>>> - the standard I/O functions (fopen()/open(), fread()/read(),
>>> fwrite()/write(), fclose()/close() ) to copy the file data
>>> - stat() to obtain the "original file information", and
>>> - utime() to set the copy timestamps,
>>> - chmod() to set the copy file permissions
>>> - chown() to set the file ownership
>>>
>>> But, perhaps Thiago would be satisfied with just a hardlinked file.
>>>
>>>> but from C rather than from a shell. You might consider using system(),
>>>> but that has some drawbacks, and there are probably better ways.
>>>
>>>
>>
>>I am using this to create a "deploy" folder with all files necessary to
>>run a program. So on windows I am coping dlls and I think it is a good
>>idea to keep the original file attributes . (I am not sure if zip files
>>keep that.. I need to check)
>
> Both the tar(1) and cpio(1) utilities can be used to create a
> compressed deployable archive. They're the most portable way
> to distribute anything and they keep and restore the attributes
> (although the ownership attributes uid and gid can only be
> restored by root if they differ from the current users).

You do have to specify it for tar tho (-p for preserve permissions)

> Windows, well 'nuf said.

I think the /newest/ version of W11 has tar support built in. Not that
W11 is any good.

>>
>>On linux I may need to copy some files and I think is is a good idea to
>>keep the original attributes as well.
>>
>>

--
user <candycane> is generated from /dev/urandom

1

rocksolid light 0.9.8
clearnet tor