2 Copyright 2008 Free Software Foundation, Inc.
3 This file is part of GNU Radio
5 GNU Radio Companion is free software; you can redistribute it and/or
6 modify it under the terms of the GNU General Public License
7 as published by the Free Software Foundation; either version 2
8 of the License, or (at your option) any later version.
10 GNU Radio Companion is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
20 from Actions import FLOW_GRAPH_CLOSE
24 from .. utils import ParseXML
25 from StateCache import StateCache
26 from .. platforms.base.Constants import FLOW_GRAPH_DTD
27 from Constants import MIN_WINDOW_WIDTH, MIN_WINDOW_HEIGHT
28 from DrawingArea import DrawingArea
31 ############################################################
33 ############################################################
35 class NotebookPage(gtk.HBox):
36 """A page in the notebook."""
38 def __init__(self, main_window, flow_graph, file_path=''):
41 @param main_window main window
42 @param file_path path to a flow graph file
44 self._flow_graph = flow_graph
47 self.main_window = main_window
48 self.set_file_path(file_path)
49 file_path = file_path or flow_graph.get_parent().get_default_flow_graph()
50 open(file_path, 'r') #test open
51 ############################################################
52 from .. utils import converter
53 converter.convert(file_path, flow_graph.get_parent())
54 ############################################################
55 ParseXML.validate_dtd(file_path, FLOW_GRAPH_DTD)
56 initial_state = ParseXML.from_file(file_path)
57 self.state_cache = StateCache(initial_state)
59 #import the data to the flow graph
60 self.get_flow_graph().import_data(initial_state)
62 gtk.HBox.__init__(self, False, 0)
64 #tab box to hold label and close button
65 self.tab = gtk.HBox(False, 0)
67 self.label = gtk.Label()
68 self.tab.pack_start(self.label, False)
71 image.set_from_stock('gtk-close', gtk.ICON_SIZE_MENU)
73 image_box = gtk.HBox(False, 0)
74 image_box.pack_start(image, True, False, 0)
77 button.connect("clicked", self._handle_button)
78 button.set_relief(gtk.RELIEF_NONE)
81 w, h = gtk.icon_size_lookup_for_settings(button.get_settings(), gtk.ICON_SIZE_MENU)
82 button.set_size_request(w+6, h+6)
83 self.tab.pack_start(button, False)
85 #setup scroll window and drawing area
86 self.scrolled_window = gtk.ScrolledWindow()
87 self.scrolled_window.set_size_request(MIN_WINDOW_WIDTH, MIN_WINDOW_HEIGHT)
88 self.scrolled_window.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
89 self.drawing_area = DrawingArea(self.get_flow_graph())
90 self.scrolled_window.add_with_viewport(self.get_drawing_area())
91 self.pack_start(self.scrolled_window)
92 #inject drawing area and handle states into flow graph
93 self.get_flow_graph().drawing_area = self.get_drawing_area()
94 self.get_flow_graph().handle_states = main_window.handle_states
97 def get_drawing_area(self): return self.drawing_area
99 def get_generator(self):
101 Get the generator object for this flow graph.
104 return self.get_flow_graph().get_parent().get_generator()(
105 self.get_flow_graph(),
106 self.get_file_path(),
109 def _handle_button(self, button):
111 The button was clicked.
112 Make the current page selected, then close.
115 self.main_window.page_to_be_closed = self
116 self.main_window.handle_states(FLOW_GRAPH_CLOSE)
118 def set_text(self, text):
120 Set the text in this label.
121 @param text the new text
123 self.label.set_text(text)
127 Get the gtk widget for this page's tab.
134 Get the pid for the flow graph.
135 @return the pid number
139 def set_pid(self, pid):
142 @param pid the new pid number
146 def get_flow_graph(self):
149 @return the flow graph
151 return self._flow_graph
153 def get_read_only(self):
155 Get the read-only state of the file.
156 Always false for empty path.
157 @return true for read-only
159 if not self.get_file_path(): return False
160 return os.path.exists(self.get_file_path()) and \
161 not os.access(self.get_file_path(), os.W_OK)
163 def get_file_path(self):
165 Get the file path for the flow graph.
166 @return the file path or ''
168 return self.file_path
170 def set_file_path(self, file_path=''):
172 Set the file path, '' for no file path.
173 @param file_path file path string
175 if file_path: self.file_path = os.path.abspath(file_path)
176 else: self.file_path = ''
180 Get the saved status for the flow graph.
181 @return true if saved
185 def set_saved(self, saved=True):
187 Set the saved status.
188 @param saved boolean status
192 def get_state_cache(self):
194 Get the state cache for the flow graph.
195 @return the state cache
197 return self.state_cache