2 File operation contexts for the Midnight Commander
4 Copyright (C) 1999-2024
5 Free Software Foundation, Inc.
8 Federico Mena <federico@nuclecu.unam.mx>
9 Miguel de Icaza <miguel@nuclecu.unam.mx>
11 This file is part of the Midnight Commander.
13 The Midnight Commander is free software: you can redistribute it
14 and/or modify it under the terms of the GNU General Public License as
15 published by the Free Software Foundation, either version 3 of the License,
16 or (at your option) any later version.
18 The Midnight Commander is distributed in the hope that it will be useful,
19 but WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 GNU General Public License for more details.
23 You should have received a copy of the GNU General Public License
24 along with this program. If not, see <http://www.gnu.org/licenses/>.
28 * \brief Source: file operation contexts
30 * \author Federico Mena <federico@nuclecu.unam.mx>
31 * \author Miguel de Icaza <miguel@nuclecu.unam.mx>
38 #include "lib/global.h"
39 #include "fileopctx.h"
41 #include "lib/search.h"
42 #include "lib/vfs/vfs.h"
44 /*** global variables ****************************************************************************/
46 /*** file scope macro definitions ****************************************************************/
48 /*** file scope type declarations ****************************************************************/
50 /*** file scope variables ************************************************************************/
52 /*** file scope functions ************************************************************************/
53 /* --------------------------------------------------------------------------------------------- */
55 /* --------------------------------------------------------------------------------------------- */
56 /*** public functions ****************************************************************************/
57 /* --------------------------------------------------------------------------------------------- */
60 * \fn file_op_context_t * file_op_context_new (FileOperation op)
61 * \param op file operation struct
62 * \return The newly-created context, filled with the default file mask values.
64 * Creates a new file operation context with the default values. If you later want
65 * to have a user interface for this, call file_op_context_create_ui().
69 file_op_context_new (FileOperation op
)
71 file_op_context_t
*ctx
;
73 ctx
= g_new0 (file_op_context_t
, 1);
76 ctx
->progress_bytes
= 0;
78 ctx
->stat_func
= mc_lstat
;
80 ctx
->preserve_uidgid
= (geteuid () == 0);
81 ctx
->umask_kill
= (mode_t
) (~0);
82 ctx
->erase_at_end
= TRUE
;
83 ctx
->skip_all
= FALSE
;
88 /* --------------------------------------------------------------------------------------------- */
90 * \fn void file_op_context_destroy (file_op_context_t *ctx)
91 * \param ctx The file operation context to destroy.
93 * Destroys the specified file operation context and its associated UI data, if
98 file_op_context_destroy (file_op_context_t
* ctx
)
102 file_op_context_destroy_ui (ctx
);
103 mc_search_free (ctx
->search_handle
);
108 /* --------------------------------------------------------------------------------------------- */
110 file_op_total_context_t
*
111 file_op_total_context_new (void)
113 file_op_total_context_t
*tctx
;
114 tctx
= g_new0 (file_op_total_context_t
, 1);
115 tctx
->ask_overwrite
= TRUE
;
119 /* --------------------------------------------------------------------------------------------- */
122 file_op_total_context_destroy (file_op_total_context_t
* tctx
)
127 /* --------------------------------------------------------------------------------------------- */