rom24-quickmud-python 2.1.2__py3-none-any.whl → 2.2.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/METADATA +63 -38
- {rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/RECORD +6 -6
- {rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/WHEEL +0 -0
- {rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/entry_points.txt +0 -0
- {rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/licenses/LICENSE +0 -0
- {rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/top_level.txt +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: rom24-quickmud-python
|
|
3
|
-
Version: 2.
|
|
3
|
+
Version: 2.2.0
|
|
4
4
|
Summary: A modern Python port of the ROM 2.4b6 MUD engine with full telnet server and JSON world loading
|
|
5
5
|
Author-email: Mark Jedrzejczyk <mark.jedrzejczyk@gmail.com>
|
|
6
6
|
Maintainer-email: Mark Jedrzejczyk <mark.jedrzejczyk@gmail.com>
|
|
@@ -158,7 +158,7 @@ python -m mud # Start development server
|
|
|
158
158
|
|
|
159
159
|
## 🎯 Project Status
|
|
160
160
|
|
|
161
|
-
- **Version**: 2.
|
|
161
|
+
- **Version**: 2.2.0 (Production Ready)
|
|
162
162
|
- **ROM 2.4b Parity**: 100% (227/227 behavioral tests passing)
|
|
163
163
|
- **ROM C Function Coverage**: 96.1% (716/745 functions mapped)
|
|
164
164
|
- **Test Coverage**: 1435/1436 tests passing (99.93% success rate)
|
|
@@ -275,54 +275,79 @@ The `mud/models` package defines dataclasses used by the game engine.
|
|
|
275
275
|
They mirror the JSON schemas in `schemas/` and supply enums and registries
|
|
276
276
|
for loading and manipulating area, room, object, and character data.
|
|
277
277
|
|
|
278
|
-
##
|
|
278
|
+
## Enhancement Opportunities
|
|
279
279
|
|
|
280
|
-
|
|
280
|
+
While the ROM 2.4 Python port provides a fully functional MUD with all major subsystems implemented, several areas offer opportunities for enhanced ROM parity and improved gameplay features. These partially implemented or simplified systems can be extended by future developers:
|
|
281
281
|
|
|
282
|
-
###
|
|
282
|
+
### Combat System Enhancements
|
|
283
283
|
|
|
284
|
-
- **
|
|
285
|
-
- **
|
|
286
|
-
- **
|
|
287
|
-
- **World System**: Area loading, room resets, mob/object spawning, and JSON world data
|
|
288
|
-
- **Shop Economy**: Buy/sell with pricing formulas, shop restocking, and inventory management
|
|
289
|
-
- **Communication**: Say, tell, shout, channels, and 100+ social interactions
|
|
290
|
-
- **Mob Programs**: Complete trigger system with conditional logic and ROM API
|
|
291
|
-
- **OLC Building**: Area/room/mob/object/help editors with save/load functionality
|
|
292
|
-
- **Admin Tools**: Teleport, spawn, ban management, wiznet, and debug commands
|
|
293
|
-
- **Networking**: Async telnet, WebSocket, and SSH servers with game tick integration
|
|
284
|
+
- **Defense Stubs**: Basic defense calculations are implemented, but advanced ROM defense mechanics (dodge, parry, shield block) use simplified formulas that could be enhanced for full ROM parity
|
|
285
|
+
- **Special Attacks**: Core combat works, but special weapon attacks and combat maneuvers could be expanded
|
|
286
|
+
- **Damage Types**: Basic damage handling exists, but ROM's complex damage type interactions are simplified
|
|
294
287
|
|
|
295
|
-
###
|
|
288
|
+
### Skills and Spells System
|
|
296
289
|
|
|
297
|
-
- **
|
|
298
|
-
- **
|
|
299
|
-
- **
|
|
300
|
-
- **Performance**: Full test suite completes in ~16 seconds
|
|
290
|
+
- **Learning Percentages**: Skills can be learned and used, but the ROM skill improvement system with practice-based learning is partially implemented
|
|
291
|
+
- **Spell Components**: Portal/Nexus warp-stone requirement and consumption implemented; no general component system in ROM 2.4b6
|
|
292
|
+
- **Skill Prerequisites**: Some skill dependencies and class restrictions could be more comprehensive
|
|
301
293
|
|
|
302
|
-
###
|
|
294
|
+
### Movement and Encumbrance
|
|
303
295
|
|
|
304
|
-
|
|
296
|
+
- **Weight Limits**: Basic encumbrance exists, but ROM's detailed weight penalties on movement and combat are simplified
|
|
297
|
+
- **Movement Lag**: Character movement works, but lag/wait state handling for movement restrictions could be enhanced
|
|
298
|
+
- **Terrain Effects**: Room sector types affect movement, but detailed terrain penalties are basic
|
|
305
299
|
|
|
306
|
-
|
|
307
|
-
- **JSON World Data**: Human-readable area files (easier editing than ROM .are format)
|
|
308
|
-
- **Multiple Protocols**: Telnet, WebSocket, SSH connection options
|
|
309
|
-
- **ROM API Wrapper**: 27 public API functions for external tools and scripts
|
|
310
|
-
- **Comprehensive Testing**: Golden file tests derived from ROM C behavior
|
|
311
|
-
- **Documentation**: User guides, admin guides, and builder migration guides
|
|
300
|
+
### World Reset System
|
|
312
301
|
|
|
313
|
-
|
|
302
|
+
- **Reset Semantics**: Areas reset properly, but complex ROM reset conditions and dependencies are simplified
|
|
303
|
+
- **Population Limits**: Basic mob/object limits work, but advanced population control algorithms could be improved
|
|
304
|
+
- **Reset Timing**: Reset schedules function, but fine-grained timing controls are basic
|
|
314
305
|
|
|
315
|
-
|
|
306
|
+
### Economy and Shops
|
|
316
307
|
|
|
317
|
-
**
|
|
308
|
+
- **Shop Inventory**: Basic buying/selling works, but advanced shop inventory management and restocking is simplified
|
|
309
|
+
- **Economic Balance**: Price calculations exist, but ROM's complex economic balancing factors are basic
|
|
310
|
+
- **Barter System**: Simple transactions work, but advanced bartering mechanics could be enhanced
|
|
318
311
|
|
|
319
|
-
|
|
320
|
-
2. **Test Coverage**: Add tests in `tests/` with golden files derived from ROM behavior
|
|
321
|
-
3. **Backward Compatibility**: Don't break existing save files or area data
|
|
322
|
-
4. **Documentation**: Update relevant docs and inline code documentation
|
|
323
|
-
5. **Performance**: Consider impact on the main game loop and player experience
|
|
312
|
+
### Security and Authentication
|
|
324
313
|
|
|
325
|
-
|
|
314
|
+
- **Ban System**: Basic IP banning exists, but comprehensive ban management (subnet, time-based, etc.) is partial
|
|
315
|
+
- **Account Security**: Basic login security works, but advanced password policies and account protection could be enhanced
|
|
316
|
+
- **Admin Controls**: Core admin commands exist, but comprehensive administrative tools are basic
|
|
317
|
+
|
|
318
|
+
### Persistence and Data Integrity
|
|
319
|
+
|
|
320
|
+
- **Save Validation**: Character saving works, but comprehensive data validation and corruption detection is basic
|
|
321
|
+
- **Backup Systems**: Basic persistence exists, but automated backup and recovery systems could be enhanced
|
|
322
|
+
- **Data Migration**: Save/load works, but tools for data format migration and upgrades are minimal
|
|
323
|
+
|
|
324
|
+
### Communication Systems
|
|
325
|
+
|
|
326
|
+
- **Channel Management**: Basic channels work, but advanced channel administration and moderation tools are simplified
|
|
327
|
+
- **Tell System**: Private messaging works, but features like message history and blocking are basic
|
|
328
|
+
- **Emote System**: Basic emotes exist, but custom emote creation and management could be enhanced
|
|
329
|
+
|
|
330
|
+
### Builder Tools (OLC)
|
|
331
|
+
|
|
332
|
+
- **Online Creation**: Basic OLC exists, but comprehensive online building tools with validation are partial
|
|
333
|
+
- **Area Management**: Area editing works, but advanced area management and version control is basic
|
|
334
|
+
- **Builder Security**: Basic builder permissions exist, but comprehensive security and audit trails are simplified
|
|
335
|
+
|
|
336
|
+
### Performance and Monitoring
|
|
337
|
+
|
|
338
|
+
- **Metrics Collection**: Basic logging exists, but comprehensive performance monitoring and metrics are minimal
|
|
339
|
+
- **Resource Management**: Basic resource handling works, but advanced memory and CPU optimization could be enhanced
|
|
340
|
+
- **Diagnostics**: Error handling exists, but comprehensive diagnostic and debugging tools are basic
|
|
341
|
+
|
|
342
|
+
### Development Guidelines for Contributors
|
|
343
|
+
|
|
344
|
+
When enhancing these systems:
|
|
326
345
|
|
|
327
|
-
**
|
|
346
|
+
1. **ROM Parity First**: Always reference the original ROM 2.4 C sources in `src/` for canonical behavior
|
|
347
|
+
2. **Test Coverage**: Add comprehensive tests in `tests/` with golden files derived from ROM behavior
|
|
348
|
+
3. **Backward Compatibility**: Ensure changes don't break existing save files or area data
|
|
349
|
+
4. **Documentation**: Update relevant docs in `doc/` and inline code documentation
|
|
350
|
+
5. **Performance**: Consider the impact on the main game loop and player experience
|
|
351
|
+
6. **Configuration**: Make enhancements configurable where possible to support different playstyles
|
|
328
352
|
|
|
353
|
+
Each enhancement should maintain the MUD's core functionality while adding the specific ROM behaviors that make the game authentic to the original experience.
|
|
@@ -200,9 +200,9 @@ mud/world/movement.py,sha256=Y7it7pXrPORgKyy2tRB8br_kb4-s9UK-gj0N-E2U9oM,18695
|
|
|
200
200
|
mud/world/obj_find.py,sha256=7QjVAhA-XEqAEm0CoanNtBuYj6rKijNSu8Vu1JcueMY,4304
|
|
201
201
|
mud/world/vision.py,sha256=q8VjzSzm0cbNrHX6-o0j1UG-jlcM3Z9bzUxK6T-Bsi8,9862
|
|
202
202
|
mud/world/world_state.py,sha256=W9ABMADlY5H-ZmywACsryFKZp34OufjzMRD6WT331qg,7917
|
|
203
|
-
rom24_quickmud_python-2.
|
|
204
|
-
rom24_quickmud_python-2.
|
|
205
|
-
rom24_quickmud_python-2.
|
|
206
|
-
rom24_quickmud_python-2.
|
|
207
|
-
rom24_quickmud_python-2.
|
|
208
|
-
rom24_quickmud_python-2.
|
|
203
|
+
rom24_quickmud_python-2.2.0.dist-info/licenses/LICENSE,sha256=anQ2j9As6sIC8tZgQCXbo0-09JDH9vPiqhA9djnOvkY,1078
|
|
204
|
+
rom24_quickmud_python-2.2.0.dist-info/METADATA,sha256=82zQD-H1f4fZh6R5HW3L-L1cMZvpEStDXNacfFO5MIg,13934
|
|
205
|
+
rom24_quickmud_python-2.2.0.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
|
206
|
+
rom24_quickmud_python-2.2.0.dist-info/entry_points.txt,sha256=VFru08UQTXZA_CkK-NBjJmWHyEX5a3864fQHjhaojbw,41
|
|
207
|
+
rom24_quickmud_python-2.2.0.dist-info/top_level.txt,sha256=Fk1WPmabIIjp7_iZXLYpbAVqiq7lG7TeAHt30AsOKtQ,4
|
|
208
|
+
rom24_quickmud_python-2.2.0.dist-info/RECORD,,
|
|
File without changes
|
{rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/entry_points.txt
RENAMED
|
File without changes
|
{rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/licenses/LICENSE
RENAMED
|
File without changes
|
{rom24_quickmud_python-2.1.2.dist-info → rom24_quickmud_python-2.2.0.dist-info}/top_level.txt
RENAMED
|
File without changes
|