[MUD]MUDLIB詳解/MUDOS運行流程/最小MUDLIB/mud文件結構


 

現在大部分中文MUD都是在東方故事(esII)基礎上發展起來的,其目錄結構基本一樣, 
也有個別MUD為了標新立異對個別目錄換了個名字以示不同,但其實質沒有什么變化。 
這個做的最可惡的是xkx,把一個好好的daemon目錄換成了一個不土不洋的kungfu, 
里邊卻還是skill,condition這些洋名,簡直讓人faint!我實在看不出這種修改有什么好處, 
除了添麻煩(xkx對一些命令的漢化,什么cha,du...也是如此)。不過, 
也有一些是為了系統更合理而修改的。 
對MUDLIB目錄的解釋已經有許多版本了,基本也沒什么區別,下邊是我的解釋, 
以我自己整理的一份MUDLIB為基礎,如果有目錄不同的地方適當貫通就是了。 

/adm 這里是最基本,最底層的程序,是整個MUD的控制樞紐。 
這個目錄只有admin權限可以修改。 
/adm/daemons 守護程序目錄。守護程序是指游戲中頻繁調用的控制類程序, 
MUD里各種基本功能都是由這些程序控制的。這些程序一般在游戲一啟動就自動載入內存。 
按照unix下文件命名習慣,這里的程序多以d.c結尾, 
比如combatd.c就是控制戰斗的程序。另外由於這些程序調用非常頻繁, 
一般都做了宏定義(查看/include/globals.h),例如/adm/daemons/combatd.c 
定義為COMBAT_D,在其它程序里可以適用這些宏定義代替這些文件名。 
/adm/etc 系統配置目錄,此目錄定義為CONFIG_DIR 這里放的是游戲的系統文檔文件, 
比如游戲的歡迎畫面,巫師列表,BAN掉的IP記錄等。 
/adm/obj 這里只有兩個文件,但卻是整個MUD最重要的東西。 
master.c:這是MudOS主控物件,也就是整個MUD的總司令。 
simul_efun.c:防真函數加載精靈,這是MUD啟動時第一個要載入的東西。 
所謂efun,是指系統函數,也就是mudos中定義的函數。 
這些函數不必做任何說明可以在MUD的任何程序里直接調用, 
而且由於他們是預先定義的,也就是mudos早已經知道他們是做什么的, 
所以比其它在MUDLIB里定義的函數執行效率要高。但他們的缺點是修改非常不方便, 
對任何一個efun函數的修改必須重新編譯mudos才能生效。因此, 
在MUDLIB中又有了防真函數的定義,也就是simul_efun, 
這些函數的作用跟efun完全一樣,不同的是他們定義在UDLIB中,可以隨時修改, 
但必須重新啟動游戲才能生效。 
順便講一下一個MUD啟動的過程,MUD啟動的初始化過程分以下幾步: 
1.載入防真函數simul_efun 
2.載入主控物件master,這里是調用master的create()函數將其載入內存。 
3.載入需要預先載入的守護程序,這里調用master的preload()函數, 
需要預先載入的文件定義在/adm/etc/preload里。 
4.MUD進入多用戶狀態,允許玩家登錄。 
以上過程必須正確無誤的執行完,否則游戲無法正確啟動。 
master.c和simul_efun.c這兩個文件只能在游戲啟動時由mudos自動載入, 
不可以在游戲中用update的方法載入,而且這兩個物件也不 
允許非ROOT權限的物件摧毀(destruct)它,因為他們的摧毀就等於游戲關閉 。 
/adm/simul_efun 防真函數目錄,這里放的是定義各類防真函數的文件, 
這些文件由SIMUL_EFUN_OB(也就是/adm/obj/simul_efun)來載入內存。 

/cmds 游戲命令目錄,這里放的是游戲中可以使用的各種命令, 
只有admin才可以修改這個目錄 
/cmds/adm 只有天神(admin)可以使用的命令 
/cmds/arch 只有大巫師(arch)以上才可以使用的命令 
/cmds/wiz 只有巫師(wizard)以上才可以使用的命令 
/cmds/app 只有巫師學徒(wizard)以上才可以使用的命令 
/cmds/imm 只有榮譽玩家(immortal)以上才可以使用的命令 
/cmds/usr 只有普通玩家(player)以上才可以使用的命令 
/cmds/std 所有生物(npc and player)都可以使用的命令命令目錄采用子集格式, 
權限高的命令完全包含權限低的命令,比如天神可以使用所有游戲命令, 
普通玩家只能使用/cmds/usr和/cmds/std目錄下的命令。 

/data 游戲數據目錄,只有arch以上權限才可以修改這個目錄 
/data/board 各個留言板的數據 
/data/login 玩家登錄數據 
/data/user 玩家檔案,呵呵,這里記錄的是每個玩家的所有勞動成果 
/data/npc 一些特殊npc的數據,比如商店老板 
/data/daemon 重要的系統數據,比如emote詞,英漢翻譯詞典 
/data/mail 玩家信件 

/feature 標准繼承函數。只有admin才可以對這個目錄進行修改這些函數是非常重要的, 
是MUD里各種物件,包括玩家,NPC,物品,房間等的各種功能的標准定義, 
這些函數反映了整個MUD的與眾不同之處,一個好的MUDLIB必然要對這些函數進行優化。 
而要設計新的程序,必須對這個目錄所有文件有所了解。 

/obj 系統物件,這是經常在MUD里被調用的各種物件。 
這個目錄下的物件被復制后跟調用他的物件具有相同的euid, 
也就是說具有相同的權限,所以,這里的一個npc如果經admin編譯后復制出來, 
也具有了admin權限。這點非常重要,有些物件必須具有跟玩家相同的euid才能正常使用 
,比如符紙。而出於安全考慮,這個目錄下的物件不可以隨便復制。 
只有arch以上才可以修改此目錄。 
/obj/board 游戲中各個留言板 
/obj/npc 一些特殊的NPC 
/obj/sheet 各種符紙 
/obj/weapons 兵器 
/obj/misc 其它亂七八糟的東西,比如信箱等 

/quest 游戲里各種任務quest的文件,此目錄需要wizard以上權限才可以修改 

/binaries 文件編譯過程生成的二進制文件,此目錄ROOT權限才可以修改 

/d 區域目錄,游戲的地圖門派和NPC存放的地方。此目錄wizard以上權限可以修改。 
這里是整個MUDLIB最簡單最常用的東西,也是玩家可以直接接觸到的東西。 
玩家所呆的任何一個房間都應該對應這個目錄下的一個文件, 
房間里每個NPC也都對應一個文件。這個目錄下存在許多子目錄, 
分別對應游戲的不同區域(domain)。 
/d/domain/npc 該區域中的npc 
/d/domain/npc/obj 該區域中npc身上的物品 
/d/domain/obj 該區域中的物品 

/data_bak 檔案備份目錄,保存需要備份的重要數據。admin可以修改 

/include 頭文件目錄,只有admin可以修改。這里放的是游戲中各個文件所需要的頭文件, 
其中以下幾個特別重要: 
globals.h:全局定義的頭文件,這是一個特殊的頭文件, 
他不需要在任何一個文件里被調用,但是這里定義的所有變量可以在任何一個文件里直接使用。 
這里一般用來定義非常重要的或者許多地方需要調用 
的變量。對這個文件的修改必須重新啟動游戲才可以生效。command.h: 
這里定義的是各個權限等級所能夠使用的命令目錄,所以,除了admin, 
應該絕對禁止任何人修改此文件。 
/include/race 種族的頭文件 
/include/net 網絡功能的頭文件 

/open 系統臨時目錄,ftp登陸目錄,任何人都具有寫權限。 

/questobj FY3的task專門目錄,存放各個task物品文件。wizard以上權限可以修改。 

/u 巫師工作目錄,存放各個巫師開發過程的半成品。 
這里的子目錄名只能為各個巫師的euid, 
而只有對應euid的人才有對相應目錄的修改權限。比如一個目錄是lion, 
那么只有lion這個ID或者比lion權限高的人 
才可以修改它下邊的內容。 

/clone 物品目錄,存放游戲中需要經常復制的各種物品,wizard以上權限可以寫。 
這個目錄下的物品一般被其他地方復制(clone)出來,但他們的euid是固定的, 
不會隨調用它的物件的不同而改變,這就是這個目錄和/obj目錄的最大不同。 
此目錄arch以上等級可以修改 
/clone/armor 裝備 
/clone/drug 葯品 
/clone/fruit 水果,水果跟食物的不同是吃了可以同時加食物和飲水, 
而且有些水果具有養顏美容之功效。 
/clone/liquid 容器,象酒袋茶壺一類 
/clone/money 顧名思義,人見人愛的東西 
/clone/user 玩家物件,包括login.c(link_ob)和user.c(body), 
此目錄只有admin可以修改 
/clone/books 各種秘籍 
/clone/food 吃的 
/clone/gift 各種禮物,一般是好東東 
/clone/weapon 兵器 
/clone/misc 其他雜物,比如屍體,頭顱。 

/daemon 呵呵,這個目錄為什么叫這個名字我一直沒明白,看下邊的說明吧。 
此目錄只有arch以上可以修改。 
/daemon/skill 游戲中所有的技能 
/daemon/condition 人物各種狀態,比如中毒,恢復等。 
/daemon/class 這個應該理解為“組織”或“工會”,是ESII從外國MUD里保留下來的東西, 
不過隨着中文MUD的發展,工會的概念逐漸被淡化,其含義已經跟以前完全不同, 
現在他的意思有點象“身份”,比如道士,和尚,喇嘛,官兵,老百姓。。。。 
個人有個人的身份。很多情況下,這個跟門派類似,但又不完全相同。 
這里存放的是各種不同身份的人所具有的特殊東西, 
不過現在一般用來存放各種特殊技能的特殊用法(perform) 

/doc 文檔。 游戲中的各種文本文件,arch以上可以修改 
/doc/help 各種幫助文件 
/doc/efuns 各種系統函數的用法 
/doc/story 各種背景故事 

/log 系統日記,記錄游戲過程各種重要事件,是巫師處理糾紛和剔除bug的主要依據來源。 
一個好的巫師應該養成經常看系統日記的習慣。本目錄只有ROOT權限可以修改。 

/p 玩家目錄,這個目錄下內容玩家具有寫的權限。主要存放需要玩家修改的內容, 
比如玩家房間,自創武功等。 

/std 標准對象目錄,游戲中各種標准物件, 
只有admin可以修改游戲里其他物件都需要繼承這里的相應文件。 
/std/armor 裝備物品的標准繼承,比如衣服,盔甲等 
/std/board 留言板 
/std/char 生物的標准繼承,MUD里的生物包含兩種:玩家(player)和非玩家( 
npc)他們都需要繼承/std/char/char.c這個對象, 
他們與其他物件的區別是具有心跳(heartbeat)。 
/std/drug 葯品的標准繼承,其實這個現在一般不用了,這部分功能都放到了 
/feature的相應文件里,保留這個是為了跟舊的系統兼容。 
/std/item 物品的標准繼承 
/std/room 房間的標准繼承 
有人曾問房間和物品到底有什么區別?說實話,這個問題還真不好說, 
這兩個物件基本結構差不多,也沒有什么可以區分的特征。 
現在的常用判斷方法是房間是沒有環境(environment)的,但也不是所有物品 
(包括生物)都有環境,所以,呵呵,這個問題還有待MUD程序的進一步完善, 
現在基本上無法判斷。 
/std/skill 技能的標准繼承 
/std/weapon 武器的標准繼承 
/std/misc 其他物件,比如錢,符紙。 
值得注意的是,/std這個目錄跟一般MUDLIB的結構不太一樣, 
一般MUDLIB並沒有如此歸類存放,大家可以根據自己的認識加以判斷。 

以上是根據我的理解對各個目錄的解釋,未必是權威的說法, 
只是為了讓大家有所認識,如果有什么錯誤請指正。 
作為剛入門的新巫師,准確理解各個目錄的作用是非常重要的, 
必須知道哪個目錄下的東西是做什么的,哪個目錄你可以去改,哪個目錄你不能動。 
一般來說,要成為一個合格的巫師,至少要花半月時間來“讀”程序, 
了解整個MUDLIB的結構,了解各個文件的作用 
(未必要完全看懂,但至少應該知道他是干什么的), 
這樣不至於再以后的程序開放過程中不知道什么功能該如何實現,從而走許多彎路。 
當你了解了整個MUDLIB后就可以試着自己寫程序了, 
一般你只能在自己的工作目錄里寫東西。剛開始不妨試着寫一個簡單的房間, 
然后試着寫一個簡單的npc,然后試着把這個npc放到這個房間里。。。。。。 
這樣逐漸提高,你很快就成為一個合格的巫師了。
參考資料:烈火西游 http://218.200.132.6:6666/list.asp?id=248

 

--------------------------------------------

mudos運行流程

今天我看了站上的一些文章,加上查看原程序,把mudos啟動后,程序運行的流程搞清楚了。小弟覺得只要有一個好的mudos,就可寫出新的mudlib 框架。我拿用戶連接來解釋程序的運行流程。

在config.xxx文件中指出了master和global兩個文件,這是十分重要的文件。
mudos啟動后會加載上述兩個文件(其它文件也有,但上述文件為主要 )
進入內存,mudos中定義了一些特殊的函數,例如create()、init()等等, 
這些函數都是在特定事件中由mudos自動調用的。
當用戶在port口請求連接的時候:
——mudos自動調用master.c中的connect()函數
——然后connect()函數調用 LOGIN_OB這個物件,[而LOGIN_OB是個物件常量,在global.h中定義LOGIN_OB 的值是"/clone/user/login.c",也就是說connect()調用了login.c這個物件]
——在login.c中有一些特殊函數,如果按照用戶正確登陸的流程,mudos自動調用login.c中logon()這個特殊函數。
——在logon()中由調用LOGIN_D這一物件常量,LOGIN_D在global.h文件中所定義的值是"/adm/daemons/logind",
——於是 mudos又把logind.c調入內存並運行。

我們一般認為mudos在編譯前在它的設置文件中定義了用戶login的程序 路徑及文件名,
編譯后路徑和文件名不可改,在用戶連入的時候,mudos根據 路徑自動啟動用戶登陸程序。
其實非也,mudos只是一個對mud進行低級支持 的程序。

我們可以利用mudos,完全拋棄已有的mudlib框架,進行新的創作。
這樣 才能使中國的mud種類走向多樣化。

-------------------------------------------=

最小Mudib有多大?

這個最小的是說能驅動MUDOS,能成功Connected.
現在以網上下載的單機專用MUDOS和其配制的config.cfg為標准說明:
先找一個單獨的MUDOS運行,需要配置文件,加載config.cfg...運行后提示:open log/debug.log file failed.OK,根椐配置我們建目錄:/log,再運行,現在提示:The simul_efun file adm/obj/simul_efun.c was not loaded.OK,我們建目錄:/adm/obj,並在obj目錄中建一個空文件simul_efun.c,再運行,現在是:adm/obj/simul_efun.c line 0: Cannot #i nclude globals.h
adm/obj/simul_efun.c line 1: parse error
No error handler for error: *Error in loading object '/adm/obj/simul_efun'
program: (none), object: (none), ..file: (none)
The simul_efun (/adm/obj/simul_efun) and master (/adm/obj/master) objects must be loadable.
看來現要config.h文件,根椐配置文件,我們建一個目錄:/include,並在此目錄中加一個空文件globals.h,再運行:The master file /adm/obj/master was not loaded.,現在我們在obj目錄中建一個空文件master.運行:No function get_root_uid() in master object; possibly the mudlib doesn't want PACKAGE_UIDS to be defined.看來空的master.c不行了,我們在master.c中加上如下語句:string get_root_uid() { return "Root"; }
string get_bb_uid() { return "Backbone"; }
string creator_file(string file) { return "Root"; },現在再運行,OK,MUDOS成功跑起來了.

但現在用zMUD連線connected后就lose了,怎么辦,現在在master.c中加一如下語句:object connect(int port)
{
     object ob;

     ob = new(__DIR__"user.c");
     return ob;
}.同時在master.c相同目錄中新建一個空文件user.c,現在運行mudos,並連線,成功...

      現在看看一共用了哪些文件和目錄?
1. /log
2. /adm/obj/simul_efun.c
3. /include/globals.h
4. /adm/obj/master.c
5. /adm/obj/user.c

其中只有master.c中有內容,其它的都是空的,這5個加起來有多大?237字節,怎么樣?


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM