Skip to content
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

Repr improvement #6597

Open
wants to merge 19 commits into
base: develop
Choose a base branch
from
Open

Repr improvement #6597

wants to merge 19 commits into from

Conversation

lL1l1
Copy link
Contributor

@lL1l1 lL1l1 commented Dec 22, 2024

Description of the proposed changes

More FAF-specific improvements to the inspect library:

  • Print the base class of a table, if any.
  • Don't print __index fields if they're the same as the table. This removes a lot of common recursive clutter (it is still possible to recurse, for example the Brain.CDR.Brain or WorldView.view.WorldView in the example below).
  • Print source for lua functions in a rather short local format.

Testing done on the proposed changes

Use this command on a Percival:

SimLua LOG(repr(SelectedUnit(), {meta=true}))

Example Output (Percival).txt

Use this command:

UI_Lua LOG(repr(import('/lua/ui/game/worldview.lua').GetWorldViews()['WorldCamera'], {meta = true}))

Example Output (main WorldView).txt

Additional context

The last version of the original repr printed class-specific data. I was lazy on implementing that, but it could be done by using a helper function instead of directly the names table. Still, in general these changes lay the foundations for class-specific data printing.

Checklist

  • Changes are annotated, including comments where useful
  • Changes are documented in the changelog for the next game version

@lL1l1 lL1l1 force-pushed the repr-improvement branch 4 times, most recently from 72c4aed to 47aac38 Compare December 22, 2024 09:25
@lL1l1 lL1l1 marked this pull request as ready for review December 22, 2024 09:28
@Garanas
Copy link
Member

Garanas commented Dec 25, 2024

@maudlin27 / @relent0r you both use this function too. It may be interesting for you to look at these changes and share your thoughts.

local gsub = string.gsub
local fmt = string.format
local _rawget = rawget
local type = type
local getmetatable = getmetatable
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Like this diversity in variable naming. It was discussed 3 years ago and we still mix this and that.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you have a link to the discussion? I haven't seen it.

}

---@param v table | fa-class | fa-class-state
local function fafTableToString(v)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ObjectToString sounds more reasonable.

lua/system/repr.lua Show resolved Hide resolved
@lL1l1 lL1l1 requested a review from 4z0t December 27, 2024 12:00
local type = type
local getmetatable = getmetatable
local debugGetInfo = debug.getinfo
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you make upvalued functions of certain libraries as Pascal case then follow it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants