Comments (7)
Does this look related?
https://github.com/TASVideos/tastools/tree/master/Lua/LuaPerks
from fceux.
Thank you. I'm sure that's it.
from fceux.
I guess it should be a part of fceux codebase if it's the right thing. @zeromus?
from fceux.
Well it's close enough, I just needed to know where to find it. All I would really suggest doing is:
- Move vc/luaperks.lib to src/drivers/win/lua/win32 instead.
- Leave a text document nearby explaining where the lib came from.
I've done this already in the x64-ready branch I'm preparing.
I still don't know what lua51.dll is, though, or if src/lua or auxlib.lua have any function. I imagine the latter two could be deleted, but not sure. The DLL I have no clue what it does.
from fceux.
It seems that lua51.dll and lua5.1.dll have the same set of exports, but lua51 has very little actual data in it. Some sort of dummy version of the library with everything removed?
I see lua51 is used by a CheckLua function that just loads it then frees it immediately to check that it exists. It doesn't seem to actually do anything with it? Change that added it.
I found this note in the 2.2.2 changes: Dynamic link to lua51.dll instead of static linking, because some external libraries might crash without lua51.dll
Before that change, it looks sorta like lua51 was just the regular lua library/DLL but renamed? (Maybe we didn't like the . in the filename in 2010?) The current version seems like some stub kludge to keep something happy but I'm not sure what yet.
from fceux.
different lua libraries reference lua51.dll or lua5.1.dll. It's standard to deploy both of them, and the small one is nothing but a dummy thingy to keep half the libraries happy. It isn't our kludge, it's a standard kludge.
the lua sources that are checked in are for linux because there was no luaperks static lib builds for that. Of course linux users would probably rather use their distro install of lua-devel or whatever, but there are virtually no lua+fceux+linux users.
I don't remember why we use our own lua. Maybe we used to have it modified. Maybe we used lua private functions. Maybe we used lua struct layout details and couldnt warrant compatibility with whatever random ass lua dlls some clowns bring. (historically, the lua APis lack something you need and so you have to do it yourself). I think it's possible that 3rd party lua libraries (or lua itself) explode when you try to use them in an incompatible process (incompatible build options and initialization logic). My static linking them all together could have been a desperate attempt to bring them to life so they could be used at all.
I don't know why some other guy decided years ago to apparently use the dll instead. Nobody's complained about anything besides the usual "my 3rd party library doesn't work" so it must be benign. But it should result in mixing the DLL lua with the static linked luaperks, and that should restrict what DLL versions can be used.
luaperks should not be part of the codebase. it's right there in another repository.
But we should try shitcanning all the static stuff and shut everyone up forever, and if we can remember why we static linked and possibly customized it, write down what nice thing that gave us that we can't have any more, so we don't forget it.
Why do you need an x64 fceux?
from fceux.
Thanks, that answers all of my questions I think. I'll close this.
As for your question about x64 FCEUX, some reasons were given here: #57
It'd probably be better to discuss it there than here, I just wanted to understand the lua build/library structure here.
from fceux.
Related Issues (20)
- SD Gundam Gaiden 2 EEPROM issues
- [Feature request] Retroachievements support
- Feature Requests + Bug Report
- Cancel button does nothing
- Enabling line break causes emulator crash. HOT 1
- Game Genie encoder/decoder not working properly. HOT 2
- Compiled Linux executable download link HOT 1
- FCEUX 2.7.0 crashes when you try to Record AVI Movie (64 bit version was tested) HOT 4
- Corrupted screen in 3D Block HOT 2
- Win64 download file trojan report HOT 1
- [glitch] Bases Loaded 3's ending graphics are glitched. HOT 4
- Snapshot shows up as blue color
- Cheats not importing
- Pac-Man Battle Royale HOT 3
- Akumajou Special - Boku Dracula-kun IRQ Emulate BUG. HOT 1
- fceux not launch - Qt Warning: Unrecognized OpenGL version
- build error - Package 'minizip', required by 'virtual:world', not found HOT 2
- [Qt] SDL video driver instant black issue
- [Qt] Couldn't save Normal Speed hotkey config
- Attribution HOT 4
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from fceux.