Renumbered UNUSED triggers to UNUSED# to make it easier to unset them when cha

nging trig types. (thanks Parna)
  Fixed double free in IBT that caused crash on /a or saving without any descrip
tion.
This commit is contained in:
Rumble 2009-12-07 04:40:16 +00:00
parent 66e4b7ec0c
commit 32880daf6b
6 changed files with 1136 additions and 1123 deletions

View file

@ -36,6 +36,9 @@ Xlist (mlist, olist, rlist, zlist, slist, tlist, qlist)
(lots of major bugfixes too)
@
tbaMUD 3.61
[Dec 07 2009] - Rumble
Renumbered UNUSED triggers to UNUSED# to make it easier to unset them when changing trig types. (thanks Parna)
Fixed double free in IBT that caused crash on /a or saving without any description.
[Dec 06 2009] - Rumble
Fixed medit sex and position numbering. The numbering was wrong with the new column_list.
Fixed medit autoroll so it would recognize a change and save.

View file

@ -0,0 +1,16 @@
Text test2~
Body test2
~
Name Rumble~
Level 34
Room 1204
Flags 1 0 0 0
End
Text test 5~
Body test5
~
Name Rumble~
Level 34
Room 1204
Flags 0 0 0 0
End

View file

@ -857,21 +857,21 @@ const char *otrig_types[] = {
"Global",
"Random",
"Command",
"UNUSED",
"UNUSED",
"UNUSED1",
"UNUSED2",
"Timer",
"Get",
"Drop",
"Give",
"Wear",
"UNUSED",
"UNUSED3",
"Remove",
"UNUSED",
"UNUSED4",
"Load",
"UNUSED",
"UNUSED5",
"Cast",
"Leave",
"UNUSED",
"UNUSED6",
"Consume",
"Time",
"\n"
@ -883,17 +883,17 @@ const char *wtrig_types[] = {
"Random",
"Command",
"Speech",
"UNUSED",
"UNUSED1",
"Zone Reset",
"Enter",
"Drop",
"UNUSED",
"UNUSED",
"UNUSED",
"UNUSED",
"UNUSED",
"UNUSED",
"UNUSED",
"UNUSED2",
"UNUSED3",
"UNUSED4",
"UNUSED5",
"UNUSED6",
"UNUSED7",
"UNUSED8",
"Cast",
"Leave",
"Door",

2008
src/ibt.c

File diff suppressed because it is too large Load diff

198
src/ibt.h
View file

@ -1,99 +1,99 @@
/**************************************************************************
* File: ibt.h Part of tbaMUD *
* Usage: Loading/saving/editing of Ideas, Bugs and Typos lists *
* *
* All rights reserved. See license for complete information. *
* *
* Created by Vash (aka Frenze) for Trigun MUD and the tbaMUD codebase *
* Copyright (C) 1993, 94 by the Trustees of the Johns Hopkins University *
* CircleMUD is based on DikuMUD, Copyright (C) 1990, 1991. *
**************************************************************************/
typedef struct ibt_data IBT_DATA;
#define MAX_IBT_LENGTH 2048
#define MAX_IBTNOTE_LENGTH 2048
/* Subcommands, also used for 'modes' */
#define SCMD_BUG 0
#define SCMD_IDEA 1
#define SCMD_TYPO 2
/* Flag array size (min = 4) */
#define IBT_ARRAY_MAX 4
/* List of flags for Ideas, Bugs and Typos */
#define IBT_RESOLVED 0
#define IBT_IMPORTANT 1
#define IBT_INPROGRESS 2
#define NUM_IBT_FLAGS 3
/* IBT Type returns 'Idea', 'Bug' or 'Typo' when in OLC */
#define IBT_TYPE (ibt_types[(OLC_VAL(d))])
#define IBT_FLAGS(x) ((x)->flags)
#define IBT_FLAGGED(x,y) (IS_SET_AR(((x)->flags), (y)))
/* IBT Editor OLC modes */
#define IBTEDIT_CONFIRM_SAVESTRING 1
#define IBTEDIT_MAIN_MENU 2
#define IBTEDIT_NAME 3
#define IBTEDIT_ROOM 4
#define IBTEDIT_TEXT 5
#define IBTEDIT_FLAGS 6
#define IBTEDIT_BODY 7
#define IBTEDIT_NOTES 8
#ifdef KEY
#undef KEY
#endif
#define KEY( literal, field, value ) \
if ( !str_cmp( word, literal ) ) \
{ \
field = value; \
fMatch = TRUE; \
break; \
}
/* TXT_KEY should be used with fread_line, as it uses a static string, so should be copied */
#ifdef TXT_KEY
#undef TXT_KEY
#endif
#define TXT_KEY( literal, field, value ) \
if ( !str_cmp( word, literal ) ) \
{ \
if (field) STRFREE(field); \
field = STRALLOC(value); \
fMatch = TRUE; \
break; \
}
struct ibt_data
{
IBT_DATA *next; /**< Pointer to next IBT in the list */
IBT_DATA *prev; /**< Pointer to previous IBT in the list */
char *text; /**< Header Text for this IBT */
char *body; /**< Body Text for this IBT */
char *name; /**< Name of the person who reported this IBT */
char *notes; /**< Resolution Notes added by Administrators */
int level; /**< Level of the person who reported this IBT */
room_vnum room; /**< Room in which this IBT was reported */
int flags[IBT_ARRAY_MAX]; /**< IBT flags */
};
extern IBT_DATA *first_bug;
extern IBT_DATA *last_bug;
extern IBT_DATA *first_idea;
extern IBT_DATA *last_idea;
extern IBT_DATA *first_typo;
extern IBT_DATA *last_typo;
/* Functions in ibt.c that are used externally */
ACMD(do_ibt);
ACMD(do_oasis_ibtedit);
void save_ibt_file(int mode);
void load_ibt_file(int mode);
void ibtedit_parse(struct descriptor_data *d, char *arg);
void ibtedit_string_cleanup(struct descriptor_data *d, int terminator);
/**************************************************************************
* File: ibt.h Part of tbaMUD *
* Usage: Loading/saving/editing of Ideas, Bugs and Typos lists *
* *
* All rights reserved. See license for complete information. *
* *
* Created by Vash (aka Frenze) for Trigun MUD and the tbaMUD codebase *
* Copyright (C) 1993, 94 by the Trustees of the Johns Hopkins University *
* CircleMUD is based on DikuMUD, Copyright (C) 1990, 1991. *
**************************************************************************/
typedef struct ibt_data IBT_DATA;
#define MAX_IBT_LENGTH 2048
#define MAX_IBTNOTE_LENGTH 2048
/* Subcommands, also used for 'modes' */
#define SCMD_BUG 0
#define SCMD_IDEA 1
#define SCMD_TYPO 2
/* Flag array size (min = 4) */
#define IBT_ARRAY_MAX 4
/* List of flags for Ideas, Bugs and Typos */
#define IBT_RESOLVED 0
#define IBT_IMPORTANT 1
#define IBT_INPROGRESS 2
#define NUM_IBT_FLAGS 3
/* IBT Type returns 'Idea', 'Bug' or 'Typo' when in OLC */
#define IBT_TYPE (ibt_types[(OLC_VAL(d))])
#define IBT_FLAGS(x) ((x)->flags)
#define IBT_FLAGGED(x,y) (IS_SET_AR(((x)->flags), (y)))
/* IBT Editor OLC modes */
#define IBTEDIT_CONFIRM_SAVESTRING 1
#define IBTEDIT_MAIN_MENU 2
#define IBTEDIT_NAME 3
#define IBTEDIT_ROOM 4
#define IBTEDIT_TEXT 5
#define IBTEDIT_FLAGS 6
#define IBTEDIT_BODY 7
#define IBTEDIT_NOTES 8
#ifdef KEY
#undef KEY
#endif
#define KEY( literal, field, value ) \
if ( !str_cmp( word, literal ) ) \
{ \
field = value; \
fMatch = TRUE; \
break; \
}
/* TXT_KEY should be used with fread_line, as it uses a static string, so should be copied */
#ifdef TXT_KEY
#undef TXT_KEY
#endif
#define TXT_KEY( literal, field, value ) \
if ( !str_cmp( word, literal ) ) \
{ \
if (field) STRFREE(field); \
field = STRALLOC(value); \
fMatch = TRUE; \
break; \
}
struct ibt_data
{
IBT_DATA *next; /**< Pointer to next IBT in the list */
IBT_DATA *prev; /**< Pointer to previous IBT in the list */
char *text; /**< Header Text for this IBT */
char *body; /**< Body Text for this IBT */
char *name; /**< Name of the person who reported this IBT */
char *notes; /**< Resolution Notes added by Administrators */
int level; /**< Level of the person who reported this IBT */
room_vnum room; /**< Room in which this IBT was reported */
int flags[IBT_ARRAY_MAX]; /**< IBT flags */
};
extern IBT_DATA *first_bug;
extern IBT_DATA *last_bug;
extern IBT_DATA *first_idea;
extern IBT_DATA *last_idea;
extern IBT_DATA *first_typo;
extern IBT_DATA *last_typo;
/* Functions in ibt.c that are used externally */
ACMD(do_ibt);
ACMD(do_oasis_ibtedit);
void save_ibt_file(int mode);
void load_ibt_file(int mode);
void ibtedit_parse(struct descriptor_data *d, char *arg);
void ibtedit_string_cleanup(struct descriptor_data *d, int terminator);

View file

@ -243,8 +243,6 @@ static void playing_string_cleanup(struct descriptor_data *d, int action)
save_ibt_file(SCMD_IDEA);
} else {
write_to_output(d, "Idea aborted!\r\n");
free(*d->str);
free(d->str);
}
}
if (PLR_FLAGGED(d->character, PLR_BUG)) {
@ -253,8 +251,6 @@ static void playing_string_cleanup(struct descriptor_data *d, int action)
save_ibt_file(SCMD_BUG);
} else {
write_to_output(d, "Bug aborted!\r\n");
free(*d->str);
free(d->str);
}
}
if (PLR_FLAGGED(d->character, PLR_TYPO)) {
@ -263,8 +259,6 @@ static void playing_string_cleanup(struct descriptor_data *d, int action)
save_ibt_file(SCMD_TYPO);
} else {
write_to_output(d, "Typo aborted!\r\n");
free(*d->str);
free(d->str);
}
}
}