Skip to content

Latest commit

 

History

History
232 lines (173 loc) · 6.38 KB

README.md

File metadata and controls

232 lines (173 loc) · 6.38 KB

Storydata

This is a repo to contain game scripts for the TEN GameBot scripting engine. This allows you to play adventure games and escape room games right inside Discord with your friends.

Join our server here to try some games! https://discord.gg/dUeQbB5rEC

Basic Authoring

Each game sits in it's own folder. Let's take the 'office' game as an example

The game scripts live in 'yaml' files inside GAMENAME/story

A top level file called story.yaml

This sets things like the overall intro to the story, custom help

Rooms

A story is broken up into rooms. eg for office story we have lobby, attic and a room called office

Inside the room files there are two main blocks

Rooms have:

example:

rooms:
  - name: office

    states:
      - name: default
        long: A boring looking tech company's office. Seems like you've been here before, but it just looks the same as any other one.
        short: A large empty room with a corner `desk`
        imageUrl: office/rooms/office-chest-closed.jpg

    actions:
      - match: smell
        always:
          reply: A musty smell of industrial carpet and cigarette smoke fills the room.
      - match: atov/i
        always:
          reply: You say ATOV to noone in particular. Maybe you need to look for something else?
          # goto without any conditions
      - match: teleport attic
        always:
          reply: you click your heels and find yourself in the attic
          goto: attic

States

An item can have various states, controlled by actions or other objects

Items

An item can have a number of states. When a user types look ITEM or X item then the corresponding state is show.

    items:
      - name: lamp
        state: off
        canTake: true  # you can pick this up
        states:
          - name: off
            short: a basic light. It's off.
          - name: lit
            short: a lamp casting light on the room

You can change the state inside other actions so you could have a switch action in the room to set: lamp.state = lit

When the canTake flag allows a user to get something they can pick it up and add to inventory.

Actors

Actors are a special type of item that you can have a conversation with. More later on this!

Actions

Are how players interact with things in the room. When the user types something that is a match then do the things underneath.

(Comments are prefixed with # )

      # user says this:
      - match: use matches (on|with) lamp
        then:
          # reply and set property on the 'lamp' object
          reply: You light the lamp with the matches
          setProps:
            - lamp.state = lit

We could also show an image here, or make other ways to say the command using the full power of RegEx syntax.

Conditions

Allow you to check for variables before doing things.

So a simple key/lock type syntax around getting matches to light up

    items:
      - name: matches
        canTake: true

this will set the matches.has to yes when a user picks something up. (note that we don't use booleans True|False since everything in this engine is currently a string)

Then we can check if the user has matches when they try to light a lamp:

      # user says this
      - match: use matches (on|with) lamp
        # check ALL these conditions
        # does user has matches?
        if:
          all:
            - matches.has = yes
        # if true then do this
        then:
          # reply and set property on the 'lamp' object
          reply: You light the lamp with the matches
          setProps:
            - lamp.state = lit
        # otherwise if NOT matches.has say this:
        else:
          reply: you don't have any matches

Then later you could check if the light is on:

      # user says this
      - match: search room|look around|look for .*
        if:
          all:
            - lamp.state = lit
        then:
          reply: You look around then room...
        else:
          reply: It's too dark... if only there was a light to see?

Match Syntax

Called

We also do replacements using the called section for objects.

      - name: lamp
        called: light|lamp|torch|flashlight

So anywhere the user types in torch it would replace with lamp so you don't have to put all the options into your match phrases.

RegEx

All match commands are using RegEx syntax, so you can have options in brackets like:

- match: (use matches on lamp|light lamp|turn the lamp on)

and much more!

Then later use lamp and use light should both work.

NLP

This engine is also actually connected to an NLP parser using word vectors for approximation of semantic meaning, and also we do spelling correction. So turn light on should match turn lamp on with ~70% confidence. That's a little outside this basic tutorial though.

Tips and Tricks

  • goto Is used to goto another room. the room is named at it's top block. On entering a room the states.default will get shown. It's good to add a prompt for what the user should say/do.
rooms:
  - name: goals
    states:
      - name: default
        long: "Let's talk about goals.
          \nType start when you're ready to begin."
  • after Allows you to trigger another match block after the current one. This Should be an array type so you can trigger a bunch of things:
      - match: start|ok|🚀
        always:
          reply: Okay, now tell me how you did with your goals
          after:
            - goals

Editing story files

You can edit files right inside the githb web interface. This is quick, but not that convenient if you're making a lot of changes.

next: read about how to edit files and use github!