From c2922a2d5ba38ad61683ef60e38b27406d6f5572 Mon Sep 17 00:00:00 2001 From: Evan Hemsley <2342303+ehemsley@users.noreply.github.com> Date: Sun, 9 Jun 2019 20:23:41 -0700 Subject: [PATCH] adding more beginner friendly getting started stuff --- content/_index.md | 2 +- content/getting_started/case_study_love.md | 2 +- content/getting_started/editor.md | 11 +++++++++++ content/getting_started/project_structure.md | 2 +- content/getting_started/terminal.md | 13 +++++++++++++ content/getting_started/version_control.md | 13 +++++++++++++ 6 files changed, 40 insertions(+), 3 deletions(-) create mode 100644 content/getting_started/editor.md create mode 100644 content/getting_started/terminal.md create mode 100644 content/getting_started/version_control.md diff --git a/content/_index.md b/content/_index.md index 7abae0b..60c44cc 100644 --- a/content/_index.md +++ b/content/_index.md @@ -15,4 +15,4 @@ Encompass is currently available with a TypeScript implementation that fully sup A C# implementation is forthcoming. -If you are here to learn how to use Encompass and don't care about the justifications for it, I recommend skipping ahead to [Chapter 2](getting_started). +If you are here to learn how to use Encompass and don't care about the justifications for it, or you've never made a game before, I recommend skipping ahead to [Chapter 2](getting_started). diff --git a/content/getting_started/case_study_love.md b/content/getting_started/case_study_love.md index 24ae0eb..6340a40 100644 --- a/content/getting_started/case_study_love.md +++ b/content/getting_started/case_study_love.md @@ -1,7 +1,7 @@ --- title: "Case Study: LÖVE" date: 2019-05-22T10:38:01-07:00 -weight: 10 +weight: 12 --- First, install [LÖVE](https://love2d.org). diff --git a/content/getting_started/editor.md b/content/getting_started/editor.md new file mode 100644 index 0000000..ab6c7eb --- /dev/null +++ b/content/getting_started/editor.md @@ -0,0 +1,11 @@ +--- +title: "The Text Editor" +date: 2019-06-09T20:12:16-07:00 +weight: 9 +--- + +You will want some kind of text editor to develop Encompass projects. + +I _highly_ recommend [VSCodium](https://vscodium.com/) if you are on Windows or OSX, and Code - OSS if you are on Linux. These are open-source distributions of Microsoft's VSCode editor, which features excellent Typescript integration and various convenient features, like an integrated Git interface and terminal. (Make sure you set the terminal to Git Bash if you are on Windows - this is under File -> Settings.) + +Of course, if you prefer some other editor, that will be perfectly fine. diff --git a/content/getting_started/project_structure.md b/content/getting_started/project_structure.md index 35297d2..be99425 100644 --- a/content/getting_started/project_structure.md +++ b/content/getting_started/project_structure.md @@ -16,6 +16,6 @@ If we look at the Encompass/LÖVE starter project, it looks like this: **game/game.ts** contains a class that defines three methods that are called by LOVE: load, update, and draw. They do what it says on the tin. You will set up your WorldBuilder in the load method. (We'll talk about that in a bit.) -The rest of it is pretty straightforward. Put your music and sprites and such in the **assets** folder. Define your components in the **components** folder, your engines in the **engines** folder, your messages in the **messages** folder, and your renderers in the **renderers** folder. (Again, we'll start getting into exactly how to define Encompass these in a minute.) +The rest of it is pretty straightforward. Put your music and sprites and such in the **assets** folder. Define your components in the **components** folder, your engines in the **engines** folder, your messages in the **messages** folder, and your renderers in the **renderers** folder. (Again, we'll start getting into exactly how to define these in a minute.) Finally, a quick note about **helpers**. I like to use classes with static methods for common behaviors that will be useful for many different engines, for example a `Color` class with a `hsv_to_rgb` conversion function. Be careful not to abuse helpers. If your helpers need to be instantiated, that is usually a sign that the behavior belongs in an engine. diff --git a/content/getting_started/terminal.md b/content/getting_started/terminal.md new file mode 100644 index 0000000..469694c --- /dev/null +++ b/content/getting_started/terminal.md @@ -0,0 +1,13 @@ +--- +title: "The Terminal" +date: 2019-06-09T20:05:57-07:00 +weight: 8 +--- + +Which operating system are you using? + +If you are on OSX, great! You have an app called Terminal. You can use it to build and run Encompass projects. + +If you are on Linux, great! You are probably a pretty savvy user, but just in case, you probably have a program called Terminal or Konsole on your machine. You can use it to build and run Encompass projects. + +If you are on Windows... things get a bit trickier. The built-in terminals are garbage. I recommend installing [Git For Windows](https://git-scm.com/downloads) and installing Git Bash when it asks you which terminal you want. It's good enough. diff --git a/content/getting_started/version_control.md b/content/getting_started/version_control.md new file mode 100644 index 0000000..1f89ad3 --- /dev/null +++ b/content/getting_started/version_control.md @@ -0,0 +1,13 @@ +--- +title: "Version Control" +date: 2019-06-09T20:17:54-07:00 +weight: 10 +--- + +I _strongly_ recommend using some kind of source control software. It is incredibly foolish to develop without it. Version control lets you make changes to your code without worrying about irreparably ruining your code base, so you can make changes with peace of mind. + +I strongly recommend [Git](https://git-scm.com/). You'll have to download and install it if you're on Windows. + +There is an excellent tutorial on how to use Git [on the Git website](https://git-scm.com/book/en/v2/Getting-Started-About-Version-Control). + +The basic Git workflow is this: when you make changes, you review them and "stage" them, and then "commit" them with a message. Think of a commit as freezing your code at a particular place in time. You can always revert to this exact place once you commit. It's incredibly useful.