function

append . files . sncode

VERSIONlatest is used to copy/append file

APPEND

NAME

append - is used to copy/append file

SYNOPSIS

append([permissions:integer, owner:"rwx", group:"rwx", other:"rwx",][append:true|false,create:true|false,error:variable]"src filename", "dst filename")

append([permissions:integer, owner:"rwx", group:"rwx", other:"rwx",][append:true|false,create:true|false,error:variable]src:"src filename", dst:"dst filename")

DESCRIPTION

This function is used to copy a file and append it in a destination file. "Append" means to join or to add something at the end: hence, it concatenates files.

If the argument to "append" is true and if the destination exists, then it will append to the file.

If the argument to "create" is false and if the destination file does not exist, the file won't be created.

File are copied from the root of the file system.

The root of the filesystem is defined in the configuration file. See ExtensoConfig for more information.

ExtensoConfig

The permissions of the destination file can be specified using permissions:

permissions:UREAD|UWRITE

or other permissions can be added using owner, group or other.

group:"rw" will add read and write permission to the group of the directory.

Include file "/includes/extenso.sn" contains definitions for permissions:

%include "/includes/extenso.sn";

{_{
// Definitions for function stat
%define FILE_SOURCE_PERMS   0x1000;                             // Copy source file's permissions

// Definitions for set file permissions
%define USETID                  0x8000;                                 /* Set user id */
%define UREAD                   0x0400;                                 /* Read by user */
%define UWRITE                  0x0200;                                 /* Write by user */
%define UEXECUTE                0x0100;                                 /* Execute by user */

%define GSETID                  0x4000;                                 /* Set group id */
%define GREAD                   0x0040;                                 /* Read by group */
%define GWRITE                  0x0020;                                 /* Write by group */
%define GEXECUTE            0x0010;                                     /* Execute by group */

%define WSTICKY                 0x2000;                                 /* Sticky bit */
%define WREAD                   0x0004;                                 /* Read by others */
%define WWRITE                  0x0002;                                 /* Write by others */
%define WEXECUTE                0x0001;                                 /* Execute by others */

%define OS_DEFAULT              0x0FFF;                                 /* use OS's default permissions */

}}

EXAMPLES

Note: In the followings examples, the _ between the { should be removed to make it work.

res={_{ copy("a", "b"); }}. return .*open src.*));
res={_{ copy(create:false, "c1", "b"); }}. return .*stat dst .*
res={_{ copy(append:false, "/tests/c1", "/tests/c2"); size("/tests/c1") == size("/tests/c2"); }}. return res=true.
res={_{ copy(src:"/tests/c1", "/tests/c2"); 2*size("/tests/c1") == size("/tests/c2");}}. return res=true.
res={_{ copy(src:"/tests/c1", dst:"/tests/c2"); 3*size("/tests/c1") == size("/tests/c2");}}. return res=true.
res={_{ copy(append:false,src:"/tests/c1", dst:"/tests/c2"); size("/tests/c1") == size("/tests/c2");}}. return res=true.
res={_{ copy(create:false,src:"/tests/c1", dst:"/tests/c3"); size("/tests/c1") == size("/tests/c2");}}. return .*stat dst.*

AUTHOR

Written by Pierre Laplante, <laplante@sednove.com>