diff --git a/default_markets.lua b/default_markets.lua index 2671f7e..16d2316 100644 --- a/default_markets.lua +++ b/default_markets.lua @@ -5,7 +5,20 @@ if not default_modpath then return end local MP = minetest.get_modpath(minetest.get_current_modname()) local S, NS = dofile(MP.."/intllib.lua") -local gold_coins_required = false +-- Only register gold coins once, if required +local gold_coins_registered = false +local register_gold_coins = function() + if not gold_coins_registered then + minetest.register_craftitem("commoditymarket:gold_coins", { + description = S("Gold Coins"), + _doc_items_longdesc = S("A gold ingot is far too valuable to use as a basic unit of value, so it has become common practice to divide the standard gold bar into one thousand small disks to make trade easier."), + _doc_items_usagehelp = S("Gold coins can be deposited and withdrawn from markets that accept them as currency. These markets can make change if you have a thousand coins and would like them back in ingot form again."), + inventory_image = "commoditymarket_gold_coins.png", + stack_max = 1000, + }) + gold_coins_registered = true + end +end local default_items = {"default:axe_bronze","default:axe_diamond","default:axe_mese","default:axe_steel","default:axe_steel","default:axe_stone","default:axe_wood","default:pick_bronze","default:pick_diamond","default:pick_mese","default:pick_steel","default:pick_stone","default:pick_wood","default:shovel_bronze","default:shovel_diamond","default:shovel_mese","default:shovel_steel","default:shovel_stone","default:shovel_wood","default:sword_bronze","default:sword_diamond","default:sword_mese","default:sword_steel","default:sword_stone","default:sword_wood", "default:blueberries", "default:book", "default:bronze_ingot", "default:clay_brick", "default:clay_lump", "default:coal_lump", "default:copper_ingot", "default:copper_lump", "default:diamond", "default:flint", "default:gold_ingot", "default:gold_lump", "default:iron_lump", "default:mese_crystal", "default:mese_crystal_fragment", "default:obsidian_shard", "default:paper", "default:steel_ingot", "default:stick", "default:tin_ingot", "default:tin_lump", "default:acacia_tree", "default:acacia_wood", "default:apple", "default:aspen_tree", "default:aspen_wood", "default:blueberry_bush_sapling", "default:bookshelf", "default:brick", "default:bronzeblock", "default:bush_sapling", "default:cactus", "default:clay", "default:coalblock", "default:cobble", "default:copperblock", "default:desert_cobble", "default:desert_sand", "default:desert_sandstone", "default:desert_sandstone_block", "default:desert_sandstone_brick", "default:desert_stone", "default:desert_stone_block", "default:desert_stonebrick", "default:diamondblock", "default:dirt", "default:glass", "default:goldblock", "default:gravel", "default:ice", "default:junglegrass", "default:junglesapling", "default:jungletree", "default:junglewood", "default:ladder_steel", "default:ladder_wood", "default:large_cactus_seedling", "default:mese", "default:mese_post_light", "default:meselamp", "default:mossycobble", "default:obsidian", "default:obsidian_block", "default:obsidian_glass", "default:obsidianbrick", "default:papyrus", "default:pine_sapling", "default:pine_tree", "default:pine_wood", "default:sand", "default:sandstone", "default:sandstone_block", "default:sandstonebrick", "default:sapling", "default:silver_sand", "default:silver_sandstone", "default:silver_sandstone_block", "default:silver_sandstone_brick", "default:snow", "default:snowblock", "default:steelblock", "default:stone", "default:stone_block", "default:stonebrick", "default:tinblock", "default:tree", "default:wood",} @@ -35,7 +48,7 @@ local kings_def = { initial_items = default_items, } -gold_coins_required = true +register_gold_coins() commoditymarket.register_market("kings", kings_def) @@ -89,7 +102,7 @@ local night_def = { anonymous = true, } -gold_coins_required = true +register_gold_coins() commoditymarket.register_market("night", night_def) @@ -146,7 +159,7 @@ local caravan_def = { initial_items = default_items, } -gold_coins_required = true +register_gold_coins() minetest.register_craft({ output = "commoditymarket:caravan_post", @@ -513,13 +526,3 @@ minetest.register_node("commoditymarket:under_market", { }) end ------------------------------------------------------------------ - -if gold_coins_required then -minetest.register_craftitem("commoditymarket:gold_coins", { - description = S("Gold Coins"), - _doc_items_longdesc = S("A gold ingot is far too valuable to use as a basic unit of value, so it has become common practice to divide the standard gold bar into one thousand small disks to make trade easier."), - _doc_items_usagehelp = S("Gold coins can be deposited and withdrawn from markets that accept them as currency. These markets can make change if you have a thousand coins and would like them back in ingot form again."), - inventory_image = "commoditymarket_gold_coins.png", - stack_max = 1000, -}) -end \ No newline at end of file diff --git a/doc.lua b/doc.lua new file mode 100644 index 0000000..7fa24db --- /dev/null +++ b/doc.lua @@ -0,0 +1,41 @@ +if not minetest.get_modpath("doc") then + return +end + +-- internationalization boilerplate +local MP = minetest.get_modpath(minetest.get_current_modname()) +local S, NS = dofile(MP.."/intllib.lua") + +doc.add_category("commoditymarket", +{ + name = S("Commodity Markets"), + description = S("Game-wide marketplaces where goods can be bought and sold at prices of your choice."), + build_formspec = doc.entry_builders.text_and_gallery, +}) + +doc.add_entry("commoditymarket", "ui_inventory", { + name = S("User Interface: Inventory"), + data = { text = +S("Each player's account has an inventory that serves as a holding area for items that are destined to be sold or that have been bought by the player but not yet retrieved. This inventory is a bit different from the standard Minetest inventory in that it doesn't hold item \"stacks\", it just tracks the total number of that item present. Some markets allow for extremely large quantities of an item to be stored here for sale." +.."\n\n".. +"To add an item to your market inventory for eventual sale either shift-click on the item in your player inventory or drag the item stack to the inventory slot below the main market inventory list. Some markets may have restrictions on what items can be bought and sold, if an item is not valid for that market it won't go into the market's inventory. Some items are considered \"currency\" and will add to your account's currency balance instead of being listed in your market inventory." +.."\n\n".. +"Tools cannot be added to the market inventory if they have any wear on them. The market also can't handle items with attached metadata such as books that have had text added to them." +.."\n\n".. +"To remove an item from your market inventory, double-click in it in the market inventory list. As much of the item as can fit into your player inventory will be transferred to you, with any remainder staying behind in the market inventory. To withdraw currency from your market balance type the amount you'd like to withdraw in the field next to the \"Withdraw\" button. The currency will be converted into items and added to your player inventory, with whatever cannot be converted remaining behind in your market balance.") +}}) + +doc.add_entry("commoditymarket", "ui_orders", { + name = S("User Interface: Orders"), + data = { text = +S( +"At the core of how a market operates are \"buy\" and \"sell\" orders. A buy order is an announcement to the world that you are interested in purchasing a certain quantity of item and are willing to pay a certain amount of currency in exchange for each unit of that item. Conversely, a sell order is an announcement to the world that you are interested in selling a certain quantity of item and will accept a certain amount of currency in exchange for each unit of that item." +.."\n\n".. +"The market price of an item is determined by where the existing buy and sell orders for that item intersect. When you offer to buy an item for a price that someone is offering to sell it at, the item is transferred to you and currency is transferred from your account to theirs to cover the cost. The market will keep track of the most recent price that an item was successfully sold for, but note that this information is for historical interest only - there's no guarantee that anyone is currently willing to match the historical price." +.."\n\n".. +"When an item is selected in the upper list, the currently existing buy and sell orders for that item will be displayed in the lower list. Sell orders are listed first in descending price, followed by buy orders in ascending price. The current market price will be somewhere in between the lowest sell order and the highest buy order. If you wish to cancel a buy or sell order that you've placed for an item, double-click on the order and the item or currency that you put into that order will be returned to your inventory." +.."\n\n".. +"If you place a buy order and there are already sell orders for the item that meet or are below your price, some or all of your buy order might be immediately fulfilled. Your purchases will be made at the price that the sell orders have been set to - if you were willing to pay 15 units of currency per item but someone was already offering to sell for 2 units of currency per item, you only pay 2 units for each of that offer's items. If there aren't enough compatible sell orders to fulfill your buy order, the remainder will be placed into the market and made available for future sellers to see and fulfill if they agree to your price. Your buy order will immediately deduct the currency required for it from your account's balance, but if you cancel your order you will get that currency back - it's not gone until the order is actually fulfilled." +.."\n\n".. +"If you place a sell order and there are already buy orders that meet or exceed your price, some or all of your sell order may be immediately fulfilled. You'll be paid the price that the buyers are offering rather than the amount you're demanding. If any of your sell offer is left unfulfilled, the sell order will be added to the market for future buyers to see. The items for this offer will be immediately taken from your market inventory but if you cancel your order you will get those items back.") +}}) \ No newline at end of file diff --git a/init.lua b/init.lua index 7bffcd5..1f88049 100644 --- a/init.lua +++ b/init.lua @@ -3,8 +3,9 @@ commoditymarket = {} local MP = minetest.get_modpath(minetest.get_current_modname()) dofile(MP.."/formspecs.lua") dofile(MP.."/market.lua") -dofile(MP.."/default_markets.lua") +dofile(MP.."/doc.lua") +dofile(MP.."/default_markets.lua") dofile(MP.."/mapgen_dungeon_markets.lua") minetest.register_chatcommand("market.show", { diff --git a/locale/template.pot b/locale/template.pot index e6bbcd9..4cc3688 100644 --- a/locale/template.pot +++ b/locale/template.pot @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2019-08-24 22:55-0600\n" +"POT-Creation-Date: 2019-12-31 14:12-0700\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" @@ -17,15 +17,33 @@ msgstr "" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: 8bit\n" -#: commoditymarket\default_markets.lua:12 +#: commoditymarket\default_markets.lua:13 +msgid "Gold Coins" +msgstr "" + +#: commoditymarket\default_markets.lua:14 +msgid "" +"A gold ingot is far too valuable to use as a basic unit of value, so it has " +"become common practice to divide the standard gold bar into one thousand " +"small disks to make trade easier." +msgstr "" + +#: commoditymarket\default_markets.lua:15 +msgid "" +"Gold coins can be deposited and withdrawn from markets that accept them as " +"currency. These markets can make change if you have a thousand coins and " +"would like them back in ingot form again." +msgstr "" + +#: commoditymarket\default_markets.lua:25 msgid "Right-click on this to open the market interface." msgstr "" -#: commoditymarket\default_markets.lua:20 +#: commoditymarket\default_markets.lua:33 msgid "King's Market" msgstr "" -#: commoditymarket\default_markets.lua:21 +#: commoditymarket\default_markets.lua:34 msgid "" "The largest and most accessible market for the common man, the King's Market " "uses gold coins as its medium of exchange (or the equivalent in gold ingots " @@ -35,23 +53,23 @@ msgid "" "Market. Gold coins are represented by a '☼' symbol." msgstr "" -#: commoditymarket\default_markets.lua:58 +#: commoditymarket\default_markets.lua:77 msgid "At this time of day the King's Market is closed." msgstr "" -#: commoditymarket\default_markets.lua:69 +#: commoditymarket\default_markets.lua:92 msgid "Night Market" msgstr "" -#: commoditymarket\default_markets.lua:102 +#: commoditymarket\default_markets.lua:131 msgid "At this time of day the Night Market is closed." msgstr "" -#: commoditymarket\default_markets.lua:117 +#: commoditymarket\default_markets.lua:150 msgid "Trader's Caravan" msgstr "" -#: commoditymarket\default_markets.lua:118 +#: commoditymarket\default_markets.lua:151 msgid "" "Unlike most markets that have well-known fixed locations that travelers " "congregate to, the network of Trader's Caravans is fluid and dynamic in " @@ -62,46 +80,46 @@ msgid "" "a location where Trader's Caravans will make a stop." msgstr "" -#: commoditymarket\default_markets.lua:186 +#: commoditymarket\default_markets.lua:219 msgid "Right-click to summon a trader's caravan" msgstr "" -#: commoditymarket\default_markets.lua:319 +#: commoditymarket\default_markets.lua:362 msgid "Trading Post" msgstr "" -#: commoditymarket\default_markets.lua:320 +#: commoditymarket\default_markets.lua:363 msgid "" "This post signals passing caravan traders that customers can be found here, " "and signals to customers that caravan traders can be found here. If no " "caravan is present, right-click to summon one." msgstr "" -#: commoditymarket\default_markets.lua:321 +#: commoditymarket\default_markets.lua:364 msgid "" "The trader's caravan requires a suitable open space next to the trading post " "for it to arrive, and takes some time to arrive after being summoned. The " "post gives a countdown to the caravan's arrival when moused over." msgstr "" -#: commoditymarket\default_markets.lua:368 +#: commoditymarket\default_markets.lua:411 msgid "" "Indicated parking area isn't suitable.\n" "A 5x3 open space with solid ground\n" "is required for a caravan." msgstr "" -#: commoditymarket\default_markets.lua:378 +#: commoditymarket\default_markets.lua:421 msgid "" "Caravan summoned\n" "ETA: @1 seconds." msgstr "" -#: commoditymarket\default_markets.lua:404 +#: commoditymarket\default_markets.lua:447 msgid "Goblin Exchange" msgstr "" -#: commoditymarket\default_markets.lua:405 +#: commoditymarket\default_markets.lua:448 msgid "" "One does not usually associate Goblins with the sort of sophistication that " "running a market requires. Usually one just associates Goblins with savagery " @@ -113,11 +131,11 @@ msgid "" "brokers prefer to \"keep the change\" when giving back actual coal lumps)." msgstr "" -#: commoditymarket\default_markets.lua:436 +#: commoditymarket\default_markets.lua:489 msgid "Undermarket" msgstr "" -#: commoditymarket\default_markets.lua:437 +#: commoditymarket\default_markets.lua:490 msgid "" "Deep in the bowels of the world, below even the goblin-infested warrens and " "ancient delvings of the dwarves, dark and mysterious beings once dwelled. A " @@ -128,33 +146,120 @@ msgid "" "renders it useless for other purposes." msgstr "" -#: commoditymarket\default_markets.lua:469 -msgid "Gold Coins" +#: commoditymarket\doc.lua:11 +msgid "Commodity Markets" msgstr "" -#: commoditymarket\default_markets.lua:470 +#: commoditymarket\doc.lua:12 msgid "" -"A gold ingot is far too valuable to use as a basic unit of value, so it has " -"become common practice to divide the standard gold bar into one thousand " -"small disks to make trade easier." +"Game-wide marketplaces where goods can be bought and sold at prices of your " +"choice." msgstr "" -#: commoditymarket\default_markets.lua:471 +#: commoditymarket\doc.lua:17 +msgid "User Interface: Inventory" +msgstr "" + +#: commoditymarket\doc.lua:19 msgid "" -"Gold coins can be deposited and withdrawn from markets that accept them as " -"currency. These markets can make change if you have a thousand coins and " -"would like them back in ingot form again." +"Each player's account has an inventory that serves as a holding area for " +"items that are destined to be sold or that have been bought by the player " +"but not yet retrieved. This inventory is a bit different from the standard " +"Minetest inventory in that it doesn't hold item \"stacks\", it just tracks " +"the total number of that item present. Some markets allow for extremely " +"large quantities of an item to be stored here for sale.\n" +"\n" +"To add an item to your market inventory for eventual sale either shift-click " +"on the item in your player inventory or drag the item stack to the inventory " +"slot below the main market inventory list. Some markets may have " +"restrictions on what items can be bought and sold, if an item is not valid " +"for that market it won't go into the market's inventory. Some items are " +"considered \"currency\" and will add to your account's currency balance " +"instead of being listed in your market inventory.\n" +"\n" +"Tools cannot be added to the market inventory if they have any wear on them. " +"The market also can't handle items with attached metadata such as books that " +"have had text added to them.\n" +"\n" +"To remove an item from your market inventory, double-click in it in the " +"market inventory list. As much of the item as can fit into your player " +"inventory will be transferred to you, with any remainder staying behind in " +"the market inventory. To withdraw currency from your market balance type the " +"amount you'd like to withdraw in the field next to the \"Withdraw\" button. " +"The currency will be converted into items and added to your player " +"inventory, with whatever cannot be converted remaining behind in your market " +"balance." +msgstr "" + +#: commoditymarket\doc.lua:29 +msgid "User Interface: Orders" +msgstr "" + +#: commoditymarket\doc.lua:32 +msgid "" +"At the core of how a market operates are \"buy\" and \"sell\" orders. A buy " +"order is an announcement to the world that you are interested in purchasing " +"a certain quantity of item and are willing to pay a certain amount of " +"currency in exchange for each unit of that item. Conversely, a sell order is " +"an announcement to the world that you are interested in selling a certain " +"quantity of item and will accept a certain amount of currency in exchange " +"for each unit of that item.\n" +"\n" +"The market price of an item is determined by where the existing buy and sell " +"orders for that item intersect. When you offer to buy an item for a price " +"that someone is offering to sell it at, the item is transferred to you and " +"currency is transferred from your account to theirs to cover the cost. The " +"market will keep track of the most recent price that an item was " +"successfully sold for, but note that this information is for historical " +"interest only - there's no guarantee that anyone is currently willing to " +"match the historical price.\n" +"\n" +"When an item is selected in the upper list, the currently existing buy and " +"sell orders for that item will be displayed in the lower list. Sell orders " +"are listed first in descending price, followed by buy orders in ascending " +"price. The current market price will be somewhere in between the lowest sell " +"order and the highest buy order. If you wish to cancel a buy or sell order " +"that you've placed for an item, double-click on the order and the item or " +"currency that you put into that order will be returned to your inventory.\n" +"\n" +"If you place a buy order and there are already sell orders for the item that " +"meet or are below your price, some or all of your buy order might be " +"immediately fulfilled. Your purchases will be made at the price that the " +"sell orders have been set to - if you were willing to pay 15 units of " +"currency per item but someone was already offering to sell for 2 units of " +"currency per item, you only pay 2 units for each of that offer's items. If " +"there aren't enough compatible sell orders to fulfill your buy order, the " +"remainder will be placed into the market and made available for future " +"sellers to see and fulfill if they agree to your price. Your buy order will " +"immediately deduct the currency required for it from your account's balance, " +"but if you cancel your order you will get that currency back - it's not gone " +"until the order is actually fulfilled.\n" +"\n" +"If you place a sell order and there are already buy orders that meet or " +"exceed your price, some or all of your sell order may be immediately " +"fulfilled. You'll be paid the price that the buyers are offering rather than " +"the amount you're demanding. If any of your sell offer is left unfulfilled, " +"the sell order will be added to the market for future buyers to see. The " +"items for this offer will be immediately taken from your market inventory " +"but if you cancel your order you will get those items back." +msgstr "" + +#: commoditymarket\formspecs.lua:43 +#: commoditymarket\formspecs.lua:137 +#: commoditymarket\formspecs.lua:275 +#: commoditymarket\formspecs.lua:323 +msgid "Unknown Item" msgstr "" #: commoditymarket\formspecs.lua:71 #: commoditymarket\formspecs.lua:225 -#: commoditymarket\formspecs.lua:438 +#: commoditymarket\formspecs.lua:448 msgid "Your Inventory" msgstr "" #: commoditymarket\formspecs.lua:71 #: commoditymarket\formspecs.lua:225 -#: commoditymarket\formspecs.lua:438 +#: commoditymarket\formspecs.lua:448 msgid "Market Orders" msgstr "" @@ -179,22 +284,22 @@ msgstr "" #: commoditymarket\formspecs.lua:93 #: commoditymarket\formspecs.lua:97 -#: commoditymarket\formspecs.lua:345 -#: commoditymarket\formspecs.lua:358 +#: commoditymarket\formspecs.lua:347 +#: commoditymarket\formspecs.lua:359 msgid "Quantity" msgstr "" -#: commoditymarket\formspecs.lua:108 +#: commoditymarket\formspecs.lua:109 msgid "" "Drop items here to\n" "add to your account" msgstr "" -#: commoditymarket\formspecs.lua:112 +#: commoditymarket\formspecs.lua:113 msgid "Inventory limit:" msgstr "" -#: commoditymarket\formspecs.lua:113 +#: commoditymarket\formspecs.lua:114 msgid "" "You can still receive purchased items if you've exceeded your inventory " "limit,\n" @@ -202,23 +307,17 @@ msgid "" "the market until you've emptied it back down below the limit again." msgstr "" -#: commoditymarket\formspecs.lua:118 +#: commoditymarket\formspecs.lua:119 msgid "Withdraw" msgstr "" -#: commoditymarket\formspecs.lua:119 +#: commoditymarket\formspecs.lua:120 msgid "" "Enter the amount of currency you'd like to withdraw then click the " "'Withdraw'\n" "button to convert it into items and transfer it to your personal inventory." msgstr "" -#: commoditymarket\formspecs.lua:136 -#: commoditymarket\formspecs.lua:275 -#: commoditymarket\formspecs.lua:323 -msgid "Unknown Item" -msgstr "" - #: commoditymarket\formspecs.lua:239 msgid "Number of items there's demand for in the market." msgstr "" @@ -308,111 +407,111 @@ msgid "" "You have @1 items remaining. Cancel old sell orders to free up space." msgstr "" -#: commoditymarket\formspecs.lua:345 -#: commoditymarket\formspecs.lua:377 -msgid "Buy" -msgstr "" - #: commoditymarket\formspecs.lua:346 -msgid "Price per" -msgstr "" - -#: commoditymarket\formspecs.lua:348 msgid "Use these fields to enter buy and sell orders for the selected item." msgstr "" -#: commoditymarket\formspecs.lua:352 -msgid "The price per item in this order." +#: commoditymarket\formspecs.lua:347 +#: commoditymarket\formspecs.lua:378 +msgid "Buy" +msgstr "" + +#: commoditymarket\formspecs.lua:348 +msgid "Price per" msgstr "" #: commoditymarket\formspecs.lua:353 -msgid "The total amount of items in this particular order." +msgid "The price per item in this order." msgstr "" #: commoditymarket\formspecs.lua:354 +msgid "The total amount of items in this particular order." +msgstr "" + +#: commoditymarket\formspecs.lua:355 msgid "" "The total amount of items available at this price accounting for the other " "orders also currently being offered." msgstr "" -#: commoditymarket\formspecs.lua:355 +#: commoditymarket\formspecs.lua:356 msgid "" "The name of the player who placed this order.\n" "Double-click your own orders to cancel them." msgstr "" -#: commoditymarket\formspecs.lua:356 +#: commoditymarket\formspecs.lua:357 msgid "How many days ago this order was placed." msgstr "" -#: commoditymarket\formspecs.lua:358 +#: commoditymarket\formspecs.lua:359 msgid "Order" msgstr "" -#: commoditymarket\formspecs.lua:358 +#: commoditymarket\formspecs.lua:359 msgid "Price" msgstr "" -#: commoditymarket\formspecs.lua:358 +#: commoditymarket\formspecs.lua:359 msgid "Total Volume" msgstr "" -#: commoditymarket\formspecs.lua:358 +#: commoditymarket\formspecs.lua:359 msgid "Player" msgstr "" -#: commoditymarket\formspecs.lua:358 +#: commoditymarket\formspecs.lua:359 msgid "Days Old" msgstr "" -#: commoditymarket\formspecs.lua:362 +#: commoditymarket\formspecs.lua:363 msgid "Sell" msgstr "" -#: commoditymarket\formspecs.lua:386 +#: commoditymarket\formspecs.lua:387 msgid "Select an item to view or place orders." msgstr "" -#: commoditymarket\formspecs.lua:401 +#: commoditymarket\formspecs.lua:402 msgid "yourself" msgstr "" -#: commoditymarket\formspecs.lua:403 -#: commoditymarket\formspecs.lua:411 +#: commoditymarket\formspecs.lua:404 +#: commoditymarket\formspecs.lua:412 msgid "someone" msgstr "" -#: commoditymarket\formspecs.lua:405 -#: commoditymarket\formspecs.lua:413 +#: commoditymarket\formspecs.lua:406 +#: commoditymarket\formspecs.lua:414 msgid "you" msgstr "" -#: commoditymarket\formspecs.lua:429 +#: commoditymarket\formspecs.lua:439 msgid "On day @1 @2 sold @3 @4 to @5 at @6@7 each for a total of @6@8." msgstr "" -#: commoditymarket\formspecs.lua:439 +#: commoditymarket\formspecs.lua:449 msgid "Description:" msgstr "" -#: commoditymarket\formspecs.lua:440 +#: commoditymarket\formspecs.lua:450 msgid "Your Recent Purchases and Sales:" msgstr "" -#: commoditymarket\formspecs.lua:453 +#: commoditymarket\formspecs.lua:463 msgid "Mark logs as read" msgstr "" -#: commoditymarket\formspecs.lua:454 +#: commoditymarket\formspecs.lua:464 msgid "" "Log entries in yellow are new since last time you marked your log as read." msgstr "" -#: commoditymarket\formspecs.lua:457 +#: commoditymarket\formspecs.lua:467 msgid "No logged activites in this market yet." msgstr "" -#: commoditymarket\formspecs.lua:462 +#: commoditymarket\formspecs.lua:472 msgid "Show Itemnames" msgstr "" @@ -446,3 +545,35 @@ msgstr "" #: commoditymarket\market.lua:299 msgid "You can't afford that many of this item." msgstr "" + +#: commoditymarket\market.lua:474 +msgid "1 @1 = @2@3" +msgstr "" + +#: commoditymarket\market.lua:478 +msgid "Market inventory is limited to @1 items." +msgstr "" + +#: commoditymarket\market.lua:480 +msgid "Market has unlimited inventory space." +msgstr "" + +#: commoditymarket\market.lua:485 +msgid "Total pending sell orders are limited to @1 items." +msgstr "" + +#: commoditymarket\market.lua:487 +msgid "Market supports unlimited pending sell orders." +msgstr "" + +#: commoditymarket\market.lua:494 +msgid "Currency item values:" +msgstr "" + +#: commoditymarket\market.lua:509 +msgid "Market" +msgstr "" + +#: commoditymarket\market.lua:510 +msgid "A market where orders to buy or sell items can be placed and fulfilled." +msgstr "" diff --git a/market.lua b/market.lua index e4b48ec..7cef8e9 100644 --- a/market.lua +++ b/market.lua @@ -465,12 +465,49 @@ local save_market_data = function(market) return true end +local make_doc_entry = function() return end +if minetest.get_modpath("doc") then + make_doc_entry = function(market_name, market_def) + local currencies = {} + for _, currency_item in ipairs(market_def.currency_ordered) do + local item_def = minetest.registered_items[currency_item.item] + table.insert(currencies, S("1 @1 = @2@3", item_def.description, market_def.currency_symbol, currency_item.amount)) + end + local inventory_limit + if market_def.inventory_limit then + inventory_limit = S("Market inventory is limited to @1 items.", market_def.inventory_limit) + else + inventory_limit = S("Market has unlimited inventory space.") + end + + local sell_limit + if market_def.sell_limit then + sell_limit = S("Total pending sell orders are limited to @1 items.", market_def.inventory_limit) + else + sell_limit = S("Market supports unlimited pending sell orders.") + end + + doc.add_entry("commoditymarket", "market_"..market_name, { + name = market_def.description, + data = { text = market_def.long_description + .."\n\n" + ..S("Currency item values:") .. "\n " .. table.concat(currencies, "\n ") + .."\n\n" + ..inventory_limit + .."\n" + ..sell_limit + } + }) + end +end + commoditymarket.register_market = function(market_name, market_def) assert(not commoditymarket.registered_markets[market_name]) + assert(market_def.currency) - market_def.currency_symbol = minetest.formspec_escape(market_def.currency_symbol) or "¤" -- \u{00A4} -- defaults to the generic currency symbol ("scarab") - market_def.description = minetest.formspec_escape(market_def.description) or "Market" - market_def.long_description = minetest.formspec_escape(market_def.long_description) or "A market where orders to buy or sell items can be placed and fulfilled." + market_def.currency_symbol = market_def.currency_symbol or "¤" -- \u{00A4} -- defaults to the generic currency symbol ("scarab") + market_def.description = market_def.description or S("Market") + market_def.long_description = market_def.long_description or S("A market where orders to buy or sell items can be placed and fulfilled.") -- Reprocess currency table into a form easier for the withdraw code to work with market_def.currency_ordered = {} @@ -479,6 +516,14 @@ commoditymarket.register_market = function(market_name, market_def) end table.sort(market_def.currency_ordered, function(currency1, currency2) return currency1.amount > currency2.amount end) + make_doc_entry(market_name, market_def) -- market_def has now been normalized, make documentation for it if doc is installed. + + -- Just in case a developer supplied strings that don't work well in formspecs, escape them now so we don't have to do it + -- wherever they're used. + market_def.currency_symbol = minetest.formspec_escape(market_def.currency_symbol) + market_def.description = minetest.formspec_escape(market_def.description) + market_def.long_description = minetest.formspec_escape(market_def.long_description) + local new_market = {} new_market.def = market_def commoditymarket.registered_markets[market_name] = new_market