2004-11-28 09:17:16 +01:00
|
|
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
|
|
|
|
"http://www.w3.org/TR/html4/strict.dtd">
|
|
|
|
<html>
|
|
|
|
|
|
|
|
<head>
|
|
|
|
<meta name="description" content="LuaSocket: Introduction to the core">
|
|
|
|
<meta name="keywords" content="Lua, LuaSocket, TCP, UDP, Network, Support,
|
|
|
|
Installation">
|
|
|
|
<title>LuaSocket: Instalation</title>
|
|
|
|
<link rel="stylesheet" href="reference.css" type="text/css">
|
|
|
|
</head>
|
|
|
|
|
|
|
|
<body>
|
|
|
|
|
|
|
|
<!-- header +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
|
|
|
|
|
|
|
<div class=header>
|
|
|
|
<hr>
|
|
|
|
<center>
|
|
|
|
<table summary="LuaSocket logo">
|
|
|
|
<tr><td align=center><a href="http://www.lua.org">
|
|
|
|
<img width=128 height=128 border=0 alt="LuaSocket" src="luasocket.png">
|
|
|
|
</a></td></tr>
|
|
|
|
<tr><td align=center valign=top>Network support for the Lua language
|
|
|
|
</td></tr>
|
|
|
|
</table>
|
|
|
|
<p class=bar>
|
|
|
|
<a href="home.html">home</a> ·
|
|
|
|
<a href="home.html#download">download</a> ·
|
|
|
|
<a href="instalation.html">instalation</a> ·
|
|
|
|
<a href="introduction.html">introduction</a> ·
|
|
|
|
<a href="reference.html">reference</a>
|
|
|
|
</p>
|
|
|
|
</center>
|
|
|
|
<hr>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<!-- instalation ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
|
|
|
|
|
|
|
<h2>Instalation</h2>
|
|
|
|
|
2004-11-29 07:55:47 +01:00
|
|
|
<p> LuaSocket 2.0 uses the new package proposal for Lua 5.1.
|
|
|
|
All Lua library developers are encouraged to update their libraries so that
|
|
|
|
all libraries can coexist peacefully and users can benefit from the
|
|
|
|
standardization and flexibility of the standard.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
The proposal was considered important enough by some of us to justify
|
|
|
|
early adoption, even before release of Lua 5.1.
|
|
|
|
Thus, a compability module
|
|
|
|
<a href=http://www.keplerproject.org/compat/>compat-5.1</a>
|
|
|
|
has been released in conjunction with Roberto Ierusalimschy and <a
|
|
|
|
href=http://www.keplerproject.org/">The Kepler Project</a> team.
|
|
|
|
It implements the Lua 5.1 package proposal on top of Lua 5.0. </p>
|
2004-11-28 09:17:16 +01:00
|
|
|
|
|
|
|
<p> As far as LuaSocket is concerned, this means that whoever is
|
2004-11-29 07:55:47 +01:00
|
|
|
deploying a non-standard distribution of LuaSocket will probably
|
|
|
|
have no problems customizing it. Here we will only describe the standard distribution. If the standard doesn't meet your
|
|
|
|
needs, we refer you to the Lua discussion list, where any question about
|
|
|
|
the package scheme will likely already have been answered.
|
2004-11-28 09:17:16 +01:00
|
|
|
</p>
|
|
|
|
|
|
|
|
<h3>Directory structure</h3>
|
|
|
|
|
2004-11-29 07:55:47 +01:00
|
|
|
<p> The standard distribution reserves a directory to be the root of
|
|
|
|
the libraries installed
|
2004-11-28 09:17:16 +01:00
|
|
|
on a given system. Let's call this directory <tt><ROOT></tt>.
|
|
|
|
On my system, this is the <tt>/usr/local/share/lua/5.0</tt> directory.
|
|
|
|
Here is the standard LuaSocket distribution directory structure:</p>
|
|
|
|
|
|
|
|
<pre class=example>
|
|
|
|
<ROOT>/compat-5.1.lua
|
|
|
|
<ROOT>/socket.lua
|
|
|
|
<ROOT>/lsocket.dll
|
|
|
|
<ROOT>/mime.lua
|
|
|
|
<ROOT>/lmime.dll
|
|
|
|
<ROOT>/ltn12.lua
|
|
|
|
<ROOT>/socket/http.lua
|
|
|
|
<ROOT>/socket/tp.lua
|
|
|
|
<ROOT>/socket/ftp.lua
|
|
|
|
<ROOT>/socket/smtp.lua
|
|
|
|
<ROOT>/socket/url.lua
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<p> Naturally, on Unix systems, <tt>lsocket.dll</tt> and <tt>lmime.dll</tt>
|
|
|
|
would be replaced by <tt>lsocket.so</tt> and <tt>lmime.so</tt>. In Mac OS
|
|
|
|
X, they would be replaced by <tt>lsocket.dylib</tt> and
|
|
|
|
<tt>lmime.dylib</tt>. </p>
|
|
|
|
|
|
|
|
<p> In order for the interpreter to find all LuaSocket components, three
|
|
|
|
environment variables need to be set. The first environment variable tells
|
2004-11-29 07:55:47 +01:00
|
|
|
the interpreter to load the <tt>compat-5.1.lua</tt> module at startup: </p>
|
2004-11-28 09:17:16 +01:00
|
|
|
|
|
|
|
<pre class=example>
|
|
|
|
LUA_INIT=@<ROOT>/compat-5.1.lua
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
The other two environment variables instruct the compatibility module to
|
|
|
|
look for dynamic libraries and modules in the appropriate directories and
|
|
|
|
with the appropriate filename extensions.
|
|
|
|
|
|
|
|
<pre class=example>
|
|
|
|
LUA_PATH=<ROOT>/?.lua;?.lua
|
|
|
|
LUA_CPATH=<ROOT>/?.dll;?.dll
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<p> Again, naturally, in Unix the shared library extension would be
|
2004-11-29 07:55:47 +01:00
|
|
|
<tt>.so</tt> instead of <tt>.dll</tt> and on Mac OS X it would be
|
2004-11-28 09:17:16 +01:00
|
|
|
<tt>.dylib</tt></p>
|
|
|
|
|
|
|
|
<h3>Using LuaSocket</h3>
|
|
|
|
|
|
|
|
<p> With the above setup, and an interpreter with shared library support,
|
|
|
|
it should be easy to use LuaSocket. Just fire the interpreter and use the
|
|
|
|
<tt>require</tt> function to gain access to whatever module you need:</p>
|
|
|
|
|
|
|
|
<pre class=example>
|
|
|
|
Lua 5.0.2 Copyright (C) 1994-2004 Tecgraf, PUC-Rio
|
|
|
|
> socket = require("socket")
|
|
|
|
> print(socket.VERSION)
|
|
|
|
--> LuaSocket 2.0 (beta3)
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<p> Each module loads their dependencies automatically, so you only need to
|
2004-11-29 07:55:47 +01:00
|
|
|
load the modues you directly depend upon: <p>
|
2004-11-28 09:17:16 +01:00
|
|
|
|
|
|
|
<pre class=example>
|
|
|
|
Lua 5.0.2 Copyright (C) 1994-2004 Tecgraf, PUC-Rio
|
|
|
|
> http = require("socket.http")
|
|
|
|
> print(http.get("http://www.tecgraf.puc-rio.br/luasocket"))
|
|
|
|
--> homepage gets dumped to terminal
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<!-- footer +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ -->
|
|
|
|
|
|
|
|
<div class=footer>
|
|
|
|
<hr>
|
|
|
|
<center>
|
|
|
|
<p class=bar>
|
|
|
|
<a href="home.html">home</a> ·
|
|
|
|
<a href="home.html#down">download</a> ·
|
|
|
|
<a href="instalation.html">instalation</a> ·
|
|
|
|
<a href="introduction.html">introduction</a> ·
|
|
|
|
<a href="reference.html">reference</a>
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
<small>
|
|
|
|
Last modified by Diego Nehab on <br>
|
2004-11-28 09:20:11 +01:00
|
|
|
Sun Nov 28 03:19:00 EST 2004
|
2004-11-28 09:17:16 +01:00
|
|
|
</small>
|
|
|
|
</p>
|
|
|
|
</center>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</body>
|
|
|
|
</html>
|