File: gui_file_action.h

package info (click to toggle)
crystal-facet-uml 1.63.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 21,640 kB
  • sloc: ansic: 109,610; xml: 3,085; makefile: 138; sh: 113
file content (85 lines) | stat: -rw-r--r-- 2,653 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/* File: gui_file_action.h; Copyright and License: see below */

#ifndef GUI_FILE_ACTION_H
#define GUI_FILE_ACTION_H

/* public file for the doxygen documentation: */
/*!
 *  \file
 *  \brief Switches the currently used data_file
 */

#include "gui_simple_message_to_user.h"
#include "wrap/gui_button.h"
#include "io_data_file.h"
#include "ctrl_controller.h"
#include "gui_gtk.h"

/*!
 *  \brief attributes of the file manager
 */
struct gui_file_action_struct {
    ctrl_controller_t *controller;  /*!< pointer to external ctrl_controller_t */
    io_data_file_t *data_file;  /*!< pointer to external io_data_file_t */
    gui_simple_message_to_user_t *message_to_user;  /*!< pointer to external gui_simple_message_to_user_t */
};

typedef struct gui_file_action_struct gui_file_action_t;

/*!
 *  \brief initializes the main window
 *
 *  \param this_ pointer to own object attributes
 *  \param controller pointer to the controller object to use
 *  \param data_file pointer to the data_file object to use
 *  \param message_to_user pointer to the message_to_user object to use
 */
void gui_file_action_init( gui_file_action_t *this_,
                           ctrl_controller_t *controller,
                           io_data_file_t *data_file,
                           gui_simple_message_to_user_t *message_to_user
                         );

/*!
 *  \brief destroys the main window
 *
 *  \param this_ pointer to own object attributes
 */
void gui_file_action_destroy( gui_file_action_t *this_ );

/*!
 *  \brief switches the data_file to the new file
 *
 *  \param this_ pointer to own object attributes
 *  \param filename filename of the file to open, must not be NULL
 */
u8_error_t gui_file_action_use_db( gui_file_action_t *this_, const char *filename );

/*!
 *  \brief saves the data_file
 *
 *  Errors are reported directly to the user via (*this_).message_to_user.
 *
 *  \param this_ pointer to own object attributes
 *  \return U8_ERROR_NONE if save was successful
 */
u8_error_t gui_file_action_save( gui_file_action_t *this_ );

#endif  /* GUI_FILE_ACTION_H */


/*
Copyright 2016-2025 Andreas Warnke

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/