NeoMutt  2020-11-20
Teaching an old dog new tricks
DOXYGEN
quad.h File Reference

Type representing a quad-option. More...

+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Enumerations

enum  QuadOption {
  MUTT_ABORT = -1, MUTT_NO, MUTT_YES, MUTT_ASKNO,
  MUTT_ASKYES
}
 Possible values for a quad-option. More...
 

Functions

int quad_he_toggle (struct ConfigSubset *sub, struct HashElem *he, struct Buffer *err)
 Toggle the value of a quad. More...
 
int quad_str_toggle (struct ConfigSubset *sub, const char *name, struct Buffer *err)
 Toggle the value of a quad. More...
 

Variables

const char * QuadValues []
 Valid strings for creating a QuadValue. More...
 

Detailed Description

Type representing a quad-option.

Authors
  • Richard Russon

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

Definition in file quad.h.

Enumeration Type Documentation

◆ QuadOption

enum QuadOption

Possible values for a quad-option.

Enumerator
MUTT_ABORT 

User aborted the question (with Ctrl-G)

MUTT_NO 

User answered 'No', or assume 'No'.

MUTT_YES 

User answered 'Yes', or assume 'Yes'.

MUTT_ASKNO 

Ask the user, defaulting to 'No'.

MUTT_ASKYES 

Ask the user, defaulting to 'Yes'.

Definition at line 36 of file quad.h.

37 {
38  MUTT_ABORT = -1,
39  MUTT_NO,
40  MUTT_YES,
41  MUTT_ASKNO,
42  MUTT_ASKYES,
43 };
Ask the user, defaulting to 'No'.
Definition: quad.h:41
User aborted the question (with Ctrl-G)
Definition: quad.h:38
Ask the user, defaulting to 'Yes'.
Definition: quad.h:42
User answered 'No', or assume 'No'.
Definition: quad.h:39
User answered 'Yes', or assume 'Yes'.
Definition: quad.h:40

Function Documentation

◆ quad_he_toggle()

int quad_he_toggle ( struct ConfigSubset sub,
struct HashElem he,
struct Buffer err 
)

Toggle the value of a quad.

Parameters
subConfig subset
heHashElem representing config item
errBuffer for error messages
Return values
numResult, e.g. CSR_SUCCESS
See also
quad_toggle()

Definition at line 202 of file quad.c.

203 {
204  if (!sub || !he || !he->data)
205  return CSR_ERR_CODE;
206 
207  struct HashElem *he_base = cs_get_base(he);
208  if (DTYPE(he_base->type) != DT_QUAD)
209  return CSR_ERR_CODE;
210 
211  intptr_t value = cs_he_native_get(sub->cs, he, err);
212  if (value == INT_MIN)
213  return CSR_ERR_CODE;
214 
215  value = quad_toggle(value);
216  int rc = cs_he_native_set(sub->cs, he, value, err);
217 
218  if ((CSR_RESULT(rc) == CSR_SUCCESS) && !(rc & CSR_SUC_NO_CHANGE))
220 
221  return rc;
222 }
#define CSR_SUCCESS
Action completed successfully.
Definition: set.h:35
void cs_subset_notify_observers(const struct ConfigSubset *sub, struct HashElem *he, enum NotifyConfig ev)
Notify all observers of an event.
Definition: subset.c:218
#define DT_QUAD
quad-option (no/yes/ask-no/ask-yes)
Definition: types.h:37
#define DTYPE(x)
Mask for the Data Type.
Definition: types.h:44
#define CSR_RESULT(x)
Definition: set.h:52
intptr_t cs_he_native_get(const struct ConfigSet *cs, struct HashElem *he, struct Buffer *err)
Natively get the value of a HashElem config item.
Definition: set.c:817
struct ConfigSet * cs
Parent ConfigSet.
Definition: subset.h:51
#define CSR_SUC_NO_CHANGE
The value hasn't changed.
Definition: set.h:44
static int quad_toggle(int opt)
Toggle (invert) the value of a quad option.
Definition: quad.c:188
struct HashElem * cs_get_base(struct HashElem *he)
Find the root Config Item.
Definition: set.c:199
Config item has been set.
Definition: subset.h:62
void * data
User-supplied data.
Definition: hash.h:47
int type
Type of data stored in Hash Table, e.g. DT_STRING.
Definition: hash.h:45
The item stored in a Hash Table.
Definition: hash.h:43
#define CSR_ERR_CODE
Problem with the code.
Definition: set.h:36
int cs_he_native_set(const struct ConfigSet *cs, struct HashElem *he, intptr_t value, struct Buffer *err)
Natively set the value of a HashElem config item.
Definition: set.c:706
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ quad_str_toggle()

int quad_str_toggle ( struct ConfigSubset sub,
const char *  name,
struct Buffer err 
)

Toggle the value of a quad.

Parameters
subConfig subset
nameHashElem representing config item
errBuffer for error messages
Return values
numResult, e.g. CSR_SUCCESS
See also
quad_toggle()

Definition at line 233 of file quad.c.

234 {
235  struct HashElem *he = cs_subset_create_inheritance(sub, name);
236 
237  return quad_he_toggle(sub, he, err);
238 }
int quad_he_toggle(struct ConfigSubset *sub, struct HashElem *he, struct Buffer *err)
Toggle the value of a quad.
Definition: quad.c:202
struct HashElem * cs_subset_create_inheritance(const struct ConfigSubset *sub, const char *name)
Create a Subset config item (inherited)
Definition: subset.c:189
The item stored in a Hash Table.
Definition: hash.h:43
+ Here is the call graph for this function:

Variable Documentation

◆ QuadValues

const char* QuadValues[]

Valid strings for creating a QuadValue.

These strings are case-insensitive.

Definition at line 48 of file quad.c.