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

[Bug]: ironpython 3.4 fails to load in pyrevit 5 from WIP installers #2440

Open
5 tasks done
jj-github-jj opened this issue Oct 29, 2024 · 12 comments
Open
5 tasks done
Labels
Bug Bug that stops user from using the tool or a major portion of pyRevit functionality [class] IronPython3 issues regarding the IronPython 3(.4) engine
Milestone

Comments

@jj-github-jj
Copy link

jj-github-jj commented Oct 29, 2024

✈ Pre-Flight checks

  • I don't have SentinelOne antivirus installed (see above for the solution)
  • I have searched in the issues (open and closed) but couldn't find a similar issue
  • I have searched in the pyRevit Forum for similar issues
  • I already followed the installation troubleshooting guide thoroughly
  • I am using the latest pyRevit Version

🐞 Describe the bug

image
The system error: could not load type 'IronPythonruntime.list from assembly 'pyrevitlabs.Ironpython Version = 3.4.1.0
shows up when I changed the core settingst ot use ironpython 3.4
Also because of the above error, pyrevit doesnt show up on Revit 2023 as well and I had to re-install pyrevit to undo this core settings change to 3.4

⌨ Error/Debug Message

image

♻️ To Reproduce

Install pyrevit 5 from wip installers and change core setting to IronPython 3.4 and restart Revit 2023
You will see the error

⏲️ Expected behavior

no fail to load

🖥️ Hardware and Software Setup (please complete the following information)

==> Registered Clones (full git repos)
==> Registered Clones (deployed from archive/image)
master | Branch: "master" | Version: "5.0.0.24299+1037-wip" | Path: "C:\Users\user\AppData\Roaming\pyRevit-Master"
==> Attachments
master | Product: "24.1.1" | Engine: IPY340PR (340) | Path: "C:\Users\user\AppData\Roaming\pyRevit-Master"
master | Product: "23.1.3" | Engine: IPY340PR (340) | Path: "C:\Users\user\AppData\Roaming\pyRevit-Master"
master | Product: "2021.1.9" | Engine: IPY340PR (340) | Path: "C:\Users\user\AppData\Roaming\pyRevit-Master"
==> Installed Extensions
==> Default Extension Search Path
C:\Users\user\AppData\Roaming\pyRevit\Extensions
==> Extension Search Paths
==> Extension Sources - Default
https://github.com/pyrevitlabs/pyRevit/raw/master/extensions/extensions.json
==> Extension Sources - Additional
==> Installed Revits
24.1.1 | Version: 24.1.10.25 | Build: 20230830_0315(x64) | Language: 1033 | Path: "C:\Program Files\Autodesk\Revit 2024\"
23.1.3 | Version: 23.1.30.97 | Build: 20230828_1515(x64) | Language: 1033 | Path: "C:\Program Files\Autodesk\Revit 2023\"
2021.1.9 | Version: 21.1.90.15 | Build: 20230907_1515(x64) | Language: 1033 | Path: "C:\Program Files\Autodesk\Revit 2021\"
==> Running Revit Instances
PID: 11736 | 23.1.3 | Version: 23.1.30.97 | Build: 20230828_1515(x64) | Language: 0 | Path: "C:\Program Files\Autodesk\Revit 2023"
==> User Environment
Microsoft Windows 10 [Version 10.0.19045]
Executing User: ***
Active User: *** 
Admin Access: No
%APPDATA%: "C:\Users\user\AppData\Roaming"
Latest Installed .Net Framework: 8.0.5
No .Net Target Packs are installed.
Installed .Net-Core Target Packs: v8.0.300
pyRevit CLI v5.0.0.24299+1037-wip.8caf21fc8ed934cf3feb7be27704d326639c6607

Additional context

No response

@jj-github-jj jj-github-jj added the Bug Bug that stops user from using the tool or a major portion of pyRevit functionality [class] label Oct 29, 2024
@sanzoghenzo
Copy link
Contributor

Thanks for the report.
FYI, you dont need to reinstall pyrevit to make it work again, just do pyrevit attach master default --installed in a command prompt as instructed in the troubleshooting guide.

@sanzoghenzo sanzoghenzo added the IronPython Issues related to standalone IronPython installation [subsystem] label Oct 30, 2024
@sanzoghenzo sanzoghenzo added IronPython3 issues regarding the IronPython 3(.4) engine and removed IronPython Issues related to standalone IronPython installation [subsystem] labels Nov 22, 2024
@sanzoghenzo sanzoghenzo added this to the pyRevit 5 RC milestone Dec 27, 2024
@sanzoghenzo
Copy link
Contributor

I can reproduce this on my machine, that has the pyrevit Dev tools extension enabled.

changing the end of pyrevit\loader\sessionmgr.py to the following shows the error but continues to load pyRevit:

    try:
        runtime.types.ScriptExecutor.ExecuteScript(
            script_data,
            script_runtime_cfg
        )
    except Exception as e:
        mlogger.error(
            'Error executing extension startup script: %s | %s', script_path, e
        )

But then no python script will run, outputting the same error as the OP.

This is the full exception stack trace I got while debugging with visual studio:

System.TypeLoadException
  HResult=0x80131522
  Message=Could not load type 'IronPython.Runtime.List' from assembly 'pyRevitLabs.IronPython, Version=3.4.1.0, Culture=neutral, PublicKeyToken=7f709c5b713576e1'.
  Source=pyRevitLabs.PyRevit.Runtime.2023
  StackTrace:
   at PyRevitLabs.PyRevit.Runtime.IronPythonEngine.SetupArguments(ScriptRuntime& runtime) in dev\pyRevitLabs.PyRevit.Runtime\IronPythonEngine.cs:line 266
   at PyRevitLabs.PyRevit.Runtime.IronPythonEngine.Start(ScriptRuntime& runtime) in dev\pyRevitLabs.PyRevit.Runtime\IronPythonEngine.cs:line 100
   at PyRevitLabs.PyRevit.Runtime.ScriptExecutor.ExecuteManagedScript[T](ScriptRuntime& runtime) in dev\pyRevitLabs.PyRevit.Runtime\ScriptExecutor.cs:line 189
   at PyRevitLabs.PyRevit.Runtime.ScriptExecutor.ExecuteScriptNow(ScriptData scriptData, ScriptRuntimeConfigs scriptRuntimeCfg, ScriptExecutorConfigs scriptExecConfigs) in dev\pyRevitLabs.PyRevit.Runtime\ScriptExecutor.cs:line 87
   at PyRevitLabs.PyRevit.Runtime.ScriptExecutor.ExecuteScript(ScriptData scriptData, ScriptRuntimeConfigs scriptRuntimeCfg, ScriptExecutorConfigs scriptExecConfigs) in dev\pyRevitLabs.PyRevit.Runtime\ScriptExecutor.cs:line 71
   at PyRevitLabs.PyRevit.Runtime.ScriptCommand.Execute(ExternalCommandData commandData, String& message, ElementSet elements) in dev\pyRevitLabs.PyRevit.Runtime\ScriptCommands.cs:line 279
   at apiManagedExecuteCommand(AString* assemblyName, AString* className, AString* vendorDescription, MFCApp* pMFCApp, DBView* pDBView, AString* message, Set<ElementId\,std::less<ElementId>\,tnallc<ElementId> >* ids, Map<AString\,AString\,std::less<AString>\,tnallc<std::pair<AString const \,AString> > >* data, AString* exceptionName, AString* exceptionMessage)

The root cause is that IronPython3 renamed IronPython.Runtime.List to IronPython.Runtime.PythonList, but pyRevitLabs.Runtime is only compiled against IronPython2.

I believe that we should move the PyRevitLabs.Runtime.IronPythonEngine (or at least the parts that directly depends on ironpython) to its own assembly, compile it against the various engines and put it into the engines folder.

The question is: @jmcouffin @dosymep are we willing to do this? I personally would like to focus on CPython 3 support instead of trying to support a library that was already old when it was released 🤣

@jmcouffin
Copy link
Contributor

The question is: @jmcouffin @dosymep are we willing to do this? I personally would like to focus on CPython 3 support instead of trying to support a library that was already old when it was released 🤣

Agreed on the "oldness" ;p

If I am not mistaken, wouldn't it imply a lot of issues/refactoring?

  • Revit API classes access issues
  • WPF support
  • Code transition from IPY to CPY3

@sanzoghenzo
Copy link
Contributor

sanzoghenzo commented Dec 28, 2024

The question is: @jmcouffin @dosymep are we willing to do this? I personally would like to focus on CPython 3 support instead of trying to support a library that was already old when it was released 🤣

Agreed on the "oldness" ;p

If I am not mistaken, wouldn't it imply a lot of issues/refactoring?

* Revit API classes access issues

* WPF support

* Code transition from IPY to CPY3

What I meant is that I would like to try to bring support to cpython 3 alongside ironpython 2.7 rather than trying to make ironpython 3.4 work as engine for pyrevit

@jmcouffin
Copy link
Contributor

What I meant is that I would like to try to bring support to cpython 3 alongside ironpython 2.7 rather than trying to make ironpython 3.4 work as engine for pyrevit

gotcha

what would be your arguments pros/cons?

@sanzoghenzo
Copy link
Contributor

What I meant is that I would like to try to bring support to cpython 3 alongside ironpython 2.7 rather than trying to make ironpython 3.4 work as engine for pyrevit

gotcha

what would be your arguments pros/cons?

Not sure I follow you...

I already proposed to drop the IronPython 3.4.0 engine, and use only one IronPython engine at a time, in my plan proposal;
this will solve the many attachments issues we currently face, and make development easier (only one IronPython library to handle at any given time).

CPython is something that I always wanted to make it work because of the endless possibilities given by the various python libraries out there (for which I proposed the "dependencies" section in the extension manifest and the usage of virtualenv/uv for managing them).
As you said there are things to fix, mainly the pyrevit.forms (revit API shouldnt be an issue, but I might be wrong). I started to investigate it a while ago but didn't manage to solve it...

@jmcouffin
Copy link
Contributor

to drop the IronPython 3.4.0 engine, and use only one IronPython engine at a time, in my plan proposal

Makes sense.

CPython is something that I always wanted to make it work because of the endless possibilities given by the various python libraries out there (for which I proposed the "dependencies" section in the extension manifest and the usage of virtualenv/uv for managing them).
As you said there are things to fix, mainly the pyrevit.forms (revit API shouldnt be an issue, but I might be wrong). I started to investigate it a while ago but didn't manage to solve it...

I agree, but I am a bit worried about it, as you mentioned you would not be involved anymore in 2025, I wonder if anyone could take over the task _ and I am sure chatGPT is not there yet ;p

@trgiangv
Copy link
Contributor

@sanzoghenzo @jmcouffin

I completely understand the challenges around juggling multiple IronPython versions, and I agree that consolidating onto a single engine simplifies both development and maintenance. IronPython 3 is actively developed for newer .NET versions and supports Python 3 syntax, which has been the modern standard for quite some time. Meanwhile, IronPython 2 is no longer being actively developed, which limits its long-term viability and poses maintenance issues.

Reasons to keep IronPython 3:

  1. Future-Proofing
    IronPython 3 aligns with current and future .NET (e.g., .NET 8+), ensuring compatibility going forward. Sticking to Python 2 syntax with IronPython 2 only gets more problematic over time.

  2. Development Efficiency
    Maintaining a single engine means fewer conflicts, simpler attachment handling, and less engine-specific debugging. We can channel resources into making IronPython 3 stable and robust instead of spreading ourselves thin across multiple Python engines.

  3. Better .NET DLL Compatibility
    IronPython 3 continues to improve its integration with .NET. It remains the best choice when tight interoperability with Revit’s APIs (or other .NET libraries) is a priority.

Overall, adopting IronPython 3 as the sole engine helps us stay modern, reduces technical debt, and maintains a strong .NET integration layer essential for Revit development.

@jmcouffin
Copy link
Contributor

I completely understand the challenges around juggling multiple IronPython versions, and I agree that consolidating onto a single engine simplifies both development and maintenance. IronPython 3 is actively developed for newer .NET versions and supports Python 3 syntax, which has been the modern standard for quite some time. Meanwhile, IronPython 2 is no longer being actively developed, which limits its long-term viability and poses maintenance issues.

Reasons to keep IronPython 3:

  1. Future-Proofing
    IronPython 3 aligns with current and future .NET (e.g., .NET 8+), ensuring compatibility going forward. Sticking to Python 2 syntax with IronPython 2 only gets more problematic over time.
  2. Development Efficiency
    Maintaining a single engine means fewer conflicts, simpler attachment handling, and less engine-specific debugging. We can channel resources into making IronPython 3 stable and robust instead of spreading ourselves thin across multiple Python engines.
  3. Better .NET DLL Compatibility
    IronPython 3 continues to improve its integration with .NET. It remains the best choice when tight interoperability with Revit’s APIs (or other .NET libraries) is a priority.

Overall, adopting IronPython 3 as the sole engine helps us stay modern, reduces technical debt, and maintains a strong .NET integration layer essential for Revit development.

you got use GTPed :)
That's ok.

I do agree, but we have no bandwidth/manpower or money to hire someone to do so.
Do you have the skills and the time @trgiangv

@trgiangv
Copy link
Contributor

@jmcouffin
Yeah 😂, I'll try to fix it on my side, but I can't guarantee anything. The build process of pyRevit is too hard for me. I already made it work before by changing the reference DLLs. Anyway, I'll do my best!

@sanzoghenzo
Copy link
Contributor

sanzoghenzo commented Jan 22, 2025

I agree with @jmcouffin, feature parity with current IronPython 2.7 needs to happen before the switch to 3.4.
What worries me most is that, despite the active development of IronPython, there are only milestones for the versions 3.4.3 and 3.6 (last updated more than 2 years ago), while CPython already marked 3.8 end-of-life in october 2024...
https://devguide.python.org/versions/#python-release-cycle

@jmcouffin
Copy link
Contributor

The build process of pyRevit is too hard for me

Just to make sure you know this exists https://docs.pyrevitlabs.io/dev-guide/ @trgiangv

Hen gap lai!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Bug that stops user from using the tool or a major portion of pyRevit functionality [class] IronPython3 issues regarding the IronPython 3(.4) engine
Projects
Status: No status
Development

No branches or pull requests

4 participants