forked from bartvdbraak/blender
71446eea57
* Some cases of struct name being set where it shouldnt have been. * Spelling: wich --> which * Copy and initialize uv modifier scale, remove unneeded enum. * Ability to pin any object into the context. * Update uv window while transforming (useful when used with UVProject modifier) * Patch by Wahooney, so new template's are internal text and dont get saved over by mistake. * Fix for https://bugzilla.redhat.com/show_bug.cgi?id=572186 Bug 572186 - [abrt] crash in blender-2.49b-5.fc12: Process /usr/bin/blender.bin was killed by signal 6 (SIGABRT). Original fix submitted by Jochen Schmitt. * [#21816] bpy.data.add_image has stopped working on Windows. moved to bpy.data.images.load(), missed this call. (commits 27726,27825,27828,27831,27832,27833,27834,27836,27837,27838,27839,27858 by Campbell from render25 branch)
304 lines
7.7 KiB
Python
304 lines
7.7 KiB
Python
# ##### BEGIN GPL LICENSE BLOCK #####
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2
|
|
# of the License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software Foundation,
|
|
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
#
|
|
# ##### END GPL LICENSE BLOCK #####
|
|
|
|
# <pep8 compliant>
|
|
import bpy
|
|
|
|
|
|
class TEXT_HT_header(bpy.types.Header):
|
|
bl_space_type = 'TEXT_EDITOR'
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
st = context.space_data
|
|
text = st.text
|
|
|
|
row = layout.row(align=True)
|
|
row.template_header()
|
|
|
|
if context.area.show_menus:
|
|
sub = row.row(align=True)
|
|
sub.menu("TEXT_MT_text")
|
|
if text:
|
|
sub.menu("TEXT_MT_edit")
|
|
sub.menu("TEXT_MT_format")
|
|
|
|
if text and text.modified:
|
|
row = layout.row()
|
|
# row.color(redalert)
|
|
row.operator("text.resolve_conflict", text="", icon='HELP')
|
|
|
|
layout.template_ID(st, "text", new="text.new", unlink="text.unlink")
|
|
|
|
row = layout.row(align=True)
|
|
row.prop(st, "line_numbers", text="")
|
|
row.prop(st, "word_wrap", text="")
|
|
row.prop(st, "syntax_highlight", text="")
|
|
|
|
if text:
|
|
row = layout.row()
|
|
row.operator("text.run_script")
|
|
row.prop(text, "use_module")
|
|
|
|
row = layout.row()
|
|
if text.filename != "":
|
|
if text.dirty:
|
|
row.label(text="File: *%s (unsaved)" % text.filename)
|
|
else:
|
|
row.label(text="File: %s" % text.filename)
|
|
else:
|
|
if text.library:
|
|
row.label(text="Text: External")
|
|
else:
|
|
row.label(text="Text: Internal")
|
|
|
|
|
|
class TEXT_PT_properties(bpy.types.Panel):
|
|
bl_space_type = 'TEXT_EDITOR'
|
|
bl_region_type = 'UI'
|
|
bl_label = "Properties"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
st = context.space_data
|
|
|
|
flow = layout.column_flow()
|
|
flow.prop(st, "line_numbers")
|
|
flow.prop(st, "word_wrap")
|
|
flow.prop(st, "syntax_highlight")
|
|
flow.prop(st, "live_edit")
|
|
|
|
flow = layout.column_flow()
|
|
flow.prop(st, "font_size")
|
|
flow.prop(st, "tab_width")
|
|
|
|
text = st.text
|
|
if text:
|
|
flow.prop(text, "tabs_as_spaces")
|
|
|
|
|
|
class TEXT_PT_find(bpy.types.Panel):
|
|
bl_space_type = 'TEXT_EDITOR'
|
|
bl_region_type = 'UI'
|
|
bl_label = "Find"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
st = context.space_data
|
|
|
|
# find
|
|
col = layout.column(align=True)
|
|
row = col.row()
|
|
row.prop(st, "find_text", text="")
|
|
row.operator("text.find_set_selected", text="", icon='TEXT')
|
|
col.operator("text.find")
|
|
|
|
# replace
|
|
col = layout.column(align=True)
|
|
row = col.row()
|
|
row.prop(st, "replace_text", text="")
|
|
row.operator("text.replace_set_selected", text="", icon='TEXT')
|
|
col.operator("text.replace")
|
|
|
|
# mark
|
|
layout.operator("text.mark_all")
|
|
|
|
# settings
|
|
row = layout.row()
|
|
row.prop(st, "find_wrap", text="Wrap")
|
|
row.prop(st, "find_all", text="All")
|
|
|
|
|
|
class TEXT_MT_text(bpy.types.Menu):
|
|
bl_label = "Text"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
st = context.space_data
|
|
text = st.text
|
|
|
|
layout.column()
|
|
layout.operator("text.new")
|
|
layout.operator("text.open")
|
|
|
|
if text:
|
|
layout.operator("text.reload")
|
|
|
|
layout.column()
|
|
layout.operator("text.save")
|
|
layout.operator("text.save_as")
|
|
|
|
if text.filename != "":
|
|
layout.operator("text.make_internal")
|
|
|
|
layout.column()
|
|
layout.operator("text.run_script")
|
|
|
|
#ifndef DISABLE_PYTHON
|
|
# XXX if(BPY_is_pyconstraint(text))
|
|
# XXX uiMenuItemO(head, 0, "text.refresh_pyconstraints");
|
|
#endif
|
|
|
|
layout.separator()
|
|
|
|
layout.operator("text.properties", icon='MENU_PANEL')
|
|
|
|
layout.menu("TEXT_MT_templates")
|
|
|
|
layout.separator()
|
|
|
|
layout.operator("screen.area_dupli")
|
|
layout.operator("screen.screen_full_area")
|
|
|
|
|
|
class TEXT_MT_templates(bpy.types.Menu):
|
|
'''
|
|
Creates the menu items by scanning scripts/templates
|
|
'''
|
|
bl_label = "Script Templates"
|
|
|
|
def draw(self, context):
|
|
self.path_menu(bpy.utils.script_paths("templates"), "text.open", {"internal": True})
|
|
|
|
|
|
class TEXT_MT_edit_view(bpy.types.Menu):
|
|
bl_label = "View"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
layout.operator("text.move", text="Top of File").type = 'FILE_TOP'
|
|
layout.operator("text.move", text="Bottom of File").type = 'FILE_BOTTOM'
|
|
|
|
|
|
class TEXT_MT_edit_select(bpy.types.Menu):
|
|
bl_label = "Select"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
layout.operator("text.select_all")
|
|
layout.operator("text.select_line")
|
|
|
|
|
|
class TEXT_MT_edit_markers(bpy.types.Menu):
|
|
bl_label = "Markers"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
layout.operator("text.markers_clear")
|
|
layout.operator("text.next_marker")
|
|
layout.operator("text.previous_marker")
|
|
|
|
|
|
class TEXT_MT_format(bpy.types.Menu):
|
|
bl_label = "Format"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
layout.operator("text.indent")
|
|
layout.operator("text.unindent")
|
|
|
|
layout.separator()
|
|
|
|
layout.operator("text.comment")
|
|
layout.operator("text.uncomment")
|
|
|
|
layout.separator()
|
|
|
|
layout.operator_menu_enum("text.convert_whitespace", "type")
|
|
|
|
|
|
class TEXT_MT_edit_to3d(bpy.types.Menu):
|
|
bl_label = "Text To 3D Object"
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
layout.operator("text.to_3d_object", text="One Object").split_lines = False
|
|
layout.operator("text.to_3d_object", text="One Object Per Line").split_lines = True
|
|
|
|
|
|
class TEXT_MT_edit(bpy.types.Menu):
|
|
bl_label = "Edit"
|
|
|
|
def poll(self, context):
|
|
return (context.space_data.text)
|
|
|
|
def draw(self, context):
|
|
layout = self.layout
|
|
|
|
layout.operator("ed.undo")
|
|
layout.operator("ed.redo")
|
|
|
|
layout.separator()
|
|
|
|
layout.operator("text.cut")
|
|
layout.operator("text.copy")
|
|
layout.operator("text.paste")
|
|
|
|
layout.separator()
|
|
|
|
layout.menu("TEXT_MT_edit_view")
|
|
layout.menu("TEXT_MT_edit_select")
|
|
layout.menu("TEXT_MT_edit_markers")
|
|
|
|
layout.separator()
|
|
|
|
layout.operator("text.jump")
|
|
layout.operator("text.properties", text="Find...")
|
|
|
|
layout.separator()
|
|
|
|
layout.menu("TEXT_MT_edit_to3d")
|
|
|
|
|
|
classes = [
|
|
TEXT_HT_header,
|
|
TEXT_PT_properties,
|
|
TEXT_PT_find,
|
|
TEXT_MT_text,
|
|
TEXT_MT_templates,
|
|
TEXT_MT_format,
|
|
TEXT_MT_edit,
|
|
TEXT_MT_edit_view,
|
|
TEXT_MT_edit_select,
|
|
TEXT_MT_edit_markers,
|
|
TEXT_MT_edit_to3d]
|
|
|
|
|
|
def register():
|
|
register = bpy.types.register
|
|
for cls in classes:
|
|
register(cls)
|
|
|
|
|
|
def unregister():
|
|
unregister = bpy.types.unregister
|
|
for cls in classes:
|
|
unregister(cls)
|
|
|
|
if __name__ == "__main__":
|
|
register()
|