Difference between revisions of "Making an API (tutorial)"

From ComputerCraft Wiki
Jump to: navigation, search
(Including the API: Added info on absolute path definition)
Line 1: Line 1:
 +
== Making an API ==
  
== MAKING AN API - a tutorial by TheVarmari ==
+
An API is a program that is not directly executed, but is a collection of variables that can be accessed from any program on that computer.
'''NOTE:''' There is a better tutorial in the [http://www.computercraft.info/forums2/ forums] located [http://www.computercraft.info/forums2/index.php?/topic/145-tutorial-creating-an-api/ here].
+
Use this if you prefer to use ccwiki.
+
  
 +
To make an API, you must create a new file. I will call it ''myapi''. Fill it with variable declarations as normal, but without the ''local'' keyword:
  
== Introduction ==
+
<pre>
Hello, dear Computercraft Wiki user!
+
-- My awesome new API
Today I will tell you how to make a functional API (Application Programming Interface).
+
Let's get started!
+
  
 +
myvar = "Hello World!"
  
== Making the API file ==
+
function myCoolNewFunction()
First we need to define what our API will be called.
+
    print(myvar)
In this case, I use exampleAPI.
+
end
Now edit the file you want your API to be called.
+
</pre>
<!--NOTE: If it exists, call it something else-->
+
  
=== The code ===
+
Now try it out. Save and exit the file, then open the ''lua'' program on your ingame computer. Then type:
Now, we need to put some functions in it!
+
Why don't we start with the basics:
+
  
 
<pre>
 
<pre>
-- this is the file exampleAPI
+
os.loadAPI("myapi") -- replace myapi with the name of your API.
-- our first function:
+
myapi.myCoolNewFunction()
function printMessage(message)
+
  print(message)
+
end
+
 
</pre>
 
</pre>
Which basically prints "message" when excecuted.
 
Save the file.
 
  
=== Including the API ===
+
If you have written the program correctly, you will see ''Hello World!'' printed to your screen. Now try:
Now that we have the API done, let's include it in some file!
+
Because we speak about APIs, we can't directly execute it.
+
  
Edit the file you want to include the API in.
 
In my case, it is called exampleAPI.
 
Now, we include the API in it by typing this to the '''first''' row:
 
 
<pre>
 
<pre>
os.loadAPI("exampleAPI")
+
print(myapi.myvar)
 
</pre>
 
</pre>
This loads the API into the file's memory. Keep in mind that if your API is in a folder, you must include the absolute path to the file:
+
 
 +
You should also see ''Hello World!'' printed to your screen. Congratulations, this is your first API!
 +
 
 +
 
 +
== Locals vs Globals ==
 +
 
 +
OK, lets go back to our API.
 +
 
 
<pre>
 
<pre>
os.loadAPI("someFolder/exampleAPI")
+
-- My awesome new API
 +
 
 +
myvar = "Hello World!"
 +
 
 +
function myCoolNewFunction()
 +
    print(myvar)
 +
end
 
</pre>
 
</pre>
'''NOTE:''' If you want your API to be loaded on every computer, copy your file to ''.minecraft\mods\ComputerCraft\lua\rom\apis\''.
 
  
=== Using the API ===
+
If we change our declaration for myvar to local, like this:
Now that that's over, let's include the printMessage command from our API.
+
Lua loads API's as tables, so you have to use api_name.function_name(function_arguments)
+
  
In my case, I use
+
<pre>
<code>
+
-- My awesome new API
exampleAPI.printMessage("message")
+
</code>
+
Ta-da! It printed out "message"!
+
  
== A couple of words ==
+
local myvar = "Hello World!"
Thank you for reading this tutorial, it sure was fun to make!
+
 
Correct any mistakes I did!  
+
function myCoolNewFunction()
[[User:TheVarmari|TheVarmari]] 16:59, 22 February 2012 (UTC)
+
    print(myvar)
 +
end
 +
</pre>
 +
 
 +
we should get the same result if we call myCoolNewFunction(). '''REMEMBER: you will need to load the API again to apply your changes!'''
 +
 
 +
But what happens if you try ''print(myapi.myvar)''?
 +
 
 +
<pre>
 +
 
 +
</pre>
 +
 
 +
It prints nothing. This is because we changed the declaration for myvar to local! This is useful if you want to have a variable visible to only your API. It will also work with functions, like this.
 +
 
 +
<pre>
 +
-- My awesome new API
 +
 
 +
local myvar = "Hello World!"
 +
 
 +
local function myCoolNewFunction()
 +
    print(myvar)
 +
end
 +
</pre>
  
[[Category:Tutorials]]
+
Now if you try to call myCoolNewFunction(), you will get an ''attempt to call nil'' error.

Revision as of 02:35, 26 October 2013

Making an API

An API is a program that is not directly executed, but is a collection of variables that can be accessed from any program on that computer.

To make an API, you must create a new file. I will call it myapi. Fill it with variable declarations as normal, but without the local keyword:

-- My awesome new API

myvar = "Hello World!"

function myCoolNewFunction()
    print(myvar)
end

Now try it out. Save and exit the file, then open the lua program on your ingame computer. Then type:

os.loadAPI("myapi") -- replace myapi with the name of your API.
myapi.myCoolNewFunction()

If you have written the program correctly, you will see Hello World! printed to your screen. Now try:

print(myapi.myvar)

You should also see Hello World! printed to your screen. Congratulations, this is your first API!


Locals vs Globals

OK, lets go back to our API.

-- My awesome new API

myvar = "Hello World!"

function myCoolNewFunction()
    print(myvar)
end

If we change our declaration for myvar to local, like this:

-- My awesome new API

local myvar = "Hello World!"

function myCoolNewFunction()
    print(myvar)
end

we should get the same result if we call myCoolNewFunction(). REMEMBER: you will need to load the API again to apply your changes!

But what happens if you try print(myapi.myvar)?


It prints nothing. This is because we changed the declaration for myvar to local! This is useful if you want to have a variable visible to only your API. It will also work with functions, like this.

-- My awesome new API

local myvar = "Hello World!"

local function myCoolNewFunction()
    print(myvar)
end

Now if you try to call myCoolNewFunction(), you will get an attempt to call nil error.