/* $Id: olc_mpcode.c,v 1.666 2004/09/20 10:50:30 shrike Exp $ */ /************************************************************************************ * Copyright 2004 Astrum Metaphora consortium * * * * 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. * * * ************************************************************************************/ /************************************************************************************ * ANATOLIA 2.1 is copyright 1996-1997 Serdar BULUT, Ibrahim CANPUNAR * * ANATOLIA has been brought to you by ANATOLIA consortium * * Serdar BULUT {Chronos} bulut@rorqual.cc.metu.edu.tr * * Ibrahim Canpunar {Asena} canpunar@rorqual.cc.metu.edu.tr * * Murat BICER {KIO} mbicer@rorqual.cc.metu.edu.tr * * D.Baris ACAR {Powerman} dbacar@rorqual.cc.metu.edu.tr * * By using this code, you have agreed to follow the terms of the * * ANATOLIA license, in the file Anatolia/anatolia.licence * ***********************************************************************************/ /************************************************************************************ * Original Diku Mud copyright (C) 1990, 1991 by Sebastian Hammer, * * Michael Seifert, Hans Henrik St{rfeldt, Tom Madsen, and Katja Nyboe. * * * * Merc Diku Mud improvments copyright (C) 1992, 1993 by Michael * * Chastain, Michael Quan, and Mitchell Tse. * * * * In order to use any part of this Merc Diku Mud, you must comply with * * both the original Diku license in 'license.doc' as well the Merc * * license in 'license.txt'. In particular, you may not remove either of * * these copyright notices. * * * * Much time and thought has gone into this software and you are * * benefitting. We hope that you share your changes too. What goes * * around, comes around. * ************************************************************************************/ /************************************************************************************ * ROM 2.4 is copyright 1993-1995 Russ Taylor * * ROM has been brought to you by the ROM consortium * * Russ Taylor (rtaylor@pacinfo.com) * * Gabrielle Taylor (gtaylor@pacinfo.com) * * Brian Moore (rom@rom.efn.org) * * By using this code, you have agreed to follow the terms of the * * ROM license, in the file Rom24/doc/rom.license * *************************************************************************************/ /************************************************************************************ * Copyright (c) 1998 fjoe <fjoe@iclub.nsu.ru> * * All rights reserved. * * * * Redistribution and use in source and binary forms, with or without * * modification, are permitted provided that the following conditions * * are met: * * 1. Redistributions of source code must retain the above copyright * * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * * notice, this list of conditions and the following disclaimer in the * * documentation and/or other materials provided with the distribution. * * * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * * SUCH DAMAGE. * ************************************************************************************/ /* The following code is based on ILAB OLC by Jason Dinkel */ /* Mobprogram code by Lordrom for Nevermore Mud */ #include <sys/types.h> #include <ctype.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <time.h> #include "merc.h" #include "olc.h" #define EDIT_MPCODE(ch, mpcode) (mpcode = (MPCODE*) ch->desc->pEdit) extern MPCODE *get_prog_index(int vnum, int type); /* Mobprog editor */ DECLARE_OLC_FUN(mped_create ); DECLARE_OLC_FUN(mped_edit ); DECLARE_OLC_FUN(mped_touch ); DECLARE_OLC_FUN(mped_show ); DECLARE_OLC_FUN(mped_list ); DECLARE_OLC_FUN(mped_code ); olc_cmd_t olc_cmds_mpcode[] = { /* { command function }, */ { "create", mped_create, 5 }, { "edit", mped_edit, 0 }, { "touch", mped_touch, 0 }, { "show", mped_show, 0 }, { "list", mped_list, 0 }, { "code", mped_code, 5 }, { "commands", show_commands, 0 }, { NULL } }; OLC_FUN(mped_create) { MPCODE *mpcode; int value; AREA_DATA *pArea; char arg[MAX_STRING_LENGTH]; one_argument(argument, arg, sizeof(arg)); value = atoi(arg); if (!value) { do_help(ch, "'OLC CREATE'"); return FALSE; } pArea = area_vnum_lookup(value); if (!pArea) { char_puts("MPEd: That vnum is not assigned an area.\n", ch); return FALSE; } if (!IS_BUILDER(ch, pArea)) { char_puts("MPEd: Insufficient security.\n", ch); return FALSE; } if (mpcode_lookup(value)) { char_puts("MPEd: vnum already exists.\n", ch); return FALSE; } mpcode = mpcode_new(); mpcode->vnum = value; mpcode_add(mpcode); ch->desc->pEdit = (void *)mpcode; OLCED(ch) = olced_lookup(ED_MPCODE); touch_area(pArea); char_puts("MPEd: mpcode created.\n", ch); return FALSE; } OLC_FUN(mped_edit) { MPCODE *mpcode; AREA_DATA *pArea; int value; char arg[MAX_INPUT_LENGTH]; one_argument(argument, arg, sizeof(arg)); if (arg[0] == '\0') { do_help(ch, "'OLC EDIT'"); return FALSE; } value = atoi(arg); mpcode = mpcode_lookup(value); if (!mpcode) { char_puts("MPEd: Vnum does not exist.\n", ch); return FALSE; } pArea = area_vnum_lookup(mpcode->vnum); if (!IS_BUILDER(ch, pArea)) { char_puts("MPEd: Insufficient security.\n", ch); return FALSE; } ch->desc->pEdit = (void*) mpcode; OLCED(ch) = olced_lookup(ED_MPCODE); return FALSE; } OLC_FUN(mped_touch) { MPCODE *mpcode; EDIT_MPCODE(ch, mpcode); return touch_vnum(mpcode->vnum); } OLC_FUN(mped_show) { MPCODE *mpcode; char arg[MAX_INPUT_LENGTH]; one_argument(argument, arg, sizeof(arg)); if (arg[0] == '\0') { if (IS_EDIT(ch, ED_MPCODE)) EDIT_MPCODE(ch, mpcode); else { do_help(ch, "'OLC ASHOW'"); return FALSE; } } else { int value = atoi(arg); mpcode = mpcode_lookup(value); if (!mpcode) { char_puts("MPEd: Vnum does not exist.\n", ch); return FALSE; } } char_printf(ch, "Vnum: [%d]\n" "Code:\n%s\n", mpcode->vnum, mpcode->code); return FALSE; } OLC_FUN(mped_list) { int count = 1; MPCODE *mpcode; BUFFER *buffer; bool fAll = !str_cmp(argument, "all"); char blah; AREA_DATA *ad; buffer = buf_new(-1); for (mpcode = mpcode_list; mpcode !=NULL; mpcode = mpcode->next) if (fAll || ENTRE(ch->in_room->area->min_vnum, mpcode->vnum, ch->in_room->area->max_vnum)) { ad = area_vnum_lookup(mpcode->vnum); if (ad == NULL) blah = '?'; else if (IS_BUILDER(ch, ad)) blah = '*'; else blah = ' '; buf_printf(buffer, "[%6d] (%c) %5d\n", count, blah, mpcode->vnum); count++; } if (count == 1) { if (fAll) buf_add(buffer, "No mobprogs found.\n"); else buf_add(buffer, "No mobprogs found in this area.\n"); } page_to_char(buf_string(buffer), ch); buf_free(buffer); return FALSE; } OLC_FUN(mped_code) { MPCODE *mpcode; EDIT_MPCODE(ch, mpcode); return olced_str_text(ch, argument, cmd, &mpcode->code); }