Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
G
Grasscutter
Manage
Activity
Members
Labels
Plan
Issues
0
Issue boards
Milestones
Wiki
Code
Merge requests
0
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package Registry
Operate
Environments
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
ziqian zhang
Grasscutter
Commits
32d2a211
Commit
32d2a211
authored
3 years ago
by
KingRainbow44
Browse files
Options
Downloads
Plain Diff
Merge remote-tracking branch 'origin/development' into development
parents
043c7315
e29c2dc1
No related merge requests found
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
proxy_config.py
+15
-2
15 additions, 2 deletions
proxy_config.py
src/main/java/emu/grasscutter/Grasscutter.java
+3
-3
3 additions, 3 deletions
src/main/java/emu/grasscutter/Grasscutter.java
src/main/java/emu/grasscutter/tools/Tools.java
+76
-8
76 additions, 8 deletions
src/main/java/emu/grasscutter/tools/Tools.java
with
94 additions
and
13 deletions
proxy_config.py
+
15
−
2
View file @
32d2a211
import
os
# This can also be replaced with another IP address.
USE_SSL
=
True
REMOTE_HOST
=
"
127.0.0.1
"
REMOTE_PORT
=
443
\ No newline at end of file
REMOTE_HOST
=
"
localhost
"
REMOTE_PORT
=
443
if
os
.
getenv
(
'
MITM_REMOTE_HOST
'
)
!=
None
:
REMOTE_HOST
=
os
.
getenv
(
'
MITM_REMOTE_HOST
'
)
if
os
.
getenv
(
'
MITM_REMOTE_PORT
'
)
!=
None
:
REMOTE_PORT
=
int
(
os
.
getenv
(
'
MITM_REMOTE_PORT
'
))
if
os
.
getenv
(
'
MITM_USE_SSL
'
)
!=
None
:
USE_SSL
=
bool
(
os
.
getenv
(
'
MITM_USE_SSL
'
))
print
(
'
MITM Remote Host:
'
+
REMOTE_HOST
)
print
(
'
MITM Remote Port:
'
+
str
(
REMOTE_PORT
))
print
(
'
MITM Use SSL
'
+
str
(
USE_SSL
))
This diff is collapsed.
Click to expand it.
src/main/java/emu/grasscutter/Grasscutter.java
+
3
−
3
View file @
32d2a211
...
...
@@ -51,7 +51,7 @@ public final class Grasscutter {
private
static
PluginManager
pluginManager
;
public
static
final
Reflections
reflector
=
new
Reflections
(
"emu.grasscutter"
);
static
{
// Declare logback configuration.
System
.
setProperty
(
"logback.configurationFile"
,
"src/main/resources/logback.xml"
);
...
...
@@ -66,7 +66,7 @@ public final class Grasscutter {
Utils
.
startupCheck
();
}
public
static
void
main
(
String
[]
args
)
throws
Exception
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
Crypto
.
loadKeys
();
// Load keys from buffers.
// Parse arguments.
...
...
@@ -127,7 +127,7 @@ public final class Grasscutter {
// Open console.
startConsole
();
}
}
/**
* Server shutdown event.
...
...
This diff is collapsed.
Click to expand it.
src/main/java/emu/grasscutter/tools/Tools.java
+
76
−
8
View file @
32d2a211
package
emu.grasscutter.tools
;
import
java.io.BufferedReader
;
import
java.io.File
;
import
java.io.FileInputStream
;
import
java.io.FileOutputStream
;
import
java.io.FileReader
;
import
java.io.FileWriter
;
import
java.io.FilenameFilter
;
import
java.io.InputStreamReader
;
import
java.io.OutputStreamWriter
;
import
java.io.PrintWriter
;
...
...
@@ -30,13 +32,73 @@ import emu.grasscutter.data.def.SceneData;
import
emu.grasscutter.utils.Utils
;
public
final
class
Tools
{
public
static
void
createGmHandbook
()
throws
Exception
{
ToolsWithLanguageOption
.
createGmHandbook
(
getLanguageOption
());
}
public
static
void
createGachaMapping
(
String
location
)
throws
Exception
{
ToolsWithLanguageOption
.
createGachaMapping
(
location
,
getLanguageOption
());
}
public
static
List
<
String
>
getAvailableLanguage
()
throws
Exception
{
File
textMapFolder
=
new
File
(
Grasscutter
.
getConfig
().
RESOURCE_FOLDER
+
"TextMap"
);
List
<
String
>
availableLangList
=
new
ArrayList
<
String
>();
for
(
String
textMapFileName
:
textMapFolder
.
list
(
new
FilenameFilter
()
{
@Override
public
boolean
accept
(
File
dir
,
String
name
)
{
if
(
name
.
startsWith
(
"TextMap"
)
&&
name
.
endsWith
(
".json"
)){
return
true
;
}
return
false
;
}
}))
{
availableLangList
.
add
(
textMapFileName
.
replace
(
"TextMap"
,
""
).
replace
(
".json"
,
""
).
toLowerCase
());
}
return
availableLangList
;
}
public
static
String
getLanguageOption
()
throws
Exception
{
List
<
String
>
availableLangList
=
getAvailableLanguage
();
// Use system out for better format
if
(
availableLangList
.
size
()
==
1
)
{
return
availableLangList
.
get
(
0
).
toUpperCase
();
}
System
.
out
.
println
(
"The following languages mappings are available, please select one: [default: EN]"
);
String
groupedLangList
=
"> "
;
int
groupedLangCount
=
0
;
String
input
=
""
;
for
(
String
availableLanguage:
availableLangList
){
groupedLangCount
++;
groupedLangList
=
groupedLangList
+
""
+
availableLanguage
+
"\t"
;
if
(
groupedLangCount
==
6
)
{
System
.
out
.
println
(
groupedLangList
);
groupedLangCount
=
0
;
groupedLangList
=
"> "
;
}
}
if
(
groupedLangCount
>
0
)
{
System
.
out
.
println
(
groupedLangList
);
}
System
.
out
.
print
(
"\nYour choice:[EN] "
);
input
=
new
BufferedReader
(
new
InputStreamReader
(
System
.
in
)).
readLine
();
if
(
availableLangList
.
contains
(
input
.
toLowerCase
()))
{
return
input
.
toUpperCase
();
}
Grasscutter
.
getLogger
().
info
(
"Invalid option. Will use EN(English) as fallback"
);
return
"EN"
;
}
}
final
class
ToolsWithLanguageOption
{
@SuppressWarnings
(
"deprecation"
)
public
static
void
createGmHandbook
()
throws
Exception
{
public
static
void
createGmHandbook
(
String
language
)
throws
Exception
{
ResourceLoader
.
loadResources
();
Map
<
Long
,
String
>
map
;
try
(
InputStreamReader
fileReader
=
new
InputStreamReader
(
new
FileInputStream
(
Utils
.
toFilePath
(
Grasscutter
.
getConfig
().
RESOURCE_FOLDER
+
"TextMap/TextMap
EN
.json"
)),
StandardCharsets
.
UTF_8
))
{
try
(
InputStreamReader
fileReader
=
new
InputStreamReader
(
new
FileInputStream
(
Utils
.
toFilePath
(
Grasscutter
.
getConfig
().
RESOURCE_FOLDER
+
"TextMap/TextMap
"
+
language
+
"
.json"
)),
StandardCharsets
.
UTF_8
))
{
map
=
Grasscutter
.
getGsonFactory
().
fromJson
(
fileReader
,
new
TypeToken
<
Map
<
Long
,
String
>>()
{}.
getType
());
}
...
...
@@ -96,11 +158,11 @@ public final class Tools {
}
@SuppressWarnings
(
"deprecation"
)
public
static
void
createGachaMapping
(
String
location
)
throws
Exception
{
public
static
void
createGachaMapping
(
String
location
,
String
language
)
throws
Exception
{
ResourceLoader
.
loadResources
();
Map
<
Long
,
String
>
map
;
try
(
InputStreamReader
fileReader
=
new
InputStreamReader
(
new
FileInputStream
(
Utils
.
toFilePath
(
Grasscutter
.
getConfig
().
RESOURCE_FOLDER
+
"TextMap/TextMap
EN
.json"
)),
StandardCharsets
.
UTF_8
))
{
try
(
InputStreamReader
fileReader
=
new
InputStreamReader
(
new
FileInputStream
(
Utils
.
toFilePath
(
Grasscutter
.
getConfig
().
RESOURCE_FOLDER
+
"TextMap/TextMap
"
+
language
+
"
.json"
)),
StandardCharsets
.
UTF_8
))
{
map
=
Grasscutter
.
getGsonFactory
().
fromJson
(
fileReader
,
new
TypeToken
<
Map
<
Long
,
String
>>()
{}.
getType
());
}
...
...
@@ -113,6 +175,9 @@ public final class Tools {
list
=
new
ArrayList
<>(
GameData
.
getAvatarDataMap
().
keySet
());
Collections
.
sort
(
list
);
// if the user made choices for language, I assume it's okay to assign his/her selected language to "en-us"
// since it's the fallback language and there will be no difference in the gacha record page.
// The enduser can still modify the `gacha_mappings.js` directly to enable multilingual for the gacha record system.
writer
.
println
(
"mappings = {\"en-us\": {"
);
// Avatars
...
...
@@ -140,10 +205,10 @@ public final class Tools {
default
:
color
=
"blue"
;
}
// Got the magic number 4233146695 from manually search in the json file
writer
.
println
(
"\""
+
(
avatarID
%
1000
+
1000
)
+
"\" : [\""
+
map
.
get
(
data
.
getNameTextMapHash
())
+
"(
Avatar
)\", \""
+
map
.
get
(
data
.
getNameTextMapHash
())
+
"(
"
+
map
.
get
(
4233146695L
)+
"
)\", \""
+
color
+
"\"]"
);
}
...
...
@@ -173,11 +238,14 @@ public final class Tools {
default
:
continue
;
// skip unnecessary entries
}
// Got the magic number 4231343903 from manually search in the json file
writer
.
println
(
",\""
+
data
.
getId
()
+
"\" : [\""
+
map
.
get
(
data
.
getNameTextMapHash
()).
replaceAll
(
"\""
,
""
)
+
"(
Weapon
)\",\""
+
color
+
"\"]"
);
+
"(
"
+
map
.
get
(
4231343903L
)+
"
)\",\""
+
color
+
"\"]"
);
}
writer
.
println
(
",\"200\": \"
Standard\", \"301\": \"Avatar Event\", \"302\": \"Weapon event
\""
);
writer
.
println
(
",\"200\": \"
"
+
map
.
get
(
332935371L
)+
"\", \"301\": \""
+
map
.
get
(
2272170627L
)
+
"\", \"302\": \""
+
map
.
get
(
2864268523L
)+
"
\""
);
writer
.
println
(
"}\n}"
);
}
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment