Show More
@@ -138,6 +138,11 b' class ConsoleWidget(LoggingConfigurable, QtGui.QWidget):' | |||||
138 |
|
138 | |||
139 | #------ Protected class variables ------------------------------------------ |
|
139 | #------ Protected class variables ------------------------------------------ | |
140 |
|
140 | |||
|
141 | # control handles | |||
|
142 | _control = None | |||
|
143 | _page_control = None | |||
|
144 | _splitter = None | |||
|
145 | ||||
141 | # When the control key is down, these keys are mapped. |
|
146 | # When the control key is down, these keys are mapped. | |
142 | _ctrl_down_remap = { QtCore.Qt.Key_B : QtCore.Qt.Key_Left, |
|
147 | _ctrl_down_remap = { QtCore.Qt.Key_B : QtCore.Qt.Key_Left, | |
143 | QtCore.Qt.Key_F : QtCore.Qt.Key_Right, |
|
148 | QtCore.Qt.Key_F : QtCore.Qt.Key_Right, | |
@@ -182,8 +187,6 b' class ConsoleWidget(LoggingConfigurable, QtGui.QWidget):' | |||||
182 | layout = QtGui.QStackedLayout(self) |
|
187 | layout = QtGui.QStackedLayout(self) | |
183 | layout.setContentsMargins(0, 0, 0, 0) |
|
188 | layout.setContentsMargins(0, 0, 0, 0) | |
184 | self._control = self._create_control() |
|
189 | self._control = self._create_control() | |
185 | self._page_control = None |
|
|||
186 | self._splitter = None |
|
|||
187 | if self.paging in ('hsplit', 'vsplit'): |
|
190 | if self.paging in ('hsplit', 'vsplit'): | |
188 | self._splitter = QtGui.QSplitter() |
|
191 | self._splitter = QtGui.QSplitter() | |
189 | if self.paging == 'hsplit': |
|
192 | if self.paging == 'hsplit': |
@@ -533,13 +533,15 b' class IPythonWidget(FrontendWidget):' | |||||
533 | """ Set the style sheets of the underlying widgets. |
|
533 | """ Set the style sheets of the underlying widgets. | |
534 | """ |
|
534 | """ | |
535 | self.setStyleSheet(self.style_sheet) |
|
535 | self.setStyleSheet(self.style_sheet) | |
|
536 | if self._control is not None: | |||
536 | self._control.document().setDefaultStyleSheet(self.style_sheet) |
|
537 | self._control.document().setDefaultStyleSheet(self.style_sheet) | |
537 | if self._page_control: |
|
|||
538 | self._page_control.document().setDefaultStyleSheet(self.style_sheet) |
|
|||
539 |
|
||||
540 | bg_color = self._control.palette().window().color() |
|
538 | bg_color = self._control.palette().window().color() | |
541 | self._ansi_processor.set_background_color(bg_color) |
|
539 | self._ansi_processor.set_background_color(bg_color) | |
542 |
|
540 | |||
|
541 | if self._page_control is not None: | |||
|
542 | self._page_control.document().setDefaultStyleSheet(self.style_sheet) | |||
|
543 | ||||
|
544 | ||||
543 |
|
545 | |||
544 | def _syntax_style_changed(self): |
|
546 | def _syntax_style_changed(self): | |
545 | """ Set the style for the syntax highlighter. |
|
547 | """ Set the style for the syntax highlighter. |
@@ -174,7 +174,7 b' class PygmentsHighlighter(QtGui.QSyntaxHighlighter):' | |||||
174 | def _get_format_from_document(self, token, document): |
|
174 | def _get_format_from_document(self, token, document): | |
175 | """ Returns a QTextCharFormat for token by |
|
175 | """ Returns a QTextCharFormat for token by | |
176 | """ |
|
176 | """ | |
177 | code, html = self._formatter._format_lines([(token, 'dummy')]).next() |
|
177 | code, html = self._formatter._format_lines([(token, u'dummy')]).next() | |
178 | self._document.setHtml(html) |
|
178 | self._document.setHtml(html) | |
179 | return QtGui.QTextCursor(self._document).charFormat() |
|
179 | return QtGui.QTextCursor(self._document).charFormat() | |
180 |
|
180 |
@@ -190,6 +190,7 b' class IPythonQtConsoleApp(BaseIPythonApplication, IPythonConsoleApp):' | |||||
190 | kernel_manager.start_channels() |
|
190 | kernel_manager.start_channels() | |
191 | widget = self.widget_factory(config=self.config, |
|
191 | widget = self.widget_factory(config=self.config, | |
192 | local_kernel=True) |
|
192 | local_kernel=True) | |
|
193 | self.init_colors(widget) | |||
193 | widget.kernel_manager = kernel_manager |
|
194 | widget.kernel_manager = kernel_manager | |
194 | widget._existing = False |
|
195 | widget._existing = False | |
195 | widget._may_close = True |
|
196 | widget._may_close = True | |
@@ -212,6 +213,7 b' class IPythonQtConsoleApp(BaseIPythonApplication, IPythonConsoleApp):' | |||||
212 | kernel_manager.start_channels() |
|
213 | kernel_manager.start_channels() | |
213 | widget = self.widget_factory(config=self.config, |
|
214 | widget = self.widget_factory(config=self.config, | |
214 | local_kernel=False) |
|
215 | local_kernel=False) | |
|
216 | self.init_colors(widget) | |||
215 | widget._existing = True |
|
217 | widget._existing = True | |
216 | widget._may_close = False |
|
218 | widget._may_close = False | |
217 | widget._confirm_exit = False |
|
219 | widget._confirm_exit = False | |
@@ -230,6 +232,7 b' class IPythonQtConsoleApp(BaseIPythonApplication, IPythonConsoleApp):' | |||||
230 | local_kernel = (not self.existing) or self.ip in LOCAL_IPS |
|
232 | local_kernel = (not self.existing) or self.ip in LOCAL_IPS | |
231 | self.widget = self.widget_factory(config=self.config, |
|
233 | self.widget = self.widget_factory(config=self.config, | |
232 | local_kernel=local_kernel) |
|
234 | local_kernel=local_kernel) | |
|
235 | self.init_colors(self.widget) | |||
233 | self.widget._existing = self.existing |
|
236 | self.widget._existing = self.existing | |
234 | self.widget._may_close = not self.existing |
|
237 | self.widget._may_close = not self.existing | |
235 | self.widget._confirm_exit = self.confirm_exit |
|
238 | self.widget._confirm_exit = self.confirm_exit | |
@@ -246,7 +249,7 b' class IPythonQtConsoleApp(BaseIPythonApplication, IPythonConsoleApp):' | |||||
246 |
|
249 | |||
247 | self.window.setWindowTitle('Python' if self.pure else 'IPython') |
|
250 | self.window.setWindowTitle('Python' if self.pure else 'IPython') | |
248 |
|
251 | |||
249 | def init_colors(self): |
|
252 | def init_colors(self, widget): | |
250 | """Configure the coloring of the widget""" |
|
253 | """Configure the coloring of the widget""" | |
251 | # Note: This will be dramatically simplified when colors |
|
254 | # Note: This will be dramatically simplified when colors | |
252 | # are removed from the backend. |
|
255 | # are removed from the backend. | |
@@ -264,6 +267,10 b' class IPythonQtConsoleApp(BaseIPythonApplication, IPythonConsoleApp):' | |||||
264 | style = self.config.IPythonWidget.syntax_style |
|
267 | style = self.config.IPythonWidget.syntax_style | |
265 | except AttributeError: |
|
268 | except AttributeError: | |
266 | style = None |
|
269 | style = None | |
|
270 | try: | |||
|
271 | sheet = self.config.IPythonWidget.style_sheet | |||
|
272 | except AttributeError: | |||
|
273 | sheet = None | |||
267 |
|
274 | |||
268 | # find the value for colors: |
|
275 | # find the value for colors: | |
269 | if colors: |
|
276 | if colors: | |
@@ -284,30 +291,27 b' class IPythonQtConsoleApp(BaseIPythonApplication, IPythonConsoleApp):' | |||||
284 | else: |
|
291 | else: | |
285 | colors=None |
|
292 | colors=None | |
286 |
|
293 | |||
287 |
# Configure the style |
|
294 | # Configure the style | |
288 | widget = self.widget |
|
|||
289 | if style: |
|
295 | if style: | |
290 | widget.style_sheet = styles.sheet_from_template(style, colors) |
|
296 | widget.style_sheet = styles.sheet_from_template(style, colors) | |
291 | widget.syntax_style = style |
|
297 | widget.syntax_style = style | |
292 | widget._syntax_style_changed() |
|
298 | widget._syntax_style_changed() | |
293 | widget._style_sheet_changed() |
|
299 | widget._style_sheet_changed() | |
294 | elif colors: |
|
300 | elif colors: | |
295 | # use a default style |
|
301 | # use a default dark/light/bw style | |
296 | widget.set_default_style(colors=colors) |
|
302 | widget.set_default_style(colors=colors) | |
297 | else: |
|
|||
298 | # this is redundant for now, but allows the widget's |
|
|||
299 | # defaults to change |
|
|||
300 | widget.set_default_style() |
|
|||
301 |
|
303 | |||
302 | if self.stylesheet: |
|
304 | if self.stylesheet: | |
303 | # we got an expicit stylesheet |
|
305 | # we got an explicit stylesheet | |
304 | if os.path.isfile(self.stylesheet): |
|
306 | if os.path.isfile(self.stylesheet): | |
305 | with open(self.stylesheet) as f: |
|
307 | with open(self.stylesheet) as f: | |
306 | sheet = f.read() |
|
308 | sheet = f.read() | |
307 | widget.style_sheet = sheet |
|
|||
308 | widget._style_sheet_changed() |
|
|||
309 | else: |
|
309 | else: | |
310 | raise IOError("Stylesheet %r not found."%self.stylesheet) |
|
310 | raise IOError("Stylesheet %r not found." % self.stylesheet) | |
|
311 | if sheet: | |||
|
312 | widget.style_sheet = sheet | |||
|
313 | widget._style_sheet_changed() | |||
|
314 | ||||
311 |
|
315 | |||
312 | def init_signal(self): |
|
316 | def init_signal(self): | |
313 | """allow clean shutdown on sigint""" |
|
317 | """allow clean shutdown on sigint""" | |
@@ -327,7 +331,6 b' class IPythonQtConsoleApp(BaseIPythonApplication, IPythonConsoleApp):' | |||||
327 | super(IPythonQtConsoleApp, self).initialize(argv) |
|
331 | super(IPythonQtConsoleApp, self).initialize(argv) | |
328 | IPythonConsoleApp.initialize(self,argv) |
|
332 | IPythonConsoleApp.initialize(self,argv) | |
329 | self.init_qt_elements() |
|
333 | self.init_qt_elements() | |
330 | self.init_colors() |
|
|||
331 | self.init_signal() |
|
334 | self.init_signal() | |
332 |
|
335 | |||
333 | def start(self): |
|
336 | def start(self): |
@@ -64,8 +64,8 b' def hex_to_rgb(color):' | |||||
64 | return False |
|
64 | return False | |
65 | try: |
|
65 | try: | |
66 | r = int(color[:2],16) |
|
66 | r = int(color[:2],16) | |
67 |
g = int(color[: |
|
67 | g = int(color[2:4],16) | |
68 |
b = int(color[: |
|
68 | b = int(color[4:],16) | |
69 | except ValueError: |
|
69 | except ValueError: | |
70 | return False |
|
70 | return False | |
71 | else: |
|
71 | else: |
General Comments 0
You need to be logged in to leave comments.
Login now