Revision Difference
auto-complete#547740
<cat>Dev.Lua</cat>⤶
# Auto-complete Overview⤶
⤶
Auto-complete is a feature that predicts words & phrases, it helps the user understand a console command & increase their efficiency whilst using it.⤶
⤶
## Auto-completion with functions⤶
⤶
To create auto-complete for your console command, a function named `AutoComplete` must be created. The function will determine what values are displayed based on what is passed to the function.⤶
⤶
*@param* `cmd` — Will always be the command, not useful for us right now. (Gives "rp_steamid").⤶
⤶
*@param* `stringargs` — Gives us the rest of the input. Typing in "rp_steamid Don" will make stringargs = " Don".⤶
In this function we are also meant to return something, a table. This table should contain the set of values we want to display to the user in the autocomplete box.⤶
⤶
The function below gives the result as seen below the function.⤶
⤶
```lua⤶
local function AutoComplete(cmd, stringargs)⤶
    local tbl = {⤶
        "Test 1",⤶
        "Test 2",⤶
        "Test 3",⤶
    }⤶
    return tbl⤶
end⤶
```⤶
⤶
<image src="autocomplete3.jpg"/><br/>⤶
⤶
⤶
The function below gives the result as seen below the function.⤶
⤶
```lua⤶
local function AutoComplete(cmd, stringargs)⤶
    --- Trim the arguments & make them lowercase.⤶
    stringargs = string.Trim(stringargs:lower())⤶
    --- Create a new table.⤶
    local tbl = {}⤶
    for _, ply in pairs(player.GetAll()) do⤶
        local name = ply:Nick()⤶
        if name:lower():find(stringargs) then⤶
            --- Add the player's name into the auto-complete.⤶
            name = "rp_steamid \"" .. name .. "\""⤶
            table.insert(tbl, name)⤶
        end⤶
    end⤶
    --- Return the table for auto-complete.⤶
    return tbl⤶
end⤶
```⤶
⤶
<image src="autocomplete4.jpg"/>⤶
<image src="autocomplete5.jpg"/>⤶
⤶
## Console command replication⤶
⤶
Console commands are not replicated. If you'd like to replicate a console command, you'll have to use <page>Global.AddCSLuaFile</page>, or create custom behavior on both the server & the client.⤶
⤶
Special thanks to old-time contributors for the images.⤶
The code was written by shawnjbragdon.
 Garry's Mod
			Garry's Mod 
		 Rust
			Rust 
		 Steamworks
			Steamworks 
		 Wiki Help
			Wiki Help