-
-
Notifications
You must be signed in to change notification settings - Fork 238
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: allow placement of minecraft gen features and structures #2364
base: main
Are you sure you want to change the base?
Conversation
dordsor21
commented
Jul 17, 2023
•
edited
Loading
edited
- closes Generation of Minecraft features and structures #2343
This only works if the EditSession is backed by an actual World, I think this should be outlined in the Javadocs. |
noticed upstream has this functionality, will change to match them and cherry-pick where appropriate |
50a3328
to
594527f
Compare
Please take a moment and address the merge conflicts of your pull request. Thanks! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As there's a mix of structures and features here, what exactly do we add what WE doesn't add? StructureType
is in the WE source here, but the commands and the tools for it are in the FAWE source, that's a bit confusing to me right now.
@@ -555,6 +571,164 @@ protected ServerLevel getServerLevel(final World world) { | |||
return ((CraftWorld) world).getHandle(); | |||
} | |||
|
|||
@Override |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is some similarity to the generateTree code here. Can we move it to the FaweAdapter too? I also think the Map<BlockPos, CraftBlockState> can be simplified to a list similar to how it's done in generateTree now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was going to look at doing so yeah. It would be more complicated though as the method changes per version a couple of times
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah I don't think that's very viable. We're not able to make any meaningful amount of abstraction as almost every line has a NMS class
import java.lang.reflect.Method; | ||
import java.lang.reflect.Proxy; | ||
|
||
public class PaperweightServerLevelDelegateProxy implements InvocationHandler { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This class seems to be unused in that version. Did you miss upstream changes in the PaperweightAdapter? Generally, do we use that code (the changes in this PR to files in ext/
) ourselves?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah I think there's some cleanup required to marry the implementation across each of the adapter versions
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also, no, we don't use the changes in the ext classes, however, I think it's useful to have the WE code there for reference
The various Tool/Factory classes are in FAWE because they are classes added by FAWE. The actual command methods are in com.sk89q because all commands are there, and are effectively just class edits, not new classes. This implementation was in line with how we handle tree generation, and if we can avoid using an InvocationHandler when it's not needed I think we should (the same for any reflection really) |
Please rebase for 1.20.3/4 |
Please take a moment and address the merge conflicts of your pull request. Thanks! |
boolean successful = false; | ||
|
||
final BlockVector3 pos = clicked.toVector().add().toBlockPoint(); | ||
for (int i = 0; i < 10; i++) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What's the repetition for?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe it exists/existed somewhere in Minecaaft or upstream? There is often a random aspect to a feature or structure (e.g. tree height) that means it might fail to be constructed occasionally. This is an arbitrary way to try a few times basically
.../main/java/com/sk89q/worldedit/bukkit/adapter/impl/fawe/v1_18_R2/PaperweightFaweAdapter.java
Outdated
Show resolved
Hide resolved
From a quick test, it looks like e.g. Similarly, features and structures often cannot be placed with messages "Failed to generated structure. Is it a valid spot for it?" and "This feature cannot go here. Ensure the area meets the requirements." In fact, I wasn't able to spawn any feature for now. Can we somehow lift those restrictions? Otherwise, this is very limiting in its use. |
Yes probably worth doing that
I tried, but no. Minecraft generation code is complete spaghetti and it would require an incredible amount of reflection and likely need us to perform changes to the byte code. The command in upstream WE has the same limitations |
Please take a moment and address the merge conflicts of your pull request. Thanks! |
Please take a moment and address the merge conflicts of your pull request. Thanks! |
Please take a moment and address the merge conflicts of your pull request. Thanks! |
Please take a moment and address the merge conflicts of your pull request. Thanks! |
9f3f70d
to
0a3a607
Compare
0a3a607
to
2807219
Compare
Please take a moment and address the merge conflicts of your pull request. Thanks! |
2807219
to
0773b89
Compare
0773b89
to
535c5e9
Compare
Please take a moment and address the merge conflicts of your pull request. Thanks! |
…eHub/WorldEdit#2239) * Add a feature generator and allow undoing of feature placement [WIP] Apply changes to Forge as well Use proper translatable components * Add a brush version of the feature command Use Java proxy classes * Add for Bukkit (only 1.19.3 for now) Clean up the proxies to use a switch Checkstyle is grumpy Add the obfuscated versions Remove debug text Fix missed "destroyBlock" deobfuscated proxy function * checkstyle
(cherry picked from commit 5ca80395a35100c2d7686ad8839baaa57f8db07c)
535c5e9
to
5face17
Compare