-
Notifications
You must be signed in to change notification settings - Fork 19
/
Xatab.lua
249 lines (204 loc) · 9.91 KB
/
Xatab.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
local sourcelink = "https://hydralinks.cloud/sources/xatab.json"
local function endsWith(str, pattern)
return string.sub(str, -string.len(pattern)) == pattern
end
function replace_spaces(input, replacement)
return string.gsub(input, " ", replacement)
end
function replace_symbol(input, replacement)
input = string.gsub(input, "'", replacement)
return string.gsub(input, "’", replacement)
end
function replace_symbol2(input, replacement)
return string.gsub(input, ":", replacement)
end
local function substituteRomanNumerals(gameName)
local romans = {
[" i"] = " 1",
[" ii"] = " 2",
[" iii"] = " 3",
[" iv"] = " 4",
[" v"] = " 5",
[" vi"] = " 6",
[" vii"] = " 7",
[" viii"] = " 8",
[" ix"] = " 9",
[" x"] = " 10"
}
for numeral, substitution in pairs(romans) do
if endsWith(gameName, numeral) then
gameName = string.sub(gameName, 1, -string.len(numeral) - 1) .. substitution
end
end
return gameName
end
local function substituteRomanNumeralsFromEntireString(gameName)
local romans = {
[" i([^a-zA-Z0-9])"] = " 1%1",
[" ii([^a-zA-Z0-9])"] = " 2%1",
[" iii([^a-zA-Z0-9])"] = " 3%1",
[" iv([^a-zA-Z0-9])"] = " 4%1",
[" v([^a-zA-Z0-9])"] = " 5%1",
[" vi([^a-zA-Z0-9])"] = " 6%1",
[" vii([^a-zA-Z0-9])"] = " 7%1",
[" viii([^a-zA-Z0-9])"] = " 8%1",
[" ix([^a-zA-Z0-9])"] = " 9%1",
[" x([^a-zA-Z0-9])"] = " 10%1"
}
for numeral, substitution in pairs(romans) do
gameName = gameName:gsub(numeral, substitution)
end
-- Handle cases where Roman numerals are at the beginning or end of the string
gameName =substituteRomanNumerals(gameName)
return gameName
end
local function generateVariations(input)
local variations = {}
-- Original variations
table.insert(variations, input)
local lower_input = input:lower()
table.insert(variations, lower_input)
local lower_input_no_roman = substituteRomanNumeralsFromEntireString(lower_input)
table.insert(variations, lower_input_no_roman)
local lower_spaces_to_dot = replace_spaces(lower_input, ".")
table.insert(variations, lower_spaces_to_dot)
local lower_spaces_to_dot_no_roman = replace_spaces(lower_input_no_roman, ".")
table.insert(variations, lower_spaces_to_dot_no_roman)
local lower_spaces_to_dot1 = replace_symbol(lower_input, ".")
table.insert(variations, lower_spaces_to_dot1)
local lower_no_symbols = replace_symbol(lower_input, "")
table.insert(variations, lower_no_symbols)
local lower_no_symbols_no_roman = replace_symbol(lower_input_no_roman, "")
table.insert(variations, lower_no_symbols_no_roman)
local lower_no_symbols_spaces_to_dot = replace_spaces(lower_no_symbols, ".")
table.insert(variations, lower_no_symbols_spaces_to_dot)
local lower_no_symbols_spaces_to_dot_no_roman = replace_spaces(lower_no_symbols_no_roman, ".")
table.insert(variations, lower_no_symbols_spaces_to_dot_no_roman)
local lower_no_symbols2 = replace_symbol2(lower_input, "")
table.insert(variations, lower_no_symbols2)
local lower_no_symbols_no_roman2 = replace_symbol2(lower_input_no_roman, "")
table.insert(variations, lower_no_symbols_no_roman2)
local lower_no_symbols_spaces_to_dot2 = replace_spaces(lower_no_symbols2, ".")
table.insert(variations, lower_no_symbols_spaces_to_dot2)
local lower_no_symbols_spaces_to_dot_no_roman2 = replace_spaces(lower_no_symbols_no_roman2, ".")
table.insert(variations, lower_no_symbols_spaces_to_dot_no_roman2)
-- Additional variations combining existing ones
-- Combine lower_input_no_roman with lower_spaces_to_dot
local combined1 = replace_spaces(lower_input_no_roman, ".")
table.insert(variations, combined1)
-- Combine lower_no_symbols with lower_no_symbols_no_roman
local combined2 = replace_symbol(lower_no_symbols, "")
table.insert(variations, combined2)
-- Combine lower_no_symbols with replace_symbol2
local combined22 = replace_symbol2(lower_no_symbols, "")
table.insert(variations, combined22)
-- Combine lower_spaces_to_dot with lower_no_symbols_no_roman2
local combined3 = replace_spaces(lower_spaces_to_dot, "")
table.insert(variations, combined3)
-- Combine lower_no_symbols_spaces_to_dot with lower_no_symbols_spaces_to_dot_no_roman2
local combined4 = replace_spaces(lower_no_symbols_spaces_to_dot, "")
table.insert(variations, combined4)
-- Combine lower_no_symbols_no_roman with lower_no_symbols2
local combined5 = replace_symbol(lower_no_symbols_no_roman, "")
table.insert(variations, combined5)
-- Combine lower_no_symbols_no_roman with replace_symbol2
local combined52 = replace_symbol2(lower_no_symbols_no_roman, "")
table.insert(variations, combined52)
-- Combine lower_spaces_to_dot_no_roman with lower_no_symbols_spaces_to_dot2
local combined6 = replace_spaces(lower_spaces_to_dot_no_roman, "")
table.insert(variations, combined6)
-- Combine lower_no_symbols_spaces_to_dot_no_roman with lower_no_symbols_spaces_to_dot_no_roman2
local combined7 = replace_spaces(lower_no_symbols_spaces_to_dot_no_roman, "")
table.insert(variations, combined7)
-- Combine lower_no_symbols_spaces_to_dot_no_roman with lower_no_symbols_spaces_to_dot2
local combined8 = replace_spaces(lower_no_symbols_spaces_to_dot_no_roman, "")
table.insert(variations, combined8)
-- Combine lower_no_symbols_spaces_to_dot with lower_no_symbols_spaces_to_dot_no_roman2
local combined9 = replace_spaces(lower_no_symbols_spaces_to_dot, "")
table.insert(variations, combined9)
-- Combine lower_no_symbols_spaces_to_dot_no_roman with lower_no_symbols_no_roman2
local combined10 = replace_spaces(lower_no_symbols_spaces_to_dot_no_roman, "")
table.insert(variations, combined10)
-- Combine lower_no_symbols_no_roman with lower_no_symbols_spaces_to_dot2
local combined11 = replace_symbol(lower_no_symbols_no_roman, "")
table.insert(variations, combined11)
-- Combine lower_no_symbols_no_roman with replace_symbol2
local combined112 = replace_symbol2(lower_no_symbols_no_roman, "")
table.insert(variations, combined112)
-- Combine lower_no_symbols_spaces_to_dot with lower_no_symbols2
local combined12 = replace_spaces(lower_no_symbols_spaces_to_dot, "")
table.insert(variations, combined12)
-- Combine lower_no_symbols_no_roman2 with lower_no_symbols_spaces_to_dot_no_roman2
local combined13 = replace_spaces(lower_no_symbols_no_roman2, "")
table.insert(variations, combined13)
-- Combine lower_spaces_to_dot with lower_spaces_to_dot_no_roman
local combined14 = replace_spaces(lower_spaces_to_dot, ".")
table.insert(variations, combined14)
-- Combine lower_spaces_to_dot with lower_no_symbols_spaces_to_dot
local combined15 = replace_spaces(lower_spaces_to_dot, ".")
table.insert(variations, combined15)
-- Combine lower_spaces_to_dot with lower_no_symbols_spaces_to_dot_no_roman
local combined16 = replace_spaces(lower_spaces_to_dot, ".")
table.insert(variations, combined16)
-- Combine lower_spaces_to_dot_no_roman with lower_no_symbols_spaces_to_dot_no_roman
local combined17 = replace_spaces(lower_spaces_to_dot_no_roman, ".")
table.insert(variations, combined17)
-- Combine lower_spaces_to_dot_no_roman with lower_no_symbols_spaces_to_dot_no_roman2
local combined18 = replace_spaces(lower_spaces_to_dot_no_roman, ".")
table.insert(variations, combined18)
-- Combine lower_spaces_to_dot_no_roman with lower_no_symbols_spaces_to_dot
local combined19 = replace_spaces(lower_spaces_to_dot_no_roman, ".")
table.insert(variations, combined19)
return variations
end
local function search_game(downloads, game_name, name_script)
local results = {}
local game_name_variations = generateVariations(game_name)
for _, download in ipairs(downloads) do
local lower_title = download.title:lower()
local lower_title_variations = generateVariations(lower_title)
local add_result = false
for _, game_variation in ipairs(game_name_variations) do
for _, title_variation in ipairs(lower_title_variations) do
if title_variation:find(game_variation, 1, true) then
add_result = true
break
end
end
if add_result then
break
end
end
if add_result then
local patchresult = {
name = "[" .. download.fileSize .. "] " .. download.title,
links = {},
tooltip = "Size: " .. download.fileSize .. " | Upload Date: " .. download.uploadDate,
ScriptName = name_script
}
for index, uri in ipairs(download.uris) do
table.insert(patchresult.links, { name = "Download Option " .. tostring(index), link = uri, addtodownloadlist = true })
end
table.insert(results, patchresult)
end
end
return results
end
local version = client.GetVersionDouble()
if version < 2.14 then
Notifications.push_error("Lua Script", "Program is Outdated Please Update to use that Script")
else
local statebool = false
local function requestfromsource()
local getgamename = game.getgamename()
local headers = {
["User-Agent"] = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36"
}
local response = http.get(sourcelink, headers) -- Use the dynamic link here
local gameResults = JsonWrapper.parse(response)["downloads"]
local scriptname = JsonWrapper.parse(response)["name"]
local results = search_game(gameResults, getgamename, scriptname)
communication.receiveSearchResults(results)
end
client.add_callback("on_scriptselected", requestfromsource) -- on a game is selected in menu callback
end