forked from Mirrorlandia_minetest/minetest
Some work-in-progress stuff and many comment updates
This commit is contained in:
parent
e0329a3cae
commit
4a6b9a6ac1
@ -739,7 +739,7 @@ void ServerEnvironment::step(float dtime)
|
|||||||
if(1)
|
if(1)
|
||||||
{
|
{
|
||||||
MapNode n_top = block->getNodeNoEx(p0+v3s16(0,1,0));
|
MapNode n_top = block->getNodeNoEx(p0+v3s16(0,1,0));
|
||||||
if(content_features(n_top.d).walkable == false &&
|
if(content_features(n_top.d).air_equivalent &&
|
||||||
n_top.getLight(LIGHTBANK_DAY) >= 13)
|
n_top.getLight(LIGHTBANK_DAY) >= 13)
|
||||||
{
|
{
|
||||||
n.d = CONTENT_GRASS;
|
n.d = CONTENT_GRASS;
|
||||||
@ -796,10 +796,10 @@ void ServerEnvironment::step(float dtime)
|
|||||||
// Convert mud under proper lighting to grass
|
// Convert mud under proper lighting to grass
|
||||||
if(n.d == CONTENT_MUD)
|
if(n.d == CONTENT_MUD)
|
||||||
{
|
{
|
||||||
if(myrand()%4 == 0)
|
if(myrand()%10 == 0)
|
||||||
{
|
{
|
||||||
MapNode n_top = block->getNodeNoEx(p0+v3s16(0,1,0));
|
MapNode n_top = block->getNodeNoEx(p0+v3s16(0,1,0));
|
||||||
if(content_features(n_top.d).walkable == false &&
|
if(content_features(n_top.d).air_equivalent &&
|
||||||
n_top.getLightBlend(getDayNightRatio()) >= 13)
|
n_top.getLightBlend(getDayNightRatio()) >= 13)
|
||||||
{
|
{
|
||||||
n.d = CONTENT_GRASS;
|
n.d = CONTENT_GRASS;
|
||||||
|
@ -112,6 +112,19 @@ public:
|
|||||||
private:
|
private:
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
Active block modifier interface
|
||||||
|
*/
|
||||||
|
|
||||||
|
class ActiveBlockModifier
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ActiveBlockModifier(){};
|
||||||
|
virtual ~ActiveBlockModifier(){};
|
||||||
|
//TODO
|
||||||
|
//virtual void
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
The server-side environment.
|
The server-side environment.
|
||||||
|
|
||||||
|
27
src/main.cpp
27
src/main.cpp
@ -85,6 +85,10 @@ SUGG: Server-side objects could be moved based on nodes to enable very
|
|||||||
lightweight operation and simple AI
|
lightweight operation and simple AI
|
||||||
- Not practical; client would still need to show smooth movement.
|
- Not practical; client would still need to show smooth movement.
|
||||||
|
|
||||||
|
SUGG: Make a system for pregenerating quick information for mapblocks, so
|
||||||
|
that the client can show them as cubes before they are actually sent
|
||||||
|
or even generated.
|
||||||
|
|
||||||
Gaming ideas:
|
Gaming ideas:
|
||||||
-------------
|
-------------
|
||||||
|
|
||||||
@ -211,6 +215,9 @@ FIXME: Server sometimes goes into some infinite PeerNotFoundException loop
|
|||||||
FIXME: The new optimized map sending doesn't sometimes send enough blocks
|
FIXME: The new optimized map sending doesn't sometimes send enough blocks
|
||||||
from big caves and such
|
from big caves and such
|
||||||
|
|
||||||
|
Environment:
|
||||||
|
------------
|
||||||
|
|
||||||
TODO: A list of "active blocks" in which stuff happens.
|
TODO: A list of "active blocks" in which stuff happens.
|
||||||
+ Add a never-resetted game timer to the server
|
+ Add a never-resetted game timer to the server
|
||||||
+ Add a timestamp value to blocks
|
+ Add a timestamp value to blocks
|
||||||
@ -289,18 +296,20 @@ Mapgen v2:
|
|||||||
|
|
||||||
Misc. stuff:
|
Misc. stuff:
|
||||||
------------
|
------------
|
||||||
* Make an "environment metafile" to store at least time of day
|
* Move digging property stuff from material.{h,cpp} to mapnode.cpp
|
||||||
* Move digging property stuff from material.{h,cpp} to mapnode.cpp...
|
- ...Or maybe move content_features to material.{h,cpp}?
|
||||||
- Or maybe move content_features to material.{h,cpp}?
|
|
||||||
* Maybe:
|
|
||||||
Make a system for pregenerating quick information for mapblocks, so
|
|
||||||
that the client can show them as cubes before they are actually sent
|
|
||||||
or even generated.
|
|
||||||
|
|
||||||
Making it more portable:
|
Making it more portable:
|
||||||
------------------------
|
------------------------
|
||||||
* Some MSVC: std::sto* are defined without a namespace and collide
|
|
||||||
with the ones in utility.h
|
Stuff to do before release:
|
||||||
|
---------------------------
|
||||||
|
- Player default privileges and default password
|
||||||
|
- Chat privilege
|
||||||
|
- Some simple block-based dynamic stuff in the world (finish the
|
||||||
|
ActiveBlockModifier stuff)
|
||||||
|
- Protocol version field
|
||||||
|
- Consider getting some textures from cisoun's texture pack
|
||||||
|
|
||||||
======================================================================
|
======================================================================
|
||||||
|
|
||||||
|
@ -252,6 +252,7 @@ void init_mapnode()
|
|||||||
f->pointable = false;
|
f->pointable = false;
|
||||||
f->diggable = false;
|
f->diggable = false;
|
||||||
f->buildable_to = true;
|
f->buildable_to = true;
|
||||||
|
f->air_equivalent = true;
|
||||||
|
|
||||||
i = CONTENT_WATER;
|
i = CONTENT_WATER;
|
||||||
f = &g_content_features[i];
|
f = &g_content_features[i];
|
||||||
@ -303,6 +304,7 @@ void init_mapnode()
|
|||||||
f->solidness = 0; // drawn separately, makes no faces
|
f->solidness = 0; // drawn separately, makes no faces
|
||||||
f->walkable = false;
|
f->walkable = false;
|
||||||
f->wall_mounted = true;
|
f->wall_mounted = true;
|
||||||
|
f->air_equivalent = true;
|
||||||
f->dug_item = std::string("MaterialItem ")+itos(i)+" 1";
|
f->dug_item = std::string("MaterialItem ")+itos(i)+" 1";
|
||||||
|
|
||||||
i = CONTENT_SIGN_WALL;
|
i = CONTENT_SIGN_WALL;
|
||||||
@ -314,6 +316,7 @@ void init_mapnode()
|
|||||||
f->solidness = 0; // drawn separately, makes no faces
|
f->solidness = 0; // drawn separately, makes no faces
|
||||||
f->walkable = false;
|
f->walkable = false;
|
||||||
f->wall_mounted = true;
|
f->wall_mounted = true;
|
||||||
|
f->air_equivalent = true;
|
||||||
f->dug_item = std::string("MaterialItem ")+itos(i)+" 1";
|
f->dug_item = std::string("MaterialItem ")+itos(i)+" 1";
|
||||||
if(f->initial_metadata == NULL)
|
if(f->initial_metadata == NULL)
|
||||||
f->initial_metadata = new SignNodeMetadata("Some sign");
|
f->initial_metadata = new SignNodeMetadata("Some sign");
|
||||||
|
@ -151,13 +151,20 @@ struct ContentFeatures
|
|||||||
// This is used for collision detection.
|
// This is used for collision detection.
|
||||||
// Also for general solidness queries.
|
// Also for general solidness queries.
|
||||||
bool walkable;
|
bool walkable;
|
||||||
|
// Player can point to these
|
||||||
bool pointable;
|
bool pointable;
|
||||||
|
// Player can dig these
|
||||||
bool diggable;
|
bool diggable;
|
||||||
|
// Player can build on these
|
||||||
bool buildable_to;
|
bool buildable_to;
|
||||||
|
// Whether the node has no liquid, source liquid or flowing liquid
|
||||||
enum LiquidType liquid_type;
|
enum LiquidType liquid_type;
|
||||||
// If true, param2 is set to direction when placed
|
// If true, param2 is set to direction when placed. Used for torches.
|
||||||
// NOTE: the direction format is quite inefficient and should be changed
|
// NOTE: the direction format is quite inefficient and should be changed
|
||||||
bool wall_mounted;
|
bool wall_mounted;
|
||||||
|
// If true, node is equivalent to air. Torches are, air is. Water is not.
|
||||||
|
// Is used for example to check whether a mud block can have grass on.
|
||||||
|
bool air_equivalent;
|
||||||
|
|
||||||
// Inventory item string as which the node appears in inventory when dug.
|
// Inventory item string as which the node appears in inventory when dug.
|
||||||
// Mineral overrides this.
|
// Mineral overrides this.
|
||||||
@ -183,6 +190,7 @@ struct ContentFeatures
|
|||||||
buildable_to = false;
|
buildable_to = false;
|
||||||
liquid_type = LIQUID_NONE;
|
liquid_type = LIQUID_NONE;
|
||||||
wall_mounted = false;
|
wall_mounted = false;
|
||||||
|
air_equivalent = false;
|
||||||
dug_item = "";
|
dug_item = "";
|
||||||
initial_metadata = NULL;
|
initial_metadata = NULL;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user