123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293 |
- #!/usr/bin/env python3
- # -*- Coding: UTF-8 -*-
- # ---------------------------------------------------------------------------
- # Open Asset Import Library (ASSIMP)
- # ---------------------------------------------------------------------------
- #
- # Copyright (c) 2006-2020, ASSIMP Development Team
- #
- # All rights reserved.
- #
- # Redistribution and use of this software in source and binary forms,
- # with or without modification, are permitted provided that the following
- # conditions are met:
- #
- # * Redistributions of source code must retain the above
- # copyright notice, this list of conditions and the
- # following disclaimer.
- #
- # * Redistributions in binary form must reproduce the above
- # copyright notice, this list of conditions and the
- # following disclaimer in the documentation and/or other
- # materials provided with the distribution.
- #
- # * Neither the name of the ASSIMP team, nor the names of its
- # contributors may be used to endorse or promote products
- # derived from this software without specific prior
- # written permission of the ASSIMP Development Team.
- #
- # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- # ---------------------------------------------------------------------------
- from tkinter import *
- import sys
- import os
- import platform
- import run
- import subprocess
- import result_checker as rc
- INFO = 0
- WARN = 1
- ERROR = 2
- # -------------------------------------------------------------------------------
- def log( sev, msg ):
- """
- This function is used to log info, warnings and errors.
- """
- logEntry = ""
- if sev == 0:
- logEntry = logEntry + "[INFO]: "
- elif sev == 1:
- logEntry = logEntry + "[WARN]: "
- elif sev == 2:
- logEntry = logEntry + "[ERR] : "
- logEntry = logEntry + str( msg )
- print( logEntry )
- # -------------------------------------------------------------------------------
- class BaseDialog( Toplevel ):
- """
- Helper base class for dialogs used in the UI.
- """
- def __init__(self, parent, title = None, buttons=""):
- """
- Constructor
- """
- Toplevel.__init__( self, parent )
- self.transient(parent)
- if title:
- self.title(title)
- self.parent = parent
- self.result = None
- body = Frame(self)
- self.initial_focus = self.body(body)
- body.pack(padx=5, pady=5)
- self.buttonbox(buttons)
- self.grab_set()
- if not self.initial_focus:
- self.initial_focus = self
- self.protocol("WM_DELETE_WINDOW", self.cancel)
- self.geometry("+%d+%d" % (parent.winfo_rootx() + 50,
- parent.winfo_rooty() + 50))
- self.initial_focus.focus_set()
- self.wait_window(self)
- def body(self, master):
- # create dialog body. return widget that should have
- # initial focus. this method should be overridden
- pass
- def buttonbox(self, buttons):
- # add standard button box. override if you don't want the
- # standard buttons
- box = Frame(self)
- w = Button(box, text="OK", width=40, command=self.ok, default=ACTIVE)
- w.pack(side=LEFT, padx=5, pady=5)
- self.bind("<Return>", self.ok)
- box.pack()
- def ok(self, event=None):
- if not self.validate():
- self.initial_focus.focus_set() # put focus back
- return
- self.withdraw()
- self.update_idletasks()
- self.apply()
- self.cancel()
- def cancel(self, event=None):
- # put focus back to the parent window
- self.parent.focus_set()
- self.destroy()
- def validate(self):
- return 1 # override
- def apply(self):
- pass # override
- # -------------------------------------------------------------------------------
- class VersionDialog( BaseDialog ):
- """
- This class is used to create the info dialog.
- """
- def body(self, master):
- # info will be read from assimp command line tool
- version = "Asset importer lib version unknown"
- exe = run.getEnvVar( "assimp_path" )
- if len( exe ) != 0:
- command = [exe, "version" ]
- log( INFO, "command = " + str(command))
- stdout = subprocess.check_output(command)
- for line in stdout.splitlines():
- pos = str(line).find( "Version" )
- if -1 != pos:
- version = line
- Label(master, text=version).pack()
- def apply(self):
- pass
- # -------------------------------------------------------------------------------
- class SetupDialog( BaseDialog ):
- """
- This class is used to create the setup dialog.
- """
- def body(self, master):
- Label(master, justify=LEFT, text="Assimp: " ).grid(row=0, column=0)
- Label(master, justify=LEFT, text=run.getEnvVar("assimp_path")).grid(row=0, column=1)
- Label(master, text="New executable:").grid(row=1)
- self.e1 = Entry(master)
- self.e1.grid(row=1, column=1)
- return self.e1 # initial focus
- def apply(self):
- exe = str( self.e1.get() )
- if len( exe ) == 0:
- return 0
- if os.path.isfile( exe ):
- log( INFO, "Set executable at " + exe)
- self.assimp_bin_path = exe
- run.setEnvVar("assimp_path", self.assimp_bin_path)
- else:
- log( ERROR, "Executable not found at "+exe )
- return 0
- # -------------------------------------------------------------------------------
- class RegDialog( object ):
- """
- This class is used to create a simplified user interface for running the regression test suite.
- """
-
- def __init__(self, bin_path ):
- """
- Constructs the dialog, you can define which executable shal be used.
- @param bin_path [in] Path to assimp binary.
- """
- run.setEnvVar( "assimp_path", bin_path )
- self.b_run_ = None
- self.b_update_ = None
- self.b_res_checker_ = None
- self.b_quit_ = None
- if platform.system() == "Windows":
- self.editor = "notepad"
- elif platform.system() == "Linux":
- self.editor = "vim"
- self.root = None
- self.width=40
-
- def run_reg(self):
- log(INFO, "Starting regression test suite.")
- run.run_test()
- rc.run()
- self.b_update_.config( state=ACTIVE )
- return 0
- def reg_update(self):
- assimp_exe = run.getEnvVar( "assimp_path" )
- if len( assimp_exe ) == 0:
- return 1
- exe = "python"
- command = [ exe, "gen_db.py", assimp_exe ]
- log(INFO, "command = " + str(command))
- stdout = subprocess.call(command)
- log(INFO, stdout)
- return 0
-
- def shop_diff( self ):
- log(WARN, "ToDo!")
- return 0
-
- def open_log(self):
- command = [ self.editor, "../results/run_regression_suite_output.txt", ]
- log(INFO, "command = " + str( command ) )
- r = subprocess.call(command)
- return 0
- def show_version( self ):
- d = VersionDialog( self.root )
- return 0
-
- def setup(self):
- d = SetupDialog( self.root )
- return 0
- def quit(self):
- log( INFO, "quit" )
- sys.exit( 0 )
- def initUi(self):
- # create the frame with buttons
- self.root = Tk()
- self.root.title( "Assimp-Regression UI")
- self.b_run_ = Button( self.root, text="Run regression ", command=self.run_reg, width = self.width )
- self.b_update_ = Button( self.root, text="Update database", command=self.reg_update, width = self.width )
- self.b_show_diff_ = Button( self.root, text="Show diff", command=self.shop_diff, width = self.width )
- self.b_log_ = Button( self.root, text="Open log", command=self.open_log, width = self.width )
- self.b_setup_ = Button( self.root, text="Setup", command=self.setup, width = self.width )
- self.b_version_ = Button( self.root, text="Show version", command=self.show_version, width = self.width )
- self.b_quit_ = Button( self.root, text="Quit", command=self.quit, width = self.width )
-
- # define the used grid
- self.b_run_.grid( row=0, column=0, sticky=W+E )
- self.b_update_.grid( row=1, column=0, sticky=W+E )
- self.b_show_diff_.grid( row=2, column=0, sticky=W+E )
- self.b_log_.grid( row=3, column=0, sticky=W+E )
- self.b_setup_.grid( row=4, column=0, sticky=W+E )
- self.b_version_.grid( row=5, column=0, sticky=W+E )
- self.b_quit_.grid( row=6, column=0, sticky=W+E )
-
- #self.b_update_.config( state=DISABLED )
- self.b_show_diff_.config( state=DISABLED )
-
- # run mainloop
- self.root.mainloop()
- # -------------------------------------------------------------------------------
- def getDefaultExecutable():
- assimp_bin_path = ""
- if platform.system() == "Windows":
- assimp_bin_path = '..\\..\\bin\\debug\\assimpd.exe'
- elif platform.system() == "Linux":
- assimp_bin_path = '../../bin/assimp'
- return assimp_bin_path
- # -------------------------------------------------------------------------------
- if __name__ == "__main__":
- if len(sys.argv) > 1:
- assimp_bin_path = sys.argv[1]
- else:
- assimp_bin_path = getDefaultExecutable()
- log( INFO, 'Using assimp binary: ' + assimp_bin_path )
- dlg = RegDialog(assimp_bin_path)
- dlg.initUi()
-
- # vim: ai ts=4 sts=4 et sw=4
|