Jump to content
MadCooper

Ultimaker Cura 3.6 - PlugIn with .pyd

Recommended Posts

Posted (edited) · Ultimaker Cura 3.6 - PlugIn with .pyd

Hello,

 

I've been educating myself in Ultimaker Cura 3.6 by writing my own Plugin. At this point I've no problems and everything is working fine. I now decided to convert one file of my Plugin from .py to .pyd with Cython. Now Ultimaker does not even load this Plugin anymore, saying:


2019-04-05 14:46:01,337 - ERROR - [MainThread] UM.Logger.logException [88]:     from . import J_Do_It_2
2019-04-05 14:46:01,337 - ERROR - [MainThread] UM.Logger.logException [88]: ImportError: cannot import name 'J_Do_It_2'

 

Does Ultimaker Cura not support Plugins with precompiled/converted .pyd files?

 

The main file MPFWriter.py

 

import tempfile
import os
import io

from typing import cast
from . import J_Do_It_2

from UM.Application import Application
from UM.Logger import Logger
from UM.Mesh.MeshWriter import MeshWriter #The writer we need to implement.
from UM.MimeTypeDatabase import MimeTypeDatabase, MimeType
from UM.PluginRegistry import PluginRegistry #To get the g-code writer.

class MPFWriter(MeshWriter):

    version = 3

    def __init__(self):
        super().__init__()

    
    def write(self, stream, nodes, mode = MeshWriter.OutputMode.TextMode):

        #Store the g-code from the scene.
        temp_gcode = tempfile.NamedTemporaryFile("w", delete=False)
        name = temp_gcode.name
        gcode_writer = cast(MeshWriter, PluginRegistry.getInstance().getPluginObject("GCodeWriter"))
        success = gcode_writer.write(temp_gcode, None)
        #converter = J_Do_It.DoIt()
        if not success: #Writing the g-code failed. 
            self.setInformation(gcode_writer.getInformation())
            return False

        path = os.path.dirname(os.path.abspath(__file__))
        try: 

            head = io.open((str(path) +"/HeadAndEnd/head.txt"), "r", encoding='utf8')
            end = io.open((str(path) + "/HeadAndEnd/end.txt"), "r", encoding='utf8')
        except EnvironmentError as e:
            if head:
                Logger.log("e", "Cannot open or find HeadFile")
            elif end:
                Logger.log("e", "Cannot open or find EndFile")
            else: 
                Logger.log("Something went wrong")
            return False

        try: 
            J_Do_It_2.DoIt.openFile(name, stream.name, head, end)
            
            
            
        except EnvironmentError as e:
            if temp_gcode:
                Logger.log("e", "Cannot create temp-File {pathTempFile}".format(temp_gcode=temp_gcode))
            return False

        temp_gcode.close()
        os.remove(temp_gcode.name)


        return True

 

The calculator file J_Do_It_2.pyd (before it is converted into pyd and shortened):

import io

class DoIt():

    #Vars

    @classmethod
    def openFile(self, pathSource, pathTarget, head, end):
        #do something

    @classmethod
    def readLine(self, line):

        #do something

    @classmethod
    def replaceVars(self, elements):
        #do something

    @classmethod
    def calculate(self, value, containsXYZ):
        #do something

 

Edited by MadCooper

Share this post


Link to post
Share on other sites
Posted · Ultimaker Cura 3.6 - PlugIn with .pyd

What do you want to achieve by converting the plugin to a pyd file?

 

All plugins are distributed as .py files. You may be able to get it to work with .pyc files instead if you want to obfuscate your code.

Share this post


Link to post
Share on other sites
Posted · Ultimaker Cura 3.6 - PlugIn with .pyd

Note that a .pyd file would only work on Windows.

Share this post


Link to post
Share on other sites
Posted · Ultimaker Cura 3.6 - PlugIn with .pyd
On ‎4‎/‎5‎/‎2019 at 8:02 PM, ahoeben said:

What do you want to achieve by converting the plugin to a pyd file?

A Professor (An engineer) asked me, if Plugins can use .DLL files. Searching for how to use .dll-files in python, I found this hole .pyd thing. So, I just wanted to try it. 

 

And yes, i am working on Windows. 

Share this post


Link to post
Share on other sites
Posted · Ultimaker Cura 3.6 - PlugIn with .pyd

Plugins can theoretically use .dll files, but it's probably going to be tricky to get it to work properly (if at all).

Share this post


Link to post
Share on other sites
Posted · Ultimaker Cura 3.6 - PlugIn with .pyd

@MadCooper There seems to be something missing in your code for your pyd file. Cura (actually the embedded Python interpreter) should be able to pick it up normally. I've embedded PyWin32 into my CAD plugins and it comes with many pyd files and works fine.

You probably want to take a look into SWIG or Cython to be able to code with fewer hassles and let one of these projects generate the C/C++ code you need.

 

Maybe this is something for you! 🙂 

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Our picks

    • Ultimaker Cura 4.0 | Stable available!
      Ultimaker Cura 4.0 is mainly focused on the improved user interface and cloud integration.
      As always, we want to collect your user feedback for this release. If there are any improvements you can think of, feel free to mention it here and help us to shape the next release.
      • 65 replies
×
×
  • Create New...

Important Information

Welcome to the Ultimaker Community of 3D printing experts. Visit the following links to read more about our Terms of Use or our Privacy Policy. Thank you!