oscalls.py 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. # THIS FILE IS A PART OF VCStudio
  2. # PYTHON 3
  3. import os
  4. import datetime
  5. import platform
  6. from subprocess import *
  7. # studio
  8. from studio import history
  9. ostype = platform.system()
  10. def Open(arg): # XDG-OPEN (start the file in a default software)
  11. ############################################################################
  12. # This function is requested by people. I can't actually test it properly
  13. # because I don't use proprietary software. And in my opinion this function
  14. # should not even exists here.
  15. # In a GNU/Linux system to open a file with a default program you use xdg-open
  16. # that does the job for you. When talking to people I figured out that similar
  17. # functions exist on different OS as well. But unfortunatly they are all
  18. # different. It's start in Windows and open in MacOS systems. Or so I
  19. # understand. I could be wrong.
  20. # I'm not going to make sure that all xdg-open calls are done using this
  21. # function. So if you trying to run VCStudio on non GNU/Linux system please
  22. # take it into concideration. You can search for xdg-open in all files. And
  23. # change those commands to oscall.Open() instead. ( Keep in mind it has to
  24. # be imported first )
  25. # I don't condone use of non-free software.
  26. ############################################################################
  27. # For The Best OS Ever
  28. if ostype == "Linux": ##### ## ## ## ##
  29. Popen(["xdg-open", arg]) ## ## #### ## ## ##
  30. # For Stinky. Like very, very Stinky ## ## ## ## ## ##
  31. elif ostype == "Windows": ## #### ## ## ## ## ##
  32. os.system("start "+arg) ## # ## ## ## ## ## ##
  33. # For Not that Stinky but it is Stinky ## ## ## #### ## ##
  34. elif ostype == "Darwin": ##### ## ## ####
  35. os.system("open "+arg)
  36. def file_open(win, path):
  37. ############################################################################
  38. # Now you maybe asking yourself "Why is there 2 functions to open files in
  39. # a default application?". Well it's because this is a VCStudio and it's a
  40. # bit more complicated then a regular file manager as you probably could tell.
  41. # One of the big differences is that you can manage versions of Blender to
  42. # be used in a particular project. For example you have a high priority,
  43. # high value project that you rather use Blender LTS for. And not update
  44. # blender. But on the other hand you might start a test / bleading edge
  45. # project. You probably want to have mulitple Blender versions installed in
  46. # the same time. And be able to use one version in one project and the other
  47. # version in the other project.
  48. # In Blender-Organizer legacy there is a setting to change the Blender version
  49. # by providing a link to the folder of where it's installed. I'm planning to
  50. # do similar system here. And so while calling Blender files I want to use
  51. # the Blender that's in the setting and not the system installed Blender.
  52. # Maybe I will expend this feature to all kinds of file formats. It's handy
  53. # to make all opening of files through this function. So I would not need
  54. # to edit this stuff in many places later on.
  55. ############################################################################
  56. # Let's see if the file is inside the project or full path.
  57. if os.path.exists(win.project+"/"+path):
  58. path = win.project+"/"+path
  59. # Let's check if the file is a blend file. (I know I can read first line
  60. # and see if there a word BLENDER in it. But come on. )
  61. blendfile = False
  62. for bt in [".blend", ".blend1"]:
  63. if path.endswith(bt):
  64. blendfile = True
  65. # Executing the file
  66. if blendfile:
  67. Popen([get_current_blender(win), path])
  68. # Every blend file opening should be recorded to history. Because then
  69. # on multiuser, the other users should somehow know that changes were
  70. # done to the blendfile.
  71. history.record(win, path, "[Openned]")
  72. else:
  73. Open(path)
  74. def copy_file(win, from_path, to_path, new_name=""):
  75. ############################################################################
  76. # This function exists because coping files is not as simple as reading one
  77. # and writting it to another. Blend-Files for example could have terrible
  78. # amount of linked stuff. And I can't be sure that the user will be always
  79. # using full path mode for these. And even. It's not good to do it anyway.
  80. # because you want to copy the project from one folder to another and keep
  81. # everything pretty much intact.
  82. # So this will make sure that stuff like blend file (maybe if future other
  83. # files) will be copied preserving all the linking inside.
  84. ############################################################################
  85. # Let's see if the file is inside the project or full path.
  86. if os.path.exists(win.project+"/"+from_path):
  87. from_path = win.project+"/"+from_path
  88. if os.path.exists(win.project+"/"+to_path):
  89. to_path = win.project+"/"+to_path
  90. # Now let's make sure that unless specified we are not overwritting some
  91. # existing file.
  92. if not new_name:
  93. new_name = from_path[from_path.rfind("/")+1:]
  94. count = 0
  95. while new_name in os.listdir(to_path):
  96. count = count + 1
  97. new_name = from_path[from_path.rfind("/")+1:from_path.rfind(".")]+"_"+str(count)+from_path[from_path.rfind("."):]
  98. # Now let's combine name and name
  99. to_path = to_path + "/" + new_name
  100. still = True
  101. # Let's check that we got a blend file
  102. blendfile = False
  103. for bt in [".blend", ".blend1"]:
  104. if from_path.endswith(bt):
  105. blendfile = True
  106. if blendfile:
  107. # Now before we copy blend file we need to check whether Blender is even
  108. # installed.
  109. noblender = os.system(get_current_blender(win)+" -v") # It's a simple version check.
  110. # If there is no Blender installed os.system will return a value higher then 0.
  111. if not noblender:
  112. still = False
  113. # Now what we are going to do is start blender using a little expression
  114. # to force it to save file as.
  115. os.system(get_current_blender(win)\
  116. +" -b "\
  117. +from_path.replace(" ", "\ ")\
  118. +" --python-expr import\ bpy\;\ bpy.ops.wm.save_as_mainfile\(filepath=\\\""\
  119. +to_path.replace(" ", "\ ")+"\\\"\)")
  120. # Writting to history. Since each copy of a file is adding a blendfile.
  121. history.record(win, to_path, "[Added]")
  122. if still:
  123. # If it's not a blendfile we going to use this.
  124. with open(from_path, "rb") as in_file, open(to_path, "wb") as out_file:
  125. out_file.write(in_file.read())
  126. return to_path
  127. def get_current_blender(win):
  128. ############################################################################
  129. # This function is going to get the current blender version from the settings
  130. # (At the moment the feature is not implemented. So this is a placeholder.)
  131. ############################################################################
  132. return "blender"