Lua - Perpustakaan Standar

Pustaka standar Lua menyediakan sekumpulan fungsi yang kaya yang diimplementasikan langsung dengan C API dan dibangun dengan bahasa pemrograman Lua. Library ini menyediakan layanan dalam bahasa pemrograman Lua dan juga layanan luar seperti operasi file dan db.

Pustaka standar yang dibangun di C API resmi ini disediakan sebagai modul C terpisah. Ini termasuk yang berikut -

  • Pustaka dasar, yang mencakup sub pustaka coroutine
  • Pustaka modul
  • Manipulasi string
  • Manipulasi tabel
  • Perpustakaan matematika
  • Masukan dan Keluaran File
  • Fasilitas sistem operasi
  • Fasilitas debug

Perpustakaan Dasar

Kami telah menggunakan pustaka dasar sepanjang tutorial dalam berbagai topik. Tabel berikut menyediakan link dari halaman-halaman terkait dan daftar fungsi-fungsi yang tercakup dalam berbagai bagian dari tutorial Lua ini.

Sr.No. Perpustakaan / Metode & Tujuan
1

Error Handling

Termasuk fungsi penanganan error seperti assert, error seperti yang dijelaskan di Lua - Penanganan Error .

2

Memory Management

Termasuk fungsi manajemen memori otomatis yang terkait dengan pengumpulan sampah seperti yang dijelaskan di Lua - Pengumpulan Sampah .

3

dofile ([filename])

Ini membuka file dan mengeksekusi konten file sebagai potongan. Jika tidak ada parameter yang dilewatkan, maka fungsi ini mengeksekusi konten input standar. Kesalahan akan disebarkan ke pemanggil.

4

_G

Demikianlah variabel global yang menampung lingkungan global (yaitu, _G._G = _G). Lua sendiri tidak menggunakan variabel ini.

5

getfenv ([f])

Mengembalikan lingkungan saat ini yang digunakan oleh fungsi. f dapat berupa fungsi Lua atau angka yang menetapkan fungsi pada level stack itu - Level 1 adalah fungsi yang memanggil getfenv. Jika fungsi yang diberikan bukan fungsi Lua, atau jika f adalah 0, getfenv mengembalikan lingkungan global. Default untuk f adalah 1.

6

getmetatable (object)

Jika objek tidak memiliki metatabel, mengembalikan nihil. Sebaliknya, jika metatabel objek memiliki bidang "__metatable", mengembalikan nilai terkait. Jika tidak, mengembalikan metatabel dari objek yang diberikan.

7

ipairs (t)

Fungsi ini mengambil indeks dan nilai tabel.

8

load (func [, chunkname])

Memuat potongan menggunakan function func untuk mendapatkan potongannya. Setiap panggilan ke func harus mengembalikan string yang digabungkan dengan hasil sebelumnya.

9

loadfile ([filename]))

Mirip dengan memuat, tetapi mendapatkan potongan dari nama file file atau dari input standar, jika tidak ada nama file yang diberikan.

10

loadstring (string [, chunkname])

Mirip dengan memuat, tetapi mendapat potongan dari string yang diberikan.

11

next (table [, index])

Mengizinkan program untuk melintasi semua bidang tabel. Argumen pertamanya adalah tabel dan argumen kedua adalah indeks dalam tabel ini. next mengembalikan indeks berikutnya dari tabel dan nilai yang terkait.

12

pairs (t)

Menangguhkan coroutine yang sedang berjalan. Parameter yang diteruskan ke metode ini bertindak sebagai nilai pengembalian tambahan ke fungsi resume.

13

print (...)

Menangguhkan coroutine yang sedang berjalan. Parameter yang diteruskan ke metode ini bertindak sebagai nilai pengembalian tambahan ke fungsi resume.

14

rawequal (v1, v2)

Memeriksa apakah v1 sama dengan v2, tanpa menggunakan metamethod. Mengembalikan boolean.

15

rawget (table, index)

Mendapatkan nilai sebenarnya dari tabel [indeks], tanpa menggunakan metode apa pun. tabel harus berupa tabel; indeks dapat berupa nilai apa pun.

16

rawset (table, index, value)

Menyetel nilai riil tabel [indeks] menjadi nilai, tanpa menggunakan metode apa pun. tabel harus berupa tabel, indeks nilai apa pun yang berbeda dari nil, dan nilai nilai Lua apa pun. Fungsi ini mengembalikan tabel.

17

select (index, ...)

Jika indeks adalah angka, kembalikan semua argumen setelah indeks nomor argumen. Jika tidak, indeks harus berupa string "#", dan pilih mengembalikan jumlah total argumen tambahan yang diterima.

18

setfenv (f, table)

Menyetel lingkungan yang akan digunakan oleh fungsi yang diberikan. f dapat berupa fungsi Lua atau angka yang menetapkan fungsi pada level stack itu - Level 1 adalah fungsi yang memanggil setfenv. setfenv mengembalikan fungsi yang diberikan. Sebagai kasus khusus, ketika f adalah 0 setfenv mengubah lingkungan thread yang sedang berjalan. Dalam kasus ini, setfenv tidak mengembalikan nilai.

19

setmetatable (table, metatable)

Menetapkan metatabel untuk tabel yang diberikan. (Anda tidak dapat mengubah metatabel jenis lain dari Lua, hanya dari C.) Jika metatabel adalah nil, hapus metatabel dari tabel yang diberikan. Jika metatabel asli memiliki bidang "__metatable", menimbulkan kesalahan. Fungsi ini mengembalikan tabel.

20

tonumber (e [, base])

Mencoba mengubah argumennya menjadi angka. Jika argumen sudah berupa angka atau string yang dapat diubah menjadi angka, maka tonumber mengembalikan angka ini; jika tidak, hasilnya nihil.

21

tostring (e)

Menerima argumen jenis apa pun dan mengubahnya menjadi string dalam format yang wajar. Untuk kontrol penuh tentang bagaimana angka dikonversi, gunakan string.format.

22

type (v)

Mengembalikan tipe dari satu-satunya argumennya, yang dikodekan sebagai string. Hasil yang mungkin dari fungsi ini adalah "nil" (string, bukan nilai nil), "number", "string", "boolean", "table", "function", "thread", dan "userdata".

23

unpack (list [, i [, j]])

Mengembalikan elemen dari tabel yang diberikan.

24

_VERSION

Variabel global (bukan fungsi) yang menyimpan string yang berisi versi interpreter saat ini. Isi dari variabel ini adalah "Lua 5.1".

25

Coroutines

Termasuk fungsi manipulasi coroutine seperti yang dijelaskan dalam Lua - Coroutines .

Pustaka Modul

Pustaka modul menyediakan fungsi dasar untuk memuat modul di Lua. Ini mengekspor satu fungsi secara langsung di lingkungan global: membutuhkan. Semua yang lain diekspor dalam paket tabel. Rincian tentang pustaka modul dijelaskan di bab sebelumnya Lua - Tutorial modul .

Manipulasi string

Lua menyediakan sekumpulan fungsi manipulasi string yang kaya. Tutorial Lua - Strings sebelumnya membahas hal ini secara mendetail.

Manipulasi tabel

Lua bergantung pada tabel di hampir setiap bit operasinya. Tutorial Lua - Tabel sebelumnya membahas hal ini secara rinci.

Masukan dan Keluaran File

Kami sering membutuhkan fasilitas penyimpanan data dalam pemrograman dan ini disediakan oleh fungsi perpustakaan standar untuk file I / O di Lua. Hal ini dibahas dalam tutorial Lua - File I / O sebelumnya .

Fasilitas debug

Lua menyediakan pustaka debug yang menyediakan semua fungsi primitif bagi kita untuk membuat debugger kita sendiri. Hal ini dibahas dalam tutorial Lua - Debugging sebelumnya .