From 7363d6d3949f5d698223cf56170b9d2167377ed5 Mon Sep 17 00:00:00 2001
From: Christian Heller <c.heller@plomlompom.de>
Date: Fri, 13 Mar 2015 01:13:53 +0100
Subject: [PATCH] (Tentative: Contains bugs!) Add carpentry, building walls
 from wood.

---
 SERVER_COMMANDS           |  3 +-
 confserver/world          |  8 +++++
 roguelike-server          | 67 +++++++++++++++++++++++++++++++++------
 src/client/draw_wins.c    |  8 ++---
 src/server/libplomrogue.c |  3 +-
 5 files changed, 73 insertions(+), 16 deletions(-)

diff --git a/SERVER_COMMANDS b/SERVER_COMMANDS
index aa147c0..e408a43 100644
--- a/SERVER_COMMANDS
+++ b/SERVER_COMMANDS
@@ -251,5 +251,4 @@ PLANT_0 [0 to infinity]
 
 LUMBER [0 to infinity]
 
-TT_TOOLS gain the "axe" argument.
-
+TT_TOOLS gains the arguments "axe", "carpentry", "wood".
diff --git a/confserver/world b/confserver/world
index 9aa0d57..452e9df 100644
--- a/confserver/world
+++ b/confserver/world
@@ -100,10 +100,18 @@ TT_TOOLPOWER 5000
 TT_START_NUMBER 1
 
 TT_ID 10
+TT_TOOL wood
 TT_START_NUMBER 0
 TT_SYMBOL =
 TT_NAME WOOD
 
+TT_ID 11
+TT_TOOL carpentry
+TT_SYMBOL -
+TT_NAME 'CARPENTRY TOOL'
+TT_TOOLPOWER 5000
+TT_START_NUMBER 1
+
 TT_ID 0
 TT_CORPSE_ID 6
 TT_ID 1
diff --git a/roguelike-server b/roguelike-server
index 6b7d8ca..a1da325 100755
--- a/roguelike-server
+++ b/roguelike-server
@@ -495,7 +495,7 @@ def make_map():
         pos = (y * length) + x  # #
         if (("." == chr(world_db["MAP"][pos]  # #
              or ":" == chr(world_db["MAP"][pos]))
-            and not is_neighbor((y, x), 'X'))):  # #
+            and not is_neighbor((y, x), "X"))):  # #
             world_db["MAP"][pos] = ord("_")  # #
             world_db["altar"] = (y, x)  # #
             altar_placed = True  # #
@@ -762,7 +762,8 @@ def actor_move(t):
             if test and t == world_db["Things"][0]:  # #
                 add_gods_favor(-test)  # #
             return
-        if ord("X") == world_db["MAP"][pos]:  # #
+        if (ord("X") == world_db["MAP"][pos]  # #
+            or ord("|") == world_db["MAP"][pos]):  # #
             carries_axe = False  # #
             for id in t["T_CARRIES"]:  # # 
                 type = world_db["Things"][id]["T_TYPE"]  # #
@@ -777,16 +778,23 @@ def actor_move(t):
                                                     + ", you chop!\n")  # #
                     add_gods_favor(-1)  # #
                 chop_power = world_db["ThingTypes"][type]["TT_TOOLPOWER"]
-                if chop_power > 0 and 0 == int(rand.next() / chop_power):  # #
+                case_X = world_db["MAP"][pos] == ord("X")  # #
+                if (chop_power > 0  # #
+                    and ((case_X and  # #
+                          0 == int(rand.next() / chop_power))  # #
+                    or (not case_X and  # #
+                             0 == int(rand.next() / (3 * chop_power))))):  # #
                     if t == world_db["Things"][0]:  # #
                         strong_write(io_db["file_out"],  # #
-                                     "LOG You chop the tree down.\n")  # #
+                                     "LOG You chop it down.\n")  # #
                     add_gods_favor(-10)  # #
                     world_db["MAP"][pos] = ord(".")   # #
-                    id = id_setter(-1, "Things")  # #
-                    world_db["Things"][id] = new_Thing(world_db["LUMBER"],  # #
-                                                       (move_result[1],  # #
-                                                        move_result[2]))  # # 
+                    i = 3 if case_X else 1  # #
+                    for i in range(i):  # #
+                        id = id_setter(-1, "Things")  # #
+                        world_db["Things"][id] = \
+                          new_Thing(world_db["LUMBER"],  # #
+                                    (move_result[1], move_result[2]))  # # 
                     build_fov_map(t)  # #
                 return   # #
         passable = ("." == chr(world_db["MAP"][pos]) or
@@ -885,6 +893,47 @@ def actor_use(t):
                              "LOG To use this item for chopping, move "  # #
                              "towards a tree while carrying it in "  # #
                              "your inventory.\n")  # #
+        elif (world_db["ThingTypes"][type]["TT_TOOL"] == "carpentry"):  # #
+            pos = t["T_POSY"] * world_db["MAP_LENGTH"] + t["T_POSX"]
+            if (world_db["MAP"][pos] == ord("X")  # #
+                or world_db["MAP"][pos] == ord("|")):  # #
+                strong_write(io_db["file_out"],  # #
+                             "LOG Can't build when standing on barrier.\n")  # #
+                return
+            for id in [id for id in world_db["Things"]
+                       if not world_db["Things"][id] == t
+                       if not world_db["Things"][id]["carried"]
+                       if world_db["Things"][id]["T_POSY"] == t["T_POSY"]
+                       if world_db["Things"][id]["T_POSX"] == t["T_POSX"]]:
+                 strong_write(io_db["file_out"],
+                              "LOG Can't build when standing objects.\n")  # #
+                 return
+            for id in t["T_CARRIES"]:  # #
+                type_tool = world_db["Things"][id]["T_TYPE"]  # #
+                if (world_db["ThingTypes"][type_tool]["TT_TOOL"]  # #
+                    == "carpentry"):  # #
+                    break  # #
+            wood_id = None  # #
+            for id in t["T_CARRIES"]:  # #
+                type_material = world_db["Things"][id]["T_TYPE"]  # #
+                if (world_db["ThingTypes"][type_material]["TT_TOOL"]  # #
+                    == "wood"):  # #
+                    wood_id = id  # #
+                    break  # #
+            if wood_id != None:  # #
+                t["T_CARRIES"].remove(wood_id)  # #
+                del world_db["Things"][wood_id]  # #
+                world_db["MAP"][pos] = ord("|")  # #
+                strong_write(io_db["file_out"], "LOG With your "  # #
+                             + world_db["ThingTypes"][type_tool]["TT_NAME"]  # #
+                             + " you build a wooden barrier from your "  # #
+                             + world_db["ThingTypes"][type_material]  # #
+                               ["TT_NAME"]  # #
+                             + ".\n")  # #
+            else:  # #
+                strong_write(io_db["file_out"], "LOG You can't use a "  # #
+                             + world_db["ThingTypes"][type_tool]["TT_NAME"]  # #
+                             + " without some wood in your inventory.\n")  # #
         elif world_db["ThingTypes"][type]["TT_TOOL"] == "food":
             t["T_CARRIES"].remove(id)
             del world_db["Things"][id]
@@ -1232,7 +1281,7 @@ def turn_over():
                    if not world_db["Things"][id]["carried"]]:
             y = world_db["Things"][id]["T_POSY"]
             x = world_db["Things"][id]["T_POSX"]
-            proliferable_map[y * world_db["MAP_LENGTH"] + x] = ord('X')
+            proliferable_map[y * world_db["MAP_LENGTH"] + x] = ord("X")
         for id in [id for id in world_db["Things"]]:  # Only what's from start!
             if not id in world_db["Things"] or \
                world_db["Things"][id]["carried"]:   # May have been consumed or
diff --git a/src/client/draw_wins.c b/src/client/draw_wins.c
index 940b768..d0d460c 100644
--- a/src/client/draw_wins.c
+++ b/src/client/draw_wins.c
@@ -365,7 +365,7 @@ extern void draw_win_log(struct Win * win)
         }
     }
     if (n_postbreak_lines > win->frame_size.y)
-    {
+    { 
         uint32_t size = n_postbreak_lines * (win->frame_size.x + 1);
         win->winmap = try_malloc(sizeof(chtype) * size, __func__);
         for (i = 0; i < size; win->winmap[i] = ' ', i++);
@@ -398,7 +398,7 @@ extern void draw_win_map(struct Win * win)
             { //
                 a = COLOR_PAIR(1); //
             } //
-            else if (c_m == 'X') //
+            else if (c_m == 'X' || c_m == '|') //
             { //
                 a = COLOR_PAIR(3); //
             } //
@@ -448,11 +448,11 @@ extern void draw_win_map(struct Win * win)
                 { //
                     a = COLOR_PAIR(9); //
                 } //
-                else if ('m' == c || '/' == c) //
+                else if ('m' == c || '/' == c || '-' == c) //
                 { //
                     a = COLOR_PAIR(10); //
                 } //
-                else if ('X' == c) //
+                else if ('X' == c || '|' == c) //
                 { //
                     a = COLOR_PAIR(11); //
                 } //
diff --git a/src/server/libplomrogue.c b/src/server/libplomrogue.c
index e8ff9ae..c7fb5ce 100644
--- a/src/server/libplomrogue.c
+++ b/src/server/libplomrogue.c
@@ -357,7 +357,8 @@ static uint8_t eval_position(uint16_t dist, uint16_t hex_i, char * fov_map,
     uint16_t pos_in_map = test_pos->y * maplength + test_pos->x;
     uint8_t all_shaded = shade_hex(left_angle, right_angle_1st, middle_angle,
                                    shadows, pos_in_map, fov_map);
-    if (!all_shaded && 'X' == worldmap[pos_in_map])
+    if (!all_shaded && ('X' == worldmap[pos_in_map]
+                        || '|' == worldmap[pos_in_map]))  //
     {
         if (set_shadow(left_angle, right_angle_1st, shadows))
         {
-- 
2.30.2