You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Glad you're reading this and hopefully this guide will help you start contributing to this codebase!
First a word of wisdom. Start small with your first set of PRs even if you are already experienced with developing for other languages or codebases. Every codebase has its own quirks and standards which you will discover by doing and receiving feedback on your work.
This guide will help you set up your git and make your first PR. It will also include some tips on how to (in my opinion) best handle the codebase.
This guide will assume that you have at least (very) minor knowledge of how programming works. Knowing what a string is and how if statements work for example. The guide will also assume that you will use VS Code which the Setup section helps you set up.
Be sure to also take a look at the contributing page so you know what the coding standards are here.
I've also made a debugging tutorial which will help you find the cause of bugs and how to fix them.
For more in-depth tutorials visit the wiki pages. SS13 code (beginner) and SS13 Code (experienced)
The DM reference guide is also great when you want to look up how a proc or such works. VS Code does have a build-in reference guide for you to use as well. Just CTRL-Click on any Byond proc or variable to see the reference on it.
Before you start coding it is best to read ourcontributing page. It contains all of the coding standards and some tips and tricks on how to write good and safe code.
I was going to make a step by step guide on here but our guide to contributing wiki page has a very extensive and comprehensible guide on how you set up your Git, GitHub and Visual Studio Code. I recommend following the guide over there and returning here once that is done.
I would 100% recommend using VS Code even though you could use another editor to make code changes. VS Code has a lot of great extensions which will make your life a whole lot easier. Things like debugging and just a great global search functionality.
I'd suggest keeping it small since setting up all of the git stuff was already a task of its own.
My suggestion would be to look at issues with the Good First Issue label. These usually are considered to be easy to solve.
Usually, they will also contain some comments containing hints on how to solve them. When picking one be sure that you do not pick an issue that already has an open PR attached to it like in the picture below.
You can make a PR that solves that issue. But it would be a waste of time since somebody else already solved it before you but their PR is still awaiting approval.
If there are no suitable good first issues then you can look through the issue list yourself to find some. Good ones include typos or small logic errors. If you know of any issues that are not yet listed in the issues list then those are also fine candidates.
Alternatively, you can implement a small new feature or change. Good examples include:
More or changed flavour text to an item/ability etc.
Adding (existing) sound effects to abilities/actions.
Adding administrative logging where it is missing. For example, a martial arts combo not being logged.
A new set of clothing or a simple item.
There of course are many more options that are not included in this list.
If you did not create a new branch in the Setup phase. Then you are still fine. Before committing make a new branch from your master branch. If you have already done this then skip two steps forward.
Select "Create new branch" and then give your new branch a name in the top text bar in VS code. Press enter once you are done and you will have created a new branch. Your saved changes will be carried over to the new branch.
You are ready to commit the changes once you are on your feature branch and when the code is done and tested.
Simply write a (short) useful commit message explaining what you've done.
For example when implementing the pet collar gibbing example
Here you can also see the changes you have made. Clicking on a file will show you the difference between how it was before and how it is now.
When you are happy with the existing changes you can press the commit button. The checkmark. By default it will commit all the changes there are unless you staged changes. Then it will only commit the staged changes. Handy when you want to commit some code while you have some experimental code still there.
Once it is committed you will have to also publish the branch.
When pressing push it will ask you if you want to publish the branch since there is no known remote version of this yet (not on Github). Say yes to that and select "origin" from the list of available remotes. Now your code is safely pushed to Github.
Now go to the Github page of this codebase and you will see the following:
Click on the green button and Github will auto-create a PR template for you for the branch you just pushed.
Be sure to fill in the template shown to you. It is quite straight forward but it is important to note down the thing you changed in enough detail.
If you fixed an issue then you can write the following fixes #12345 where 12345 is the number of the issue. Put this line of text in the What Does This PR Do part of the PR.
You can submit it once you are happy with how the PR looks. After this, your PR will be made public and visible to others to review. In due time a maintainer will look at your PR and will merge it if it is deemed an addition to the codebase.
reacted with thumbs up emoji reacted with thumbs down emoji reacted with laugh emoji reacted with hooray emoji reacted with confused emoji reacted with heart emoji reacted with rocket emoji reacted with eyes emoji
-
Table of contents
Intro
Glad you're reading this and hopefully this guide will help you start contributing to this codebase!
First a word of wisdom. Start small with your first set of PRs even if you are already experienced with developing for other languages or codebases. Every codebase has its own quirks and standards which you will discover by doing and receiving feedback on your work.
This guide will help you set up your git and make your first PR. It will also include some tips on how to (in my opinion) best handle the codebase.
This guide will assume that you have at least (very) minor knowledge of how programming works. Knowing what a
string
is and howif
statements work for example. The guide will also assume that you will use VS Code which the Setup section helps you set up.Be sure to also take a look at the contributing page so you know what the coding standards are here.
I've also made a debugging tutorial which will help you find the cause of bugs and how to fix them.
Quick DM tutorial
For your first PR you won't need an in-depth knowledge of how to code in DM/SS13 but here are some of the basics that go for DM/SS13.
Feel free to skip these and come back to this once you feel like you are missing some info.
For more in-depth tutorials visit the wiki pages. SS13 code (beginner) and SS13 Code (experienced)
The DM reference guide is also great when you want to look up how a proc or such works. VS Code does have a build-in reference guide for you to use as well. Just CTRL-Click on any Byond proc or variable to see the reference on it.
Object definitions (inheritance)
An object is defined the following way:
Here we can see a
multitool
being defined. Amultitool
is anitem
which is anobj
. This is how the class inheritance works for DM. A real-life example is that a dog is an animal and a cat is an animal. But a dog is not a cat. In DM it could look something like this:Where
mob
is a being in DM. Thus something that "lives" and can do things.Procs (methods/functions)
The way DM groups a set of instructions is as follows. It uses a
proc
or in other languages also called a method or function./obj/item/pen/multi/proc/select_colour
here is the proc definition. Meaning this is the first instance of this proc. For this, you need to addproc/
in front of the method name (select_colour
in this case).mob/user
is here a parameter given to the proc. The name of the parameter isuser
and its type ismob
.As with other languages you can also override the behaviour of a proc.
Here the proc
attack_self
is overridden with new behaviour. It will callselect_colour
with as a parameter the givenuser
.When overriding a proc you can also call the parents implementation. This is especially handy when you want to extend the existing behaviour with new behaviour.
Here
Initialize
is overridden withmapload
as a parameter...()
means call the parent implementation of this proc with the parameters given to this version. Somapload
will be passed through.. = ..()
means assign the value that the parent's version returns as our default return value..
is the default return value in DM. So if you don't return an explicit value at the end of the proc then.
will be returned.This will return
"No"
since you explicitly state to return"No"
.Small tip. You can also CTRL + Click on
..()
to go to the parent's definition.Putting values easily in strings
Other languages use something like
string.format("{0} says {1}", mob_name, say_text)
. But DM has something nifty for that.The same result can be achieved in DM using the following:
[...]
will run the code and return the outcome inside the[]
. In the case above it will just return the value of the variables but you can also use logic here.Which will produce
"val is 1. val plus 10 is: 11"
Scoping
If you come from another language then you might think. "Hey, where are the {}'s?!". Well, we do not use those (usually).
Instead scoping is done by whitespace. Tabs in our case. One tab means one scope deeper.
In VS Code you can make your life easier by turning on the rendering of whitespace. Go to the settings and search for whitespace.
data:image/s3,"s3://crabby-images/24673/246735672cde41d81efc5c861047f68953f43dfa" alt="image"
I have set it up so that I can only see the boundary whitespace. Meaning that I visually see spaces and tabs on the outmost left and right side of a line. Very handy in spotting indentation errors.
Deleting stuff
DM has a build-in proc called
del
. DO NOT USE THIS.del
is very slow and gives us no control over properly destroying the object. Instead, most/all SS13 codebases have made their own version for this.qdel
which will queue a delete for a given item. You should always callqdel
when deleting an object. This will not only be better performance-wise but it will also ensure that other objects get notified about its deletion if needed.Coding Standards
Before you start coding it is best to read our contributing page. It contains all of the coding standards and some tips and tricks on how to write good and safe code.
Terminology
Here is some terminology that will be used in the later text.
Setup
I was going to make a step by step guide on here but our guide to contributing wiki page has a very extensive and comprehensible guide on how you set up your Git, GitHub and Visual Studio Code. I recommend following the guide over there and returning here once that is done.
I would 100% recommend using VS Code even though you could use another editor to make code changes. VS Code has a lot of great extensions which will make your life a whole lot easier. Things like debugging and just a great global search functionality.
Your First PR
Once you've completed the setup you can continue with making an actual PR.
I'd suggest keeping it small since setting up all of the git stuff was already a task of its own.
data:image/s3,"s3://crabby-images/bec5a/bec5ada04f327778d145ba5f42620c308bdb9351" alt="image"
My suggestion would be to look at issues with the Good First Issue label. These usually are considered to be easy to solve.
Usually, they will also contain some comments containing hints on how to solve them. When picking one be sure that you do not pick an issue that already has an open PR attached to it like in the picture below.
You can make a PR that solves that issue. But it would be a waste of time since somebody else already solved it before you but their PR is still awaiting approval.
If there are no suitable good first issues then you can look through the issue list yourself to find some. Good ones include typos or small logic errors. If you know of any issues that are not yet listed in the issues list then those are also fine candidates.
Alternatively, you can implement a small new feature or change. Good examples include:
There of course are many more options that are not included in this list.
Finding The Relevant Code
The first thing you will need to do is to find the relevant code once you figured out what you want to add/change.
This is no exact science and requires some creative thinking but I will list a few methods I use myself when finding code.
For all of these, you will need to have VS code open and use the search functionality. I tend to only look for things in dm files. Which are the code files.
data:image/s3,"s3://crabby-images/c52c7/c52c7edf2e6909b01058a3dcf6b5c6d2ca341501" alt="image"
Finding Existing Items
If you're looking for an existing item then it might be easiest to look for the name of the item. Let's take a multitool as an example here.
When looking for the term
data:image/s3,"s3://crabby-images/052fc/052fc795dcf2a2da6c5c95d88fb35aa90c567c5d" alt="image"
data:image/s3,"s3://crabby-images/0c856/0c856ff6124b51a5ee99ffa3380ef077e79c03c0" alt="image"
multitool
you will tend to find a lot of results. 305 results on my current version of the game in fact.Alternatively, you can search for
"multitool"
(the string with the valuemultitool
) and find a lot fewer results. For demonstration purposes, I will exclude the""
here. This will give you the following match:This might seem like a lot (and it is) but you don't have to go through them all to find the item itself. Using some deduction we can find the result we need. Or find it via another result we found.
data:image/s3,"s3://crabby-images/bf06d/bf06d764ba8be0441aef08baf2fd13a21783bac9" alt="image"
Here we can see that there are some matches with
obj/item/multitool
for example:We know that we are looking for a multitool and that a multitool is an item so it looks like this is what we want to find.
data:image/s3,"s3://crabby-images/3ad4e/3ad4e9eca253e8ceceae6634743c7d6c8de1d568" alt="image"
When hovering over the
multitool
part ofobj/item/multitool
and holding the CTRL key you will see the definition of the object.Perfect! This is the one we need. How how do we get to that definition? Simple you click on
multitool
when holding CTRL.This will send you to the definition of the object.
Most of the times the file containing the definition will also include the looked for proc or value you want to change.
Finding Behaviour
This is a very wide concept and thus hard to exactly find.
data:image/s3,"s3://crabby-images/2ea2d/2ea2d9d683dbb953962bcee69393d0f26420b82f" alt="image"
For this, we will use the above method and use keywords explaining the behaviour you want to search. For example a mob gibbing.
Simply looking for
gib
here will find us too many results. About 1073 in my case.Instead, we will try to look for a proc named gib.
/gib(
will be used as our search criteria here.Et voila, just 15 results.
Say we want to delete the pet collar of animals such as Ian when he is gibbed. Here we need to find something stating that the
data:image/s3,"s3://crabby-images/f10fc/f10fcde8e9c95eaeb4d2757c5547ccbf27558758" alt="image"
gib
belongs to an animal./mob/living/simple_animal/gib()
is what we are looking for here. Ian is an animal.simple_animal
in code.This will find us the following code (on my current branch)
The behaviour we're looking for here has to do with the
pcollar
code there. It will currently move the attached pet collar (if any) to the drop location of the animal when they are gibbed.Finding A Suitable Place To Add A New Item
When adding a new item you want to ensure that it is placed in a logical file or that you make a new file in a logical directory.
data:image/s3,"s3://crabby-images/69a42/69a426125f841a35da7d07099a07a6dfc5e83052" alt="image"
I find that it is best to find other similar items and see how they are defined. For example a special jumpsuit without armour values.
Here we first go look for the existing non-job-related jumpsuits such as the
"mailman's jumpsuit"
. Say we don't know the exact name of that jumpsuit but we do know that it is for a mailman.Our best bet will be to look for the term
mailman
and see what pops up. This is a rather uncommon term so it should give only a few results.Perfect. Even the item definition has the name mailman in it.
We already see from the search results that the item is defined in the
data:image/s3,"s3://crabby-images/87b05/87b0556cef96dedc2ff5609b5c1f04a51ccf6e63" alt="image"
miscellaneous.dm
file. Navigating to it will show us the directory it is in.As you can see most clothing items are defined in this
clothing
directory. Depending on your to add the item you can pick one of those files and see if it would fit in there. Feel free to ask for advice from others if you are unsure.Solving The Actual Issue
Now comes the Fun part. How to achieve what you want to achieve?
The answer is. "That depends" Fun, isn't it?
Every problem has its own way of solving it. I will list some of the more common solutions to a problem down here. This list will of course not be complete.
A great hotkey for building your code quick is CTRL SHIFT B. Then press enter to select to build via Byond. This will start building your code in the console at the bottom of your screen (by default). It will also show any errors in the build process.
data:image/s3,"s3://crabby-images/b0b32/b0b3230989baffcba5497a962295e9c2b79002d8" alt="image"
Here I have "accidentally" placed some text where it should not belong. Going to the "Problems" tab and clicking on the error will bring you to where it goes wrong.
data:image/s3,"s3://crabby-images/71570/715707e5cefe83afb555c1aa62f3cc2ce77a830a" alt="image"
This error does not tell much on its own (Byond is not great at telling you what goes wrong sometimes) but going to the location shows the problem quite easily.
data:image/s3,"s3://crabby-images/f15ff/f15ff61dffc4319e657c540356aaae03cc0b040c" alt="image"
More cases might be added later.
Typo Or Grammar
The easiest of them all if you can properly speak English.
Say the multitool description text is as follows
"Used for pusling wires to test which to cut. Not recommended by doctors."
Then you can easily fix the typo by just changing the value of the string to the correct spelling.
Wrong Logic
This one really depends on the context. But let us take the following example. You cannot link machinery using a multitool. Something it should do.
Here a simple mistake is made. A
!
is forgotten.!
will negate the outcome of any given value. In this case, a check to see ifM
is indeed a piece of machinery. This seems dumb to forget or do wrong but it can happen when a large PR gets made and is changed often. Testing every case is difficult and cases can slip under the radar.Adding A New Item
You can start defining the new item once you found the proper file the item should belong to.
Depending on the item you will have to write different code (duh). We will take the new jumpsuit as an example again and will put it in the
miscellaneous
file.When defining a new jumpsuit you can easily copy an existing one and change the definition values. We will take the mailman outfit as a template.
As seen here a jumpsuit has multiple values you can define. The
name
is pretty straight forward.desc
is the description of the item.icon_state
is the name the sprite has in the DMI file.item_state
is the name of the sprite of the suit while held in your hands has in the DMI file.item_color
is the name of the sprite in theicons/mob/uniform.dmi
file. This value will indicate what sprite will be used when a person wears this jumpsuit. (I knowitem_color
is a weird name for this)We of course also have to change the path of the newly created object. We'll name it
/obj/item/clothing/under/rank/tutorial
.This alone will make it so that you can spawn the item using admin powers. It will not automagically appear in vendors or such.
Testing Your Code
Once you are done coding you can start testing your code, assuming your code compiles of course.
To do this simply press F5 on your keyboard. This will by default build your code and start the game with a debugger attached. This allows you to debug the code in more detail.
Later I will include a more detailed testing plan in this guide.
Making The PR
Once you are done with your changes you can make a new PR.
If you did not create a new branch in the Setup phase. Then you are still fine. Before committing make a new branch from your master branch. If you have already done this then skip two steps forward.
data:image/s3,"s3://crabby-images/b417e/b417e59e5070c8ef294da594a77c75b8015c6db3" alt="image"
Select "Create new branch" and then give your new branch a name in the top text bar in VS code. Press enter once you are done and you will have created a new branch. Your saved changes will be carried over to the new branch.
data:image/s3,"s3://crabby-images/6220c/6220ccc3aa7f75289d9dbee678eaa516f0757e65" alt="image"
You are ready to commit the changes once you are on your feature branch and when the code is done and tested.
data:image/s3,"s3://crabby-images/e7b39/e7b39321e5b8f017bd230a5565baee1cf335ee39" alt="image"
Simply write a (short) useful commit message explaining what you've done.
For example when implementing the pet collar gibbing example
Here you can also see the changes you have made. Clicking on a file will show you the difference between how it was before and how it is now.
When you are happy with the existing changes you can press the commit button. The checkmark. By default it will commit all the changes there are unless you staged changes. Then it will only commit the staged changes. Handy when you want to commit some code while you have some experimental code still there.
Once it is committed you will have to also publish the branch.
data:image/s3,"s3://crabby-images/82d4b/82d4b934be004580552599dfee1528e1f5fdd2dc" alt="image"
When pressing push it will ask you if you want to publish the branch since there is no known remote version of this yet (not on Github). Say yes to that and select "origin" from the list of available remotes. Now your code is safely pushed to Github.
Now go to the Github page of this codebase and you will see the following:
data:image/s3,"s3://crabby-images/1411b/1411be09d5bcfdcc66ce7bc78bcd1d294e9f5099" alt="image"
Click on the green button and Github will auto-create a PR template for you for the branch you just pushed.
Be sure to fill in the template shown to you. It is quite straight forward but it is important to note down the thing you changed in enough detail.
If you fixed an issue then you can write the following
fixes #12345
where 12345 is the number of the issue. Put this line of text in the What Does This PR Do part of the PR.You can submit it once you are happy with how the PR looks. After this, your PR will be made public and visible to others to review. In due time a maintainer will look at your PR and will merge it if it is deemed an addition to the codebase.
Tips And Tricks
Here I will list some of my tips and tricks that can be useful for you when developing our codebase.
preLaunchTask
line in the debug config:TODOs
This guide is far from final and will later include the following topics:
Be sure to comment your suggestions for this guide as that will help me improve it!
Beta Was this translation helpful? Give feedback.
All reactions