File: MISSIONS_JSON.md

package info (click to toggle)
cataclysm-dda 0.C%2Bgit20190228.faafa3a-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 181,636 kB
  • sloc: cpp: 256,609; python: 2,621; makefile: 862; sh: 495; perl: 37; xml: 33
file content (156 lines) | stat: -rw-r--r-- 8,121 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
# Creating missions

NPCs can assign missions to the player.  There is a fairly regular structure for this:

```JSON
  {
    "id": "MISSION_GET_BLACK_BOX_TRANSCRIPT",
    "type": "mission_definition",
    "name": "Retrieve Black Box Transcript",
    "goal": "MGOAL_FIND_ITEM",
    "difficulty": 2,
    "value": 150000,
    "item": "black_box_transcript",
    "start": {
       "effect": { "u_buy_item": "black_box" },
       "assign_mission_target": { "om_terrain": "lab", "reveal_radius": 3 }
    },
    "origins": [ "ORIGIN_SECONDARY" ],
    "followup": "MISSION_EXPLORE_SARCOPHAGUS",
    "dialogue": {
      "describe": "With the black box in hand, we need to find a lab.",
      "offer": "Thanks to your searching we've got the black box but now we need to have a look'n-side her.  Now, most buildings don't have power anymore but there are a few that might be of use.  Have you ever seen one of those science labs that have popped up in the middle of nowhere?  Them suckers have a glowing terminal out front so I know they have power somewhere inside'em.  If you can get inside and find a computer lab that still works you ought to be able to find out what's in the black box.",
      "accepted": "Fuck ya, America!",
      "rejected": "Do you have any better ideas?",
      "advice": "When I was play'n with the terminal for the one I ran into it kept asking for an ID card.  Finding one would be the first order of business.",
      "inquire": "How 'bout that black box?",
      "success": "America, fuck ya!  I was in the guard a few years back so I'm confident I can make heads-or-tails of these transmissions.",
      "success_lie": "What?!  I out'ta whip you're ass.",
      "failure": "Damn, I maybe we can find an egg-head to crack the terminal."
    }
  }
```

### type
Must always be there and must always be "mission_definition".

### id
The mission id is required, but for new missions, it can be arbitrary.  Convention is to start
it with "MISSION" and to use a fairly desriptive name.

### name
The name is also required, and the name is what is displayed in the 'm'issions menu, so please
make it descriptive.

### goal
Must be included, and must be one of these strings:
"MGOAL_GO_TO"             - Reach a specific overmap tile
"MGOAL_GO_TO_TYPE"        - Reach any instance of a specified overmap tile type
"MGOAL_COMPUTER_TOGGLE"   - Activating the correct terminal will complete the mission
"MGOAL_FIND_ITEM"         - Find 1 or more items of a given type
"MGOAL_FIND_ANY_ITEM"     - Find 1 or more items of a given type, tagged for this mission
"MGOAL_FIND_MONSTER"      - Find and retrieve a friendly monster
"MGOAL_FIND_NPC"          - Find a specific NPC
"MGOAL_RECRUIT_NPC"       - Recruit a specific NPC
"MGOAL_RECRUIT_NPC_CLASS" - Recruit an NPC of a specific class
"MGOAL_ASSASSINATE"       - Kill a specific NPC
"MGOAL_KILL_MONSTER"      - Kill a specific hostile monster
"MGOAL_KILL_MONSTER_TYPE" - Kill some number of a specific monster type
"MGOAL_KILL_MONSTER_SPEC" -  Kill some number of monsters from a specific species

Currently, only "MGOAL_FIND_ITEM", "MGOAL_KILL_MONSTER_TYPE", and "MGOAL_KILL_MONSTER_SPEC"
missions can be fully defined in JSON without requiring C++ code support.

### start
Optional field.  If it is present and a string, it must be name of a function in mission_start::
that takes a mission * and performs the start code for the mission.  A hardcoded function is
currently necessary to set up any mission other than MGOAL_FIND_ITEM", "MGOAL_KILL_MONSTER_TYPE",
or "MGOAL_KILL_MONSTER_SPEC".

Alternately, if present, it can be an object with any of the following optional fields:

#### effects
This is an effects array, exactly as defined in NPCs.md, and can use any of the values from
effects.  In all cases, the NPC involved is the quest giver.

#### reveal_om_ter
This can be a string or a list of strings, all of which must be overmap terrain ids.  A randomly
selected overmap terrain tile with that id - or one of the ids from list, randomly selected -
will be revealed, and there is a 1 in 3 chance that the road route to the map tile will also
be revealed.

#### assign_mission_target

The **assign_mission_target** object specifies the criteria for finding (or creating if 
necessary) a particular overmap terrain and designating it as the mission target. Its parameters
allow control over how it is picked and how some effects (such as revealing the surrounding area)
are applied afterwards. The `om_terrain` is the only required field.

|      Identifier      |                                  Description                                  |
| -------------------- | ----------------------------------------------------------------------------- |
| `om_terrain`         | ID of overmap terrain which will be selected as the target. Mandatory.        |
| `om_special`         | ID of overmap special containing the overmap terrain.                         |
| `om_terrain_replace` | ID of overmap terrain to be found and replaced if om_terrain cannot be found. |
| `reveal_radius`      | Radius in overmap terrain coordinates to reveal.                              |
| `must_see`           | If true, the `om_terrain` must have been seen already.                        |
| `random`             | If true, a random matching om_terrain is used. If false, the closest is used. |
| `search_range`       | Range in overmap terrain coordinates to look for a matching `om_terrain`.     |
| `z`                  | If specified, will be used rather than the player's z when searching.         |

**example**
```json
{
	"assign_mission_target": {
		"om_terrain": "necropolis_c_44",
		"om_special": "Necropolis",
		"reveal_radius": 1,
		"must_see": false,
		"random": true,
		"search_range": 180,
		"z": -2
	}
}
```

If the `om_terrain` is part of an overmap special, it's essential to specify the `om_special`
value as well--otherwise, the game will not know how to spawn the entire special.

If an `om_special` must be placed, it will follow the same placement rules as defined in its
overmap special definition, respecting allowed terrains, distance from cities, road connections,
and so on. Consequently, the more restrictive the rules, the less likely this placement will
succeed (as it is competing for space with already-spawned specials).

`om_terrain_replace` is only relevent if the `om_terrain` is not part of an overmap special.
This value is used if the `om_terrain` cannot be found, and will be used as an alternative target
which will then be replaced with the `om_terrain` value. 

If `must_see` is set to true, the game will not create the terrain if it can't be found. It tries 
to avoid having new terrains magically appear in areas where the player has already been, and this
is a consequence.

`reveal_radius` and `search_range` are both in overmap terrain coordinates (an overmap is currently
180 x 180 OMT units). The search is centered on the player, gives preference to existing overmaps
(and will only spawn new overmaps if the terrain can't be found on existing overmaps), and only
executes on the player's current z-level. The `z` attribute can be used to override this and search
on a different z-level than the player--this is an absolute value rather than relative.

### monster_species
For "MGOAL_KILL_MONSTER_SPEC", sets the target monster species.

### monster_type
For "MGOAL_KILL_MONSTER_TYPE", sets the target monster type.

### monster_kill_goal
For "MGOAL_KILL_MONSTER_SPEC" and "MGOAL_KILL_MONSTER_TYPE", sets the number of monsters above
the player's current kill count that must be killed to complete the mission.

### dialogue
This is a dictionary of strings.  The NPC says these exact strings in response to the player
inquiring about the mission or reporting its completion.

## Adding new missions to NPC dialogue
Any NPC that has missions needs to either:
* Add one of their talk_topic IDs to the list of generic mission reponse IDs in the first
talk_topic of data/json/npcs/TALK_COMMON_MISSION.json
* Have a similar talk_topic with responses that lead to TALK_MISSION_INQUIRE and
TALK_MISSION_LIST_ASSIGNED.