mirror of
https://github.com/lune-org/docs.git
synced 2025-04-04 18:40:59 +01:00
Merge branch 'main' into feat/security
This commit is contained in:
commit
3dda948ce9
6 changed files with 279 additions and 17 deletions
|
@ -10,16 +10,36 @@ local typedefsFile = fs.readFile("temp/moonwave.json")
|
||||||
local items: { moonwave.Item } = serde.decode("json", typedefsFile)
|
local items: { moonwave.Item } = serde.decode("json", typedefsFile)
|
||||||
|
|
||||||
-- Generate markdown for all of the libraries
|
-- Generate markdown for all of the libraries
|
||||||
local generatedFiles = {}
|
local generatedFiles = {} :: { [number]: {
|
||||||
|
displayName: string,
|
||||||
|
name: string,
|
||||||
|
content: string,
|
||||||
|
} }
|
||||||
for _, item in items do
|
for _, item in items do
|
||||||
local file = item.source.path
|
local file = item.source.path
|
||||||
local name = string.match(file, "(.+)%.luau")
|
local name = string.match(file, "(.+)%.luau")
|
||||||
assert(name ~= nil, "Failed to remove luau suffix from file name")
|
assert(name ~= nil, "Failed to remove luau suffix from file name")
|
||||||
table.insert(generatedFiles, {
|
|
||||||
displayName = item.name,
|
-- If we have an existing entry, such as when we have multiple
|
||||||
name = string.lower(name),
|
-- classes within the same library (Regex, RegexCaptures, ...)
|
||||||
content = writeMarkdown(item),
|
-- we want to append to the existing entry instead of creating
|
||||||
})
|
local existing = nil
|
||||||
|
for _, info in generatedFiles do
|
||||||
|
if info.name == string.lower(name) then
|
||||||
|
existing = info
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if existing then
|
||||||
|
existing.content ..= writeMarkdown(item)
|
||||||
|
else
|
||||||
|
table.insert(generatedFiles, {
|
||||||
|
displayName = item.name,
|
||||||
|
name = string.lower(name),
|
||||||
|
content = writeMarkdown(item),
|
||||||
|
})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Remove any old files, generate new ones
|
-- Remove any old files, generate new ones
|
||||||
|
|
18
.vscode/settings.json
vendored
18
.vscode/settings.json
vendored
|
@ -1,11 +1,9 @@
|
||||||
{
|
{
|
||||||
"luau-lsp.types.roblox": false,
|
"luau-lsp.types.roblox": false,
|
||||||
"luau-lsp.sourcemap.enabled": false,
|
"luau-lsp.sourcemap.enabled": false,
|
||||||
"luau-lsp.ignoreGlobs": [
|
"luau-lsp.ignoreGlobs": ["temp/**"],
|
||||||
"temp/**"
|
"luau-lsp.require.mode": "relativeToFile",
|
||||||
],
|
"luau-lsp.require.directoryAliases": {
|
||||||
"luau-lsp.require.mode": "relativeToFile",
|
"@lune/": "~/.lune/.typedefs/0.8.5/"
|
||||||
"luau-lsp.require.directoryAliases": {
|
}
|
||||||
"@lune/": "~/.lune/.typedefs/0.8.5/"
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
[tools]
|
[tools]
|
||||||
just = "readysetplay/just@1.8.0"
|
just = "readysetplay/just@1.8.0"
|
||||||
luau-lsp = "JohnnyMorganz/luau-lsp@1.29.0"
|
luau-lsp = "JohnnyMorganz/luau-lsp@1.29.1"
|
||||||
lune = "lune-org/lune@0.8.5"
|
lune = "lune-org/lune@0.8.5"
|
||||||
stylua = "JohnnyMorganz/StyLua@0.20.0"
|
stylua = "JohnnyMorganz/StyLua@0.20.0"
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
"luau": "Luau",
|
"luau": "Luau",
|
||||||
"net": "Net",
|
"net": "Net",
|
||||||
"process": "Process",
|
"process": "Process",
|
||||||
|
"regex": "Regex",
|
||||||
"roblox": "Roblox",
|
"roblox": "Roblox",
|
||||||
"serde": "Serde",
|
"serde": "Serde",
|
||||||
"stdio": "Stdio",
|
"stdio": "Stdio",
|
||||||
|
|
230
pages/api-reference/regex.md
Normal file
230
pages/api-reference/regex.md
Normal file
|
@ -0,0 +1,230 @@
|
||||||
|
# Regex
|
||||||
|
|
||||||
|
Built-in library for regular expressions
|
||||||
|
|
||||||
|
#### Example usage
|
||||||
|
|
||||||
|
```lua
|
||||||
|
local Regex = require("@lune/regex")
|
||||||
|
|
||||||
|
local re = Regex.new("hello")
|
||||||
|
|
||||||
|
if re:isMatch("hello, world!") then
|
||||||
|
print("Matched!")
|
||||||
|
end
|
||||||
|
|
||||||
|
local caps = re:captures("hello, world! hello, again!")
|
||||||
|
|
||||||
|
print(#caps) -- 2
|
||||||
|
print(caps:get(1)) -- "hello"
|
||||||
|
print(caps:get(2)) -- "hello"
|
||||||
|
print(caps:get(3)) -- nil
|
||||||
|
```
|
||||||
|
|
||||||
|
## Constructors
|
||||||
|
|
||||||
|
### new
|
||||||
|
|
||||||
|
Creates a new `Regex` from a given string pattern.
|
||||||
|
|
||||||
|
#### Errors
|
||||||
|
|
||||||
|
This constructor throws an error if the given pattern is invalid.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `pattern` `string` The string pattern to use
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `Regex` The new Regex object
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Methods
|
||||||
|
|
||||||
|
### isMatch
|
||||||
|
|
||||||
|
Check if the given text matches the regular expression.
|
||||||
|
|
||||||
|
This method may be slightly more efficient than calling `find` if you only need to know if the text
|
||||||
|
matches the pattern.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` Regex
|
||||||
|
|
||||||
|
- `text` `string` The text to search
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `boolean` Whether the text matches the pattern
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### find
|
||||||
|
|
||||||
|
Finds the first match in the given text.
|
||||||
|
|
||||||
|
Returns `nil` if no match was found.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` Regex
|
||||||
|
|
||||||
|
- `text` `string` The text to search
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `RegexMatch?` The match object
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### captures
|
||||||
|
|
||||||
|
Finds all matches in the given text as a `RegexCaptures` object.
|
||||||
|
|
||||||
|
Returns `nil` if no matches are found.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` Regex
|
||||||
|
|
||||||
|
- `text` `string` The text to search
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `RegexCaptures?` The captures object
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### split
|
||||||
|
|
||||||
|
Splits the given text using the regular expression.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` Regex
|
||||||
|
|
||||||
|
- `text` `string` The text to split
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `{ string }` The split text
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### replace
|
||||||
|
|
||||||
|
Replaces the first match in the given text with the given replacer string.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` Regex
|
||||||
|
|
||||||
|
- `haystack` `string` The text to search
|
||||||
|
|
||||||
|
- `replacer` `string` The string to replace matches with
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `string` The text with the first match replaced
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### replaceAll
|
||||||
|
|
||||||
|
Replaces all matches in the given text with the given replacer string.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` Regex
|
||||||
|
|
||||||
|
- `haystack` `string` The text to search
|
||||||
|
|
||||||
|
- `replacer` `string` The string to replace matches with
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `string` The text with all matches replaced
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# RegexCaptures
|
||||||
|
|
||||||
|
Captures from a regular expression.
|
||||||
|
|
||||||
|
## Methods
|
||||||
|
|
||||||
|
### get
|
||||||
|
|
||||||
|
Returns the match at the given index, if one exists.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` RegexCaptures
|
||||||
|
|
||||||
|
- `index` `number` The index of the match to get
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `RegexMatch` The match, if one exists
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### group
|
||||||
|
|
||||||
|
Returns the match for the given named match group, if one exists.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` RegexCaptures
|
||||||
|
|
||||||
|
- `group` `string` The name of the group to get
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `RegexMatch` The match, if one exists
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### format
|
||||||
|
|
||||||
|
Formats the captures using the given format string.
|
||||||
|
|
||||||
|
#### Example usage
|
||||||
|
|
||||||
|
```lua
|
||||||
|
local regex = require("@lune/regex")
|
||||||
|
|
||||||
|
local re = regex.new("(?<day>[0-9]{2})-(?<month>[0-9]{2})-(?<year>[0-9]{4})")
|
||||||
|
|
||||||
|
local caps = re:captures("On 14-03-2010, I became a Tenneessee lamb.");
|
||||||
|
assert(caps ~= nil, "Example pattern should match example text")
|
||||||
|
|
||||||
|
local formatted = caps:format("year=$year, month=$month, day=$day")
|
||||||
|
print(formatted) -- "year=2010, month=03, day=14"
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
|
||||||
|
- `self` RegexCaptures
|
||||||
|
|
||||||
|
- `format` `string` The format string to use
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- `string` The formatted string
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
# RegexMatch
|
||||||
|
|
||||||
|
A match from a regular expression.
|
||||||
|
|
||||||
|
Contains the following values:
|
||||||
|
|
||||||
|
- `start` -- The start index of the match in the original string.
|
||||||
|
- `finish` -- The end index of the match in the original string.
|
||||||
|
- `text` -- The text that was matched.
|
||||||
|
- `len` -- The length of the text that was matched.
|
|
@ -16,6 +16,9 @@ stdio.write("Hello, ")
|
||||||
stdio.write("World! ")
|
stdio.write("World! ")
|
||||||
stdio.write("All on the same line")
|
stdio.write("All on the same line")
|
||||||
stdio.ewrite("\nAnd some error text, too")
|
stdio.ewrite("\nAnd some error text, too")
|
||||||
|
|
||||||
|
-- Reading the entire input from stdin
|
||||||
|
local input = stdio.readToEnd()
|
||||||
```
|
```
|
||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
|
@ -124,3 +127,13 @@ Writes a string directly to stderr, without any newline.
|
||||||
- `s` The string to write to stderr
|
- `s` The string to write to stderr
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
### readToEnd
|
||||||
|
|
||||||
|
Reads the entire input from stdin.
|
||||||
|
|
||||||
|
#### Returns
|
||||||
|
|
||||||
|
- The input from stdin
|
||||||
|
|
||||||
|
---
|
||||||
|
|
Loading…
Add table
Reference in a new issue