summaryrefslogtreecommitdiff
path: root/docs/create-a-module.md
blob: ae70905433e27a409c0aa339595f77f21ca6f12d (plain)
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
---
redirect_from: "/Create-a-Module"
---

# Create a Module

## **How to create a module**

Before start we suggest you to read [Documentation about modular structure](The-Modular-Structure) to understand the way AzerothCore works.

### Resources

- Module template: [https://github.com/azerothcore/skeleton-module](https://github.com/azerothcore/skeleton-module)
- Script template: https://github.com/azerothcore/azerothcore-boilerplates
- All the hooks in the core are listed in [ScriptMgr.h](https://github.com/azerothcore/azerothcore-wotlk/blob/master/src/server/game/Scripting/ScriptMgr.h). If you need custom hooks, they can be added to the core by [sending a PR](https://www.azerothcore.org/wiki/How-to-create-a-PR).

- If you need to create a new hook for your module, please follow this guide: [How to create a new hook](hooks-script.md)

### **The Basis**

1. Create a folder inside modules/ directory

2. Now you can develop add anything to the main project, such as some scripts or 
even an entire library

Note: we suggest to use the [directory structure](Directory-Structure) standards of AzerothCore to better organize your modules and be familiar with main project.

### **Add the first script**

1. Before continue, we suggest you to follow our guide on how to create a script for AzerothCore

2. After you’ve created your script you’ve to create a .cpp file to handle the script loading.

  For example ( Assuming you’ve created an src folder ):

  **my_custom_loader.cpp**

 ```cpp
// From SC
void AddMyCustomScripts();

// Add all
// cf. the naming convention https://github.com/azerothcore/azerothcore-wotlk/blob/master/doc/changelog/master.md#how-to-upgrade-4
// additionally replace all '-' in the module folder name with '_' here
void Addmod_my_customScripts()
{
    AddMyCustomScripts();
}
```

  NOTE: AddMyCustomScripts is composed by: 

  Add (Prefix)

  MyCustom (An unique name identifier for your script to avoid function collisions)

  Scripts ( Suffix )

### **Create a custom configuration file**

if you need to add a custom configuration file to your module that will be installed with server, the steps are very simple.

1. Add a file with the extension `.conf.dist` in folder `./conf`
2. Done. Yes, really, that's all there is to it.

### **Add your db files to db_assembler**

you are able to create base, updates and custom sql that will be automatically loaded in our db_assembler

**work in progress….**