Mercurial > octave-nkf
comparison libgui/qterminal/libqterminal/unix/Emulation.h @ 19627:446c46af4b42 stable
strip trailing whitespace from most source files
* Makefile.am, NEWS, build-aux/common.mk, configure.ac,
doc/Makefile.am, doc/doxyhtml/Makefile.am,
doc/interpreter/Makefile.am, doc/interpreter/arith.txi,
doc/interpreter/audio.txi, doc/interpreter/basics.txi,
doc/interpreter/bugs.txi, doc/interpreter/container.txi,
doc/interpreter/cp-idx.txi, doc/interpreter/data.txi,
doc/interpreter/debug.txi, doc/interpreter/diagperm.txi,
doc/interpreter/diffeq.txi, doc/interpreter/doccheck/README,
doc/interpreter/doccheck/spellcheck, doc/interpreter/emacs.txi,
doc/interpreter/errors.txi, doc/interpreter/eval.txi,
doc/interpreter/expr.txi, doc/interpreter/external.txi,
doc/interpreter/fn-idx.txi, doc/interpreter/func.txi,
doc/interpreter/geometry.txi, doc/interpreter/geometryimages.m,
doc/interpreter/gpl.txi, doc/interpreter/grammar.txi,
doc/interpreter/gui.txi, doc/interpreter/image.txi,
doc/interpreter/install.txi, doc/interpreter/interp.txi,
doc/interpreter/interpimages.m, doc/interpreter/intro.txi,
doc/interpreter/io.txi, doc/interpreter/java.txi,
doc/interpreter/linalg.txi, doc/interpreter/macros.texi,
doc/interpreter/matrix.txi, doc/interpreter/munge-texi.pl,
doc/interpreter/nonlin.txi, doc/interpreter/numbers.txi,
doc/interpreter/obsolete.txi, doc/interpreter/octave-config.1,
doc/interpreter/octave.texi, doc/interpreter/oop.txi,
doc/interpreter/op-idx.txi, doc/interpreter/optim.txi,
doc/interpreter/package.txi, doc/interpreter/plot.txi,
doc/interpreter/poly.txi, doc/interpreter/preface.txi,
doc/interpreter/quad.txi, doc/interpreter/set.txi,
doc/interpreter/signal.txi, doc/interpreter/sparse.txi,
doc/interpreter/sparseimages.m, doc/interpreter/splineimages.m,
doc/interpreter/stats.txi, doc/interpreter/stmt.txi,
doc/interpreter/strings.txi, doc/interpreter/system.txi,
doc/interpreter/testfun.txi, doc/interpreter/tips.txi,
doc/interpreter/var.txi, doc/interpreter/vectorize.txi,
doc/liboctave/Makefile.am, doc/liboctave/array.texi,
doc/liboctave/bugs.texi, doc/liboctave/cp-idx.texi,
doc/liboctave/dae.texi, doc/liboctave/diffeq.texi,
doc/liboctave/error.texi, doc/liboctave/factor.texi,
doc/liboctave/fn-idx.texi, doc/liboctave/gpl.texi,
doc/liboctave/install.texi, doc/liboctave/intro.texi,
doc/liboctave/liboctave.texi, doc/liboctave/matvec.texi,
doc/liboctave/nleqn.texi, doc/liboctave/nlfunc.texi,
doc/liboctave/ode.texi, doc/liboctave/optim.texi,
doc/liboctave/preface.texi, doc/liboctave/quad.texi,
doc/liboctave/range.texi, doc/refcard/Makefile.am,
doc/refcard/refcard.tex, etc/HACKING, etc/NEWS.1, etc/NEWS.2,
etc/NEWS.3, etc/OLD-ChangeLogs/ChangeLog,
etc/OLD-ChangeLogs/doc-ChangeLog,
etc/OLD-ChangeLogs/scripts-ChangeLog,
etc/OLD-ChangeLogs/src-ChangeLog, etc/OLD-ChangeLogs/test-ChangeLog,
etc/PROJECTS, etc/README.Cygwin, etc/README.MacOS, etc/README.MinGW,
etc/README.gnuplot, etc/gdbinit, etc/icons/Makefile.am,
examples/@polynomial/end.m, examples/@polynomial/subsasgn.m,
examples/Makefile.am, examples/standalonebuiltin.cc,
libgui/Makefile.am, libgui/qterminal/libqterminal/README,
libgui/qterminal/libqterminal/unix/BlockArray.cpp,
libgui/qterminal/libqterminal/unix/BlockArray.h,
libgui/qterminal/libqterminal/unix/Character.h,
libgui/qterminal/libqterminal/unix/CharacterColor.h,
libgui/qterminal/libqterminal/unix/Emulation.cpp,
libgui/qterminal/libqterminal/unix/Emulation.h,
libgui/qterminal/libqterminal/unix/Filter.cpp,
libgui/qterminal/libqterminal/unix/Filter.h,
libgui/qterminal/libqterminal/unix/History.cpp,
libgui/qterminal/libqterminal/unix/History.h,
libgui/qterminal/libqterminal/unix/KeyboardTranslator.cpp,
libgui/qterminal/libqterminal/unix/KeyboardTranslator.h,
libgui/qterminal/libqterminal/unix/LineFont.h,
libgui/qterminal/libqterminal/unix/QUnixTerminalImpl.cpp,
libgui/qterminal/libqterminal/unix/QUnixTerminalImpl.h,
libgui/qterminal/libqterminal/unix/Screen.cpp,
libgui/qterminal/libqterminal/unix/Screen.h,
libgui/qterminal/libqterminal/unix/ScreenWindow.cpp,
libgui/qterminal/libqterminal/unix/ScreenWindow.h,
libgui/qterminal/libqterminal/unix/TerminalCharacterDecoder.cpp,
libgui/qterminal/libqterminal/unix/TerminalCharacterDecoder.h,
libgui/qterminal/libqterminal/unix/Vt102Emulation.h,
libgui/qterminal/libqterminal/win32/QWinTerminalImpl.cpp,
libgui/qterminal/qterminal/main.cpp,
libgui/src/m-editor/file-editor-tab.cc, libgui/src/octave-gui.cc,
libgui/src/octave-qt-link.cc, libinterp/corefcn/data.cc,
libinterp/corefcn/defun-int.h, libinterp/corefcn/det.cc,
libinterp/corefcn/gl2ps-renderer.cc, libinterp/corefcn/graphics.cc,
libinterp/corefcn/graphics.in.h, libinterp/corefcn/ls-mat5.cc,
libinterp/corefcn/lu.cc, libinterp/corefcn/oct-tex-parser.yy,
libinterp/corefcn/oct-tex-symbols.in, libinterp/corefcn/quadcc.cc,
libinterp/corefcn/zfstream.cc, libinterp/dldfcn/__eigs__.cc,
libinterp/dldfcn/__voronoi__.cc, libinterp/gendoc.pl,
libinterp/genprops.awk, libinterp/mk-errno-list, libinterp/mk-pkg-add,
libinterp/mkbuiltins, libinterp/mkdefs, libinterp/mkdocs,
libinterp/mkops, libinterp/octave-value/ov-java.cc,
libinterp/parse-tree/lex.ll, libinterp/parse-tree/oct-parse.in.yy,
libinterp/parse-tree/octave.gperf, liboctave/Makefile.am,
liboctave/array/Array.cc, liboctave/array/module.mk,
liboctave/cruft/daspk/datv.f, liboctave/cruft/daspk/dcnst0.f,
liboctave/cruft/daspk/dcnstr.f, liboctave/cruft/daspk/ddasic.f,
liboctave/cruft/daspk/ddasid.f, liboctave/cruft/daspk/ddasik.f,
liboctave/cruft/daspk/ddaspk.f, liboctave/cruft/daspk/ddstp.f,
liboctave/cruft/daspk/ddwnrm.f, liboctave/cruft/daspk/dfnrmd.f,
liboctave/cruft/daspk/dfnrmk.f, liboctave/cruft/daspk/dhels.f,
liboctave/cruft/daspk/dheqr.f, liboctave/cruft/daspk/dinvwt.f,
liboctave/cruft/daspk/dlinsd.f, liboctave/cruft/daspk/dlinsk.f,
liboctave/cruft/daspk/dmatd.f, liboctave/cruft/daspk/dnedd.f,
liboctave/cruft/daspk/dnedk.f, liboctave/cruft/daspk/dnsd.f,
liboctave/cruft/daspk/dnsid.f, liboctave/cruft/daspk/dnsik.f,
liboctave/cruft/daspk/dnsk.f, liboctave/cruft/daspk/dorth.f,
liboctave/cruft/daspk/dslvd.f, liboctave/cruft/daspk/dslvk.f,
liboctave/cruft/daspk/dspigm.f, liboctave/cruft/daspk/dyypnw.f,
liboctave/cruft/dasrt/ddasrt.f, liboctave/cruft/dasrt/drchek.f,
liboctave/cruft/dassl/ddaslv.f, liboctave/cruft/dassl/ddassl.f,
liboctave/cruft/misc/blaswrap.c, liboctave/cruft/misc/module.mk,
liboctave/cruft/odepack/cfode.f, liboctave/cruft/odepack/dlsode.f,
liboctave/cruft/odepack/ewset.f, liboctave/cruft/odepack/intdy.f,
liboctave/cruft/odepack/prepj.f, liboctave/cruft/odepack/sintdy.f,
liboctave/cruft/odepack/slsode.f, liboctave/cruft/odepack/solsy.f,
liboctave/cruft/odepack/ssolsy.f, liboctave/cruft/odepack/stode.f,
liboctave/cruft/odepack/vnorm.f, liboctave/cruft/ranlib/Basegen.doc,
liboctave/cruft/ranlib/README, liboctave/cruft/ranlib/genbet.f,
liboctave/cruft/ranlib/genexp.f, liboctave/cruft/ranlib/gennch.f,
liboctave/cruft/ranlib/gennf.f, liboctave/cruft/ranlib/gennor.f,
liboctave/cruft/ranlib/getsd.f, liboctave/cruft/ranlib/initgn.f,
liboctave/cruft/ranlib/phrtsd.f, liboctave/cruft/ranlib/randlib.fdoc,
liboctave/cruft/ranlib/setsd.f, liboctave/cruft/ranlib/tstgmn.for,
liboctave/cruft/ranlib/tstmid.for, liboctave/cruft/slatec-fn/atanh.f,
liboctave/cruft/slatec-fn/datanh.f,
liboctave/cruft/slatec-fn/xgmainc.f,
liboctave/cruft/slatec-fn/xsgmainc.f, liboctave/numeric/module.mk,
liboctave/operators/mk-ops.awk, liboctave/operators/mx-ops,
liboctave/operators/sparse-mk-ops.awk,
liboctave/operators/sparse-mx-ops, liboctave/operators/vx-ops,
liboctave/util/module.mk, run-octave.in, scripts/@ftp/ftp.m,
scripts/audio/wavread.m, scripts/deprecated/java_convert_matrix.m,
scripts/deprecated/java_debug.m, scripts/deprecated/java_invoke.m,
scripts/deprecated/java_new.m,
scripts/deprecated/java_unsigned_conversion.m,
scripts/deprecated/javafields.m, scripts/deprecated/javamethods.m,
scripts/deprecated/shell_cmd.m, scripts/general/accumarray.m,
scripts/general/display.m, scripts/general/fieldnames.m,
scripts/general/interp1.m, scripts/general/interp2.m,
scripts/general/interp3.m, scripts/general/isa.m,
scripts/general/methods.m, scripts/general/sortrows.m,
scripts/geometry/convhull.m, scripts/geometry/delaunay.m,
scripts/geometry/delaunay3.m, scripts/geometry/delaunayn.m,
scripts/geometry/griddata.m, scripts/geometry/griddatan.m,
scripts/geometry/voronoi.m, scripts/geometry/voronoin.m,
scripts/gui/guihandles.m, scripts/gui/inputdlg.m,
scripts/gui/listdlg.m, scripts/gui/msgbox.m, scripts/gui/questdlg.m,
scripts/gui/uigetfile.m, scripts/gui/waitbar.m, scripts/gui/warndlg.m,
scripts/help/doc.m, scripts/help/help.m, scripts/help/type.m,
scripts/image/bone.m, scripts/image/cmpermute.m,
scripts/image/cmunique.m, scripts/image/colorcube.m,
scripts/image/colormap.m, scripts/image/contrast.m,
scripts/image/gray2ind.m, scripts/image/image.m,
scripts/image/imshow.m, scripts/image/ind2gray.m, scripts/image/jet.m,
scripts/image/rgb2ntsc.m, scripts/image/spinmap.m,
scripts/io/importdata.m, scripts/io/strread.m, scripts/io/textread.m,
scripts/io/textscan.m, scripts/java/java_get.m,
scripts/java/java_set.m, scripts/java/javaaddpath.m,
scripts/java/javaclasspath.m, scripts/java/javamem.m,
scripts/linear-algebra/linsolve.m, scripts/linear-algebra/qzhess.m,
scripts/miscellaneous/debug.m, scripts/miscellaneous/desktop.m,
scripts/miscellaneous/dir.m, scripts/miscellaneous/dos.m,
scripts/miscellaneous/edit.m, scripts/miscellaneous/fact.m,
scripts/miscellaneous/getappdata.m, scripts/miscellaneous/inputname.m,
scripts/miscellaneous/license.m, scripts/miscellaneous/ls_command.m,
scripts/miscellaneous/run.m, scripts/miscellaneous/setfield.m,
scripts/miscellaneous/unix.m, scripts/miscellaneous/ver.m,
scripts/mk-pkg-add, scripts/mkdoc.pl,
scripts/optimization/fminsearch.m, scripts/optimization/optimset.m,
scripts/optimization/sqp.m, scripts/pkg/pkg.m,
scripts/pkg/private/create_pkgadddel.m,
scripts/pkg/private/fix_depends.m, scripts/pkg/private/install.m,
scripts/plot/appearance/axis.m, scripts/plot/appearance/box.m,
scripts/plot/appearance/clabel.m, scripts/plot/appearance/daspect.m,
scripts/plot/appearance/datetick.m, scripts/plot/appearance/grid.m,
scripts/plot/appearance/legend.m, scripts/plot/appearance/orient.m,
scripts/plot/appearance/shading.m, scripts/plot/appearance/text.m,
scripts/plot/appearance/title.m, scripts/plot/appearance/xlabel.m,
scripts/plot/appearance/ylabel.m, scripts/plot/appearance/zlabel.m,
scripts/plot/draw/area.m, scripts/plot/draw/bar.m,
scripts/plot/draw/barh.m, scripts/plot/draw/colorbar.m,
scripts/plot/draw/contour.m, scripts/plot/draw/contour3.m,
scripts/plot/draw/contourf.m, scripts/plot/draw/ellipsoid.m,
scripts/plot/draw/errorbar.m, scripts/plot/draw/ezcontour.m,
scripts/plot/draw/ezcontourf.m, scripts/plot/draw/ezmesh.m,
scripts/plot/draw/ezpolar.m, scripts/plot/draw/fill.m,
scripts/plot/draw/fplot.m, scripts/plot/draw/hist.m,
scripts/plot/draw/meshc.m, scripts/plot/draw/meshz.m,
scripts/plot/draw/pareto.m, scripts/plot/draw/patch.m,
scripts/plot/draw/peaks.m, scripts/plot/draw/pie.m,
scripts/plot/draw/pie3.m, scripts/plot/draw/plot.m,
scripts/plot/draw/plotyy.m, scripts/plot/draw/private/__bar__.m,
scripts/plot/draw/private/__contour__.m,
scripts/plot/draw/private/__errplot__.m,
scripts/plot/draw/private/__ezplot__.m,
scripts/plot/draw/private/__patch__.m,
scripts/plot/draw/private/__stem__.m, scripts/plot/draw/rectangle.m,
scripts/plot/draw/ribbon.m, scripts/plot/draw/rose.m,
scripts/plot/draw/scatter.m, scripts/plot/draw/scatter3.m,
scripts/plot/draw/semilogx.m, scripts/plot/draw/shrinkfaces.m,
scripts/plot/draw/sombrero.m, scripts/plot/draw/sphere.m,
scripts/plot/draw/stairs.m, scripts/plot/draw/stem.m,
scripts/plot/draw/stemleaf.m, scripts/plot/draw/surf.m,
scripts/plot/draw/surface.m, scripts/plot/draw/surfc.m,
scripts/plot/draw/surfl.m, scripts/plot/draw/surfnorm.m,
scripts/plot/draw/tetramesh.m, scripts/plot/draw/trimesh.m,
scripts/plot/draw/triplot.m, scripts/plot/draw/trisurf.m,
scripts/plot/util/__gnuplot_drawnow__.m,
scripts/plot/util/__plt_get_axis_arg__.m, scripts/plot/util/axes.m,
scripts/plot/util/clf.m, scripts/plot/util/copyobj.m,
scripts/plot/util/figure.m, scripts/plot/util/gcbo.m,
scripts/plot/util/graphics_toolkit.m, scripts/plot/util/hggroup.m,
scripts/plot/util/meshgrid.m, scripts/plot/util/newplot.m,
scripts/plot/util/print.m,
scripts/plot/util/private/__add_default_menu__.m,
scripts/plot/util/private/__fltk_print__.m,
scripts/plot/util/private/__gnuplot_print__.m,
scripts/plot/util/private/__print_parse_opts__.m,
scripts/plot/util/refreshdata.m, scripts/plot/util/subplot.m,
scripts/polynomial/conv.m, scripts/polynomial/poly.m,
scripts/polynomial/polyeig.m, scripts/polynomial/polyfit.m,
scripts/polynomial/polyval.m,
scripts/polynomial/private/__splinefit__.m,
scripts/polynomial/spline.m, scripts/prefs/prefdir.m,
scripts/prefs/preferences.m, scripts/prefs/private/prefsfile.m,
scripts/prefs/rmpref.m, scripts/signal/freqz.m,
scripts/signal/module.mk, scripts/sparse/eigs.m, scripts/sparse/pcg.m,
scripts/sparse/private/__sprand_impl__.m, scripts/sparse/sprand.m,
scripts/sparse/sprandn.m, scripts/sparse/spy.m, scripts/sparse/svds.m,
scripts/specfun/expint.m, scripts/specfun/factor.m,
scripts/special-matrix/gallery.m, scripts/special-matrix/hankel.m,
scripts/special-matrix/toeplitz.m, scripts/startup/inputrc,
scripts/statistics/base/kurtosis.m, scripts/statistics/base/moment.m,
scripts/statistics/base/qqplot.m, scripts/statistics/base/var.m,
scripts/statistics/distributions/betarnd.m,
scripts/statistics/distributions/binoinv.m,
scripts/statistics/distributions/binopdf.m,
scripts/statistics/distributions/binornd.m,
scripts/statistics/distributions/cauchy_rnd.m,
scripts/statistics/distributions/chi2rnd.m,
scripts/statistics/distributions/discrete_pdf.m,
scripts/statistics/distributions/discrete_rnd.m,
scripts/statistics/distributions/empirical_rnd.m,
scripts/statistics/distributions/exprnd.m,
scripts/statistics/distributions/frnd.m,
scripts/statistics/distributions/gamrnd.m,
scripts/statistics/distributions/geornd.m,
scripts/statistics/distributions/hygernd.m,
scripts/statistics/distributions/kolmogorov_smirnov_cdf.m,
scripts/statistics/distributions/laplace_cdf.m,
scripts/statistics/distributions/laplace_pdf.m,
scripts/statistics/distributions/logistic_cdf.m,
scripts/statistics/distributions/logistic_pdf.m,
scripts/statistics/distributions/lognrnd.m,
scripts/statistics/distributions/nbincdf.m,
scripts/statistics/distributions/nbininv.m,
scripts/statistics/distributions/nbinpdf.m,
scripts/statistics/distributions/nbinrnd.m,
scripts/statistics/distributions/normrnd.m,
scripts/statistics/distributions/poissinv.m,
scripts/statistics/distributions/poissrnd.m,
scripts/statistics/distributions/tinv.m,
scripts/statistics/distributions/trnd.m,
scripts/statistics/distributions/unidcdf.m,
scripts/statistics/distributions/unidpdf.m,
scripts/statistics/distributions/unidrnd.m,
scripts/statistics/distributions/unifrnd.m,
scripts/statistics/distributions/wblrnd.m,
scripts/statistics/models/module.mk,
scripts/statistics/tests/kruskal_wallis_test.m,
scripts/strings/base2dec.m, scripts/strings/deblank.m,
scripts/strings/dec2base.m, scripts/strings/dec2bin.m,
scripts/strings/dec2hex.m, scripts/strings/mat2str.m,
scripts/strings/ostrsplit.m, scripts/strings/regexptranslate.m,
scripts/strings/str2num.m, scripts/strings/strcat.m,
scripts/strings/strjoin.m, scripts/strings/strsplit.m,
scripts/strings/strtok.m, scripts/strings/strtrim.m,
scripts/strings/strtrunc.m, scripts/strings/substr.m,
scripts/testfun/__run_test_suite__.m, scripts/testfun/speed.m,
scripts/testfun/test.m, scripts/time/asctime.m,
scripts/time/datenum.m, scripts/time/datevec.m,
scripts/time/weekday.m, src/Makefile.am, test/Makefile.am,
test/build-bc-overload-tests.sh, test/build-sparse-tests.sh,
test/jit.tst, test/line-continue.tst: Strip trailing whitespace.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Tue, 20 Jan 2015 08:26:57 -0500 |
parents | 2de613986374 |
children |
comparison
equal
deleted
inserted
replaced
19488:8dbd55742112 | 19627:446c46af4b42 |
---|---|
1 /* | 1 /* |
2 This file is part of Konsole, an X terminal. | 2 This file is part of Konsole, an X terminal. |
3 | 3 |
4 Copyright (C) 2007, 2013 by Robert Knight <robertknight@gmail.com> | 4 Copyright (C) 2007, 2013 by Robert Knight <robertknight@gmail.com> |
5 Copyright (C) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> | 5 Copyright (C) 1997,1998 by Lars Doelle <lars.doelle@on-line.de> |
6 | 6 |
7 Rewritten for QT4 by e_k <e_k at users.sourceforge.net>, Copyright (C)2008 | 7 Rewritten for QT4 by e_k <e_k at users.sourceforge.net>, Copyright (C)2008 |
8 | 8 |
26 #define EMULATION_H | 26 #define EMULATION_H |
27 | 27 |
28 // System | 28 // System |
29 #include <stdio.h> | 29 #include <stdio.h> |
30 | 30 |
31 // Qt | 31 // Qt |
32 #include <QKeyEvent> | 32 #include <QKeyEvent> |
33 | 33 |
34 #include <QtCore/QTextCodec> | 34 #include <QtCore/QTextCodec> |
35 #include <QtCore/QTextStream> | 35 #include <QtCore/QTextStream> |
36 #include <QtCore/QTimer> | 36 #include <QtCore/QTimer> |
39 class HistoryType; | 39 class HistoryType; |
40 class Screen; | 40 class Screen; |
41 class ScreenWindow; | 41 class ScreenWindow; |
42 class TerminalCharacterDecoder; | 42 class TerminalCharacterDecoder; |
43 | 43 |
44 /** | 44 /** |
45 * This enum describes the available states which | 45 * This enum describes the available states which |
46 * the terminal emulation may be set to. | 46 * the terminal emulation may be set to. |
47 * | 47 * |
48 * These are the values used by Emulation::stateChanged() | 48 * These are the values used by Emulation::stateChanged() |
49 */ | 49 */ |
50 enum | 50 enum |
51 { | 51 { |
52 /** The emulation is currently receiving user input. */ | 52 /** The emulation is currently receiving user input. */ |
53 NOTIFYNORMAL=0, | 53 NOTIFYNORMAL=0, |
54 /** | 54 /** |
55 * The terminal program has triggered a bell event | 55 * The terminal program has triggered a bell event |
56 * to get the user's attention. | 56 * to get the user's attention. |
57 */ | 57 */ |
58 NOTIFYBELL=1, | 58 NOTIFYBELL=1, |
59 /** | 59 /** |
60 * The emulation is currently receiving data from its | 60 * The emulation is currently receiving data from its |
61 * terminal input. | 61 * terminal input. |
62 */ | 62 */ |
63 NOTIFYACTIVITY=2, | 63 NOTIFYACTIVITY=2, |
64 | 64 |
65 // unused here? | 65 // unused here? |
66 NOTIFYSILENCE=3 | 66 NOTIFYSILENCE=3 |
67 }; | 67 }; |
68 | 68 |
69 /** | 69 /** |
70 * Base class for terminal emulation back-ends. | 70 * Base class for terminal emulation back-ends. |
71 * | 71 * |
72 * The back-end is responsible for decoding an incoming character stream and | 72 * The back-end is responsible for decoding an incoming character stream and |
73 * producing an output image of characters. | 73 * producing an output image of characters. |
74 * | 74 * |
75 * When input from the terminal is received, the receiveData() slot should be called with | 75 * When input from the terminal is received, the receiveData() slot should be called with |
76 * the data which has arrived. The emulation will process the data and update the | 76 * the data which has arrived. The emulation will process the data and update the |
77 * screen image accordingly. The codec used to decode the incoming character stream | 77 * screen image accordingly. The codec used to decode the incoming character stream |
78 * into the unicode characters used internally can be specified using setCodec() | 78 * into the unicode characters used internally can be specified using setCodec() |
79 * | 79 * |
80 * The size of the screen image can be specified by calling setImageSize() with the | 80 * The size of the screen image can be specified by calling setImageSize() with the |
81 * desired number of lines and columns. When new lines are added, old content | 81 * desired number of lines and columns. When new lines are added, old content |
82 * is moved into a history store, which can be set by calling setHistory(). | 82 * is moved into a history store, which can be set by calling setHistory(). |
83 * | 83 * |
84 * The screen image can be accessed by creating a ScreenWindow onto this emulation | 84 * The screen image can be accessed by creating a ScreenWindow onto this emulation |
85 * by calling createWindow(). Screen windows provide access to a section of the | 85 * by calling createWindow(). Screen windows provide access to a section of the |
86 * output. Each screen window covers the same number of lines and columns as the | 86 * output. Each screen window covers the same number of lines and columns as the |
87 * image size returned by imageSize(). The screen window can be moved up and down | 87 * image size returned by imageSize(). The screen window can be moved up and down |
88 * and provides transparent access to both the current on-screen image and the | 88 * and provides transparent access to both the current on-screen image and the |
89 * previous output. The screen windows emit an outputChanged signal | 89 * previous output. The screen windows emit an outputChanged signal |
90 * when the section of the image they are looking at changes. | 90 * when the section of the image they are looking at changes. |
91 * Graphical views can then render the contents of a screen window, listening for notifications | 91 * Graphical views can then render the contents of a screen window, listening for notifications |
92 * of output changes from the screen window which they are associated with and updating | 92 * of output changes from the screen window which they are associated with and updating |
93 * accordingly. | 93 * accordingly. |
94 * | 94 * |
95 * The emulation also is also responsible for converting input from the connected views such | 95 * The emulation also is also responsible for converting input from the connected views such |
96 * as keypresses and mouse activity into a character string which can be sent | 96 * as keypresses and mouse activity into a character string which can be sent |
97 * to the terminal program. Key presses can be processed by calling the sendKeyEvent() slot, | 97 * to the terminal program. Key presses can be processed by calling the sendKeyEvent() slot, |
98 * while mouse events can be processed using the sendMouseEvent() slot. When the character | 98 * while mouse events can be processed using the sendMouseEvent() slot. When the character |
101 * process. The translation of key presses into an output character stream is performed | 101 * process. The translation of key presses into an output character stream is performed |
102 * using a lookup in a set of key bindings which map key sequences to output | 102 * using a lookup in a set of key bindings which map key sequences to output |
103 * character sequences. The name of the key bindings set used can be specified using | 103 * character sequences. The name of the key bindings set used can be specified using |
104 * setKeyBindings() | 104 * setKeyBindings() |
105 * | 105 * |
106 * The emulation maintains certain state information which changes depending on the | 106 * The emulation maintains certain state information which changes depending on the |
107 * input received. The emulation can be reset back to its starting state by calling | 107 * input received. The emulation can be reset back to its starting state by calling |
108 * reset(). | 108 * reset(). |
109 * | 109 * |
110 * The emulation also maintains an activity state, which specifies whether | 110 * The emulation also maintains an activity state, which specifies whether |
111 * terminal is currently active ( when data is received ), normal | 111 * terminal is currently active ( when data is received ), normal |
112 * ( when the terminal is idle or receiving user input ) or trying | 112 * ( when the terminal is idle or receiving user input ) or trying |
113 * to alert the user ( also known as a "Bell" event ). The stateSet() signal | 113 * to alert the user ( also known as a "Bell" event ). The stateSet() signal |
114 * is emitted whenever the activity state is set. This can be used to determine | 114 * is emitted whenever the activity state is set. This can be used to determine |
115 * how long the emulation has been active/idle for and also respond to | 115 * how long the emulation has been active/idle for and also respond to |
116 * a 'bell' event in different ways. | 116 * a 'bell' event in different ways. |
117 */ | 117 */ |
118 class Emulation : public QObject | 118 class Emulation : public QObject |
119 { | 119 { |
120 Q_OBJECT | 120 Q_OBJECT |
121 | 121 |
122 public: | 122 public: |
123 | 123 |
124 /** Constructs a new terminal emulation */ | 124 /** Constructs a new terminal emulation */ |
125 Emulation(); | 125 Emulation(); |
126 ~Emulation(); | 126 ~Emulation(); |
127 | 127 |
128 /** | 128 /** |
129 * Creates a new window onto the output from this emulation. The contents | 129 * Creates a new window onto the output from this emulation. The contents |
135 /** Returns the size of the screen image which the emulation produces */ | 135 /** Returns the size of the screen image which the emulation produces */ |
136 QSize imageSize(); | 136 QSize imageSize(); |
137 | 137 |
138 /** | 138 /** |
139 * Returns the total number of lines, including those stored in the history. | 139 * Returns the total number of lines, including those stored in the history. |
140 */ | 140 */ |
141 int lineCount(); | 141 int lineCount(); |
142 | 142 |
143 | 143 |
144 /** | 144 /** |
145 * Sets the history store used by this emulation. When new lines | 145 * Sets the history store used by this emulation. When new lines |
146 * are added to the output, older lines at the top of the screen are transferred to a history | 146 * are added to the output, older lines at the top of the screen are transferred to a history |
147 * store. | 147 * store. |
148 * | 148 * |
149 * The number of lines which are kept and the storage location depend on the | 149 * The number of lines which are kept and the storage location depend on the |
150 * type of store. | 150 * type of store. |
151 */ | 151 */ |
152 void setHistory(const HistoryType&); | 152 void setHistory(const HistoryType&); |
153 /** Returns the history store used by this emulation. See setHistory() */ | 153 /** Returns the history store used by this emulation. See setHistory() */ |
154 const HistoryType& history(); | 154 const HistoryType& history(); |
155 /** Clears the history scroll. */ | 155 /** Clears the history scroll. */ |
156 void clearHistory(); | 156 void clearHistory(); |
157 | 157 |
158 /** | 158 /** |
159 * Copies the output history from @p startLine to @p endLine | 159 * Copies the output history from @p startLine to @p endLine |
160 * into @p stream, using @p decoder to convert the terminal | 160 * into @p stream, using @p decoder to convert the terminal |
161 * characters into text. | 161 * characters into text. |
162 * | 162 * |
163 * @param decoder A decoder which converts lines of terminal characters with | 163 * @param decoder A decoder which converts lines of terminal characters with |
164 * appearance attributes into output text. PlainTextDecoder is the most commonly | 164 * appearance attributes into output text. PlainTextDecoder is the most commonly |
165 * used decoder. | 165 * used decoder. |
166 * @param startLine The first | 166 * @param startLine The first |
167 */ | 167 */ |
168 virtual void writeToStream(TerminalCharacterDecoder* decoder,int startLine,int endLine); | 168 virtual void writeToStream(TerminalCharacterDecoder* decoder,int startLine,int endLine); |
169 | 169 |
170 | 170 |
171 /** Returns the codec used to decode incoming characters. See setCodec() */ | 171 /** Returns the codec used to decode incoming characters. See setCodec() */ |
172 const QTextCodec* codec() { return _codec; } | 172 const QTextCodec* codec() { return _codec; } |
173 /** Sets the codec used to decode incoming characters. */ | 173 /** Sets the codec used to decode incoming characters. */ |
174 void setCodec(const QTextCodec*); | 174 void setCodec(const QTextCodec*); |
175 | 175 |
176 /** | 176 /** |
177 * Convenience method. | 177 * Convenience method. |
178 * Returns true if the current codec used to decode incoming | 178 * Returns true if the current codec used to decode incoming |
179 * characters is UTF-8 | 179 * characters is UTF-8 |
180 */ | 180 */ |
181 bool utf8() { Q_ASSERT(_codec); return _codec->mibEnum() == 106; } | 181 bool utf8() { Q_ASSERT(_codec); return _codec->mibEnum() == 106; } |
182 | 182 |
183 | 183 |
184 /** TODO Document me */ | 184 /** TODO Document me */ |
185 virtual char getErase() const; | 185 virtual char getErase() const; |
186 | 186 |
187 /** | 187 /** |
188 * Sets the key bindings used to key events | 188 * Sets the key bindings used to key events |
189 * ( received through sendKeyEvent() ) into character | 189 * ( received through sendKeyEvent() ) into character |
190 * streams to send to the terminal. | 190 * streams to send to the terminal. |
191 */ | 191 */ |
192 void setKeyBindings(const QString& name); | 192 void setKeyBindings(const QString& name); |
193 /** | 193 /** |
194 * Returns the name of the emulation's current key bindings. | 194 * Returns the name of the emulation's current key bindings. |
195 * See setKeyBindings() | 195 * See setKeyBindings() |
196 */ | 196 */ |
197 QString keyBindings(); | 197 QString keyBindings(); |
198 | 198 |
199 /** | 199 /** |
200 * Copies the current image into the history and clears the screen. | 200 * Copies the current image into the history and clears the screen. |
201 */ | 201 */ |
202 virtual void clearEntireScreen() =0; | 202 virtual void clearEntireScreen() =0; |
203 | 203 |
204 /** Resets the state of the terminal. */ | 204 /** Resets the state of the terminal. */ |
205 virtual void reset() =0; | 205 virtual void reset() =0; |
206 | 206 |
207 /** | 207 /** |
208 * Returns true if the active terminal program wants | 208 * Returns true if the active terminal program wants |
209 * mouse input events. | 209 * mouse input events. |
210 * | 210 * |
211 * The programUsesMouseChanged() signal is emitted when this | 211 * The programUsesMouseChanged() signal is emitted when this |
212 * changes. | 212 * changes. |
213 */ | 213 */ |
214 bool programUsesMouse() const; | 214 bool programUsesMouse() const; |
215 | 215 |
216 public slots: | 216 public slots: |
217 | 217 |
218 /** Change the size of the emulation's image */ | 218 /** Change the size of the emulation's image */ |
219 virtual void setImageSize(int lines, int columns); | 219 virtual void setImageSize(int lines, int columns); |
220 | 220 |
221 /** | 221 /** |
222 * Interprets a sequence of characters and sends the result to the terminal. | 222 * Interprets a sequence of characters and sends the result to the terminal. |
223 * This is equivalent to calling sendKeyEvent() for each character in @p text in succession. | 223 * This is equivalent to calling sendKeyEvent() for each character in @p text in succession. |
224 */ | 224 */ |
225 virtual void sendText(const QString& text) = 0; | 225 virtual void sendText(const QString& text) = 0; |
226 | 226 |
227 /** | 227 /** |
228 * Interprets a key press event and emits the sendData() signal with | 228 * Interprets a key press event and emits the sendData() signal with |
229 * the resulting character stream. | 229 * the resulting character stream. |
230 */ | 230 */ |
231 virtual void sendKeyEvent(QKeyEvent*); | 231 virtual void sendKeyEvent(QKeyEvent*); |
232 | 232 |
233 /** | 233 /** |
234 * Converts information about a mouse event into an xterm-compatible escape | 234 * Converts information about a mouse event into an xterm-compatible escape |
235 * sequence and emits the character sequence via sendData() | 235 * sequence and emits the character sequence via sendData() |
236 */ | 236 */ |
237 virtual void sendMouseEvent(int buttons, int column, int line, int eventType); | 237 virtual void sendMouseEvent(int buttons, int column, int line, int eventType); |
238 | 238 |
239 /** | 239 /** |
240 * Sends a string of characters to the foreground terminal process. | 240 * Sends a string of characters to the foreground terminal process. |
241 * | 241 * |
242 * @param string The characters to send. | 242 * @param string The characters to send. |
243 * @param length Length of @p string or if set to a negative value, @p string will | 243 * @param length Length of @p string or if set to a negative value, @p string will |
244 * be treated as a null-terminated string and its length will be determined automatically. | 244 * be treated as a null-terminated string and its length will be determined automatically. |
245 */ | 245 */ |
246 virtual void sendString(const char* string, int length = -1) = 0; | 246 virtual void sendString(const char* string, int length = -1) = 0; |
247 | 247 |
248 /** | 248 /** |
249 * Processes an incoming stream of characters. receiveData() decodes the incoming | 249 * Processes an incoming stream of characters. receiveData() decodes the incoming |
250 * character buffer using the current codec(), and then calls receiveChar() for | 250 * character buffer using the current codec(), and then calls receiveChar() for |
251 * each unicode character in the resulting buffer. | 251 * each unicode character in the resulting buffer. |
252 * | 252 * |
253 * receiveData() also starts a timer which causes the outputChanged() signal | 253 * receiveData() also starts a timer which causes the outputChanged() signal |
254 * to be emitted when it expires. The timer allows multiple updates in quick | 254 * to be emitted when it expires. The timer allows multiple updates in quick |
255 * succession to be buffered into a single outputChanged() signal emission. | 255 * succession to be buffered into a single outputChanged() signal emission. |
256 * | 256 * |
259 */ | 259 */ |
260 void receiveData(const char* buffer,int len); | 260 void receiveData(const char* buffer,int len); |
261 | 261 |
262 signals: | 262 signals: |
263 | 263 |
264 /** | 264 /** |
265 * Emitted when a buffer of data is ready to send to the | 265 * Emitted when a buffer of data is ready to send to the |
266 * standard input of the terminal. | 266 * standard input of the terminal. |
267 * | 267 * |
268 * @param data The buffer of data ready to be sent | 268 * @param data The buffer of data ready to be sent |
269 * @paran len The length of @p data in bytes | 269 * @paran len The length of @p data in bytes |
270 */ | 270 */ |
271 void sendData(const char* data,int len); | 271 void sendData(const char* data,int len); |
272 | 272 |
273 /** | 273 /** |
274 * Requests that sending of input to the emulation | 274 * Requests that sending of input to the emulation |
275 * from the terminal process be suspended or resumed. | 275 * from the terminal process be suspended or resumed. |
276 * | 276 * |
277 * @param suspend If true, requests that sending of | 277 * @param suspend If true, requests that sending of |
278 * input from the terminal process' stdout be | 278 * input from the terminal process' stdout be |
279 * suspended. Otherwise requests that sending of | 279 * suspended. Otherwise requests that sending of |
280 * input be resumed. | 280 * input be resumed. |
281 */ | 281 */ |
282 void lockPtyRequest(bool suspend); | 282 void lockPtyRequest(bool suspend); |
283 | 283 |
284 /** | 284 /** |
285 * Requests that the pty used by the terminal process | 285 * Requests that the pty used by the terminal process |
286 * be set to UTF 8 mode. | 286 * be set to UTF 8 mode. |
287 * | 287 * |
288 * TODO: More documentation | 288 * TODO: More documentation |
289 */ | 289 */ |
290 void useUtf8Request(bool); | 290 void useUtf8Request(bool); |
291 | 291 |
306 * | 306 * |
307 * TODO: Document how the parameter works. | 307 * TODO: Document how the parameter works. |
308 */ | 308 */ |
309 void changeTabTextColorRequest(int color); | 309 void changeTabTextColorRequest(int color); |
310 | 310 |
311 /** | 311 /** |
312 * This is emitted when the program running in the shell indicates whether or | 312 * This is emitted when the program running in the shell indicates whether or |
313 * not it is interested in mouse events. | 313 * not it is interested in mouse events. |
314 * | 314 * |
315 * @param usesMouse This will be true if the program wants to be informed about | 315 * @param usesMouse This will be true if the program wants to be informed about |
316 * mouse events or false otherwise. | 316 * mouse events or false otherwise. |
317 */ | 317 */ |
318 void programUsesMouseChanged(bool usesMouse); | 318 void programUsesMouseChanged(bool usesMouse); |
319 | 319 |
320 /** | 320 /** |
321 * Emitted when the contents of the screen image change. | 321 * Emitted when the contents of the screen image change. |
322 * The emulation buffers the updates from successive image changes, | 322 * The emulation buffers the updates from successive image changes, |
323 * and only emits outputChanged() at sensible intervals when | 323 * and only emits outputChanged() at sensible intervals when |
324 * there is a lot of terminal activity. | 324 * there is a lot of terminal activity. |
325 * | 325 * |
326 * Normally there is no need for objects other than the screen windows | 326 * Normally there is no need for objects other than the screen windows |
327 * created with createWindow() to listen for this signal. | 327 * created with createWindow() to listen for this signal. |
328 * | 328 * |
329 * ScreenWindow objects created using createWindow() will emit their | 329 * ScreenWindow objects created using createWindow() will emit their |
330 * own outputChanged() signal in response to this signal. | 330 * own outputChanged() signal in response to this signal. |
331 */ | 331 */ |
332 void outputChanged(); | 332 void outputChanged(); |
333 | 333 |
334 /** | 334 /** |
335 * Emitted when the program running in the terminal wishes to update the | 335 * Emitted when the program running in the terminal wishes to update the |
336 * session's title. This also allows terminal programs to customize other | 336 * session's title. This also allows terminal programs to customize other |
337 * aspects of the terminal emulation display. | 337 * aspects of the terminal emulation display. |
338 * | 338 * |
339 * This signal is emitted when the escape sequence "\033]ARG;VALUE\007" | 339 * This signal is emitted when the escape sequence "\033]ARG;VALUE\007" |
340 * is received in the input string, where ARG is a number specifying what | 340 * is received in the input string, where ARG is a number specifying what |
341 * should change and VALUE is a string specifying the new value. | 341 * should change and VALUE is a string specifying the new value. |
342 * | 342 * |
343 * TODO: The name of this method is not very accurate since this method | 343 * TODO: The name of this method is not very accurate since this method |
344 * is used to perform a whole range of tasks besides just setting | 344 * is used to perform a whole range of tasks besides just setting |
345 * the user-title of the session. | 345 * the user-title of the session. |
346 * | 346 * |
347 * @param title Specifies what to change. | 347 * @param title Specifies what to change. |
348 * <ul> | 348 * <ul> |
349 * <li>0 - Set window icon text and session title to @p newTitle</li> | 349 * <li>0 - Set window icon text and session title to @p newTitle</li> |
350 * <li>1 - Set window icon text to @p newTitle</li> | 350 * <li>1 - Set window icon text to @p newTitle</li> |
351 * <li>2 - Set session title to @p newTitle</li> | 351 * <li>2 - Set session title to @p newTitle</li> |
352 * <li>11 - Set the session's default background color to @p newTitle, | 352 * <li>11 - Set the session's default background color to @p newTitle, |
353 * where @p newTitle can be an HTML-style string (#RRGGBB) or a named | 353 * where @p newTitle can be an HTML-style string (#RRGGBB) or a named |
354 * color (eg 'red', 'blue'). | 354 * color (eg 'red', 'blue'). |
355 * See http://doc.trolltech.com/4.2/qcolor.html#setNamedColor for more | 355 * See http://doc.trolltech.com/4.2/qcolor.html#setNamedColor for more |
356 * details. | 356 * details. |
357 * </li> | 357 * </li> |
358 * <li>31 - Supposedly treats @p newTitle as a URL and opens it (NOT IMPLEMENTED)</li> | 358 * <li>31 - Supposedly treats @p newTitle as a URL and opens it (NOT IMPLEMENTED)</li> |
359 * <li>32 - Sets the icon associated with the session. @p newTitle is the name | 359 * <li>32 - Sets the icon associated with the session. @p newTitle is the name |
360 * of the icon to use, which can be the name of any icon in the current KDE icon | 360 * of the icon to use, which can be the name of any icon in the current KDE icon |
361 * theme (eg: 'konsole', 'kate', 'folder_home')</li> | 361 * theme (eg: 'konsole', 'kate', 'folder_home')</li> |
362 * </ul> | 362 * </ul> |
363 * @param newTitle Specifies the new title | 363 * @param newTitle Specifies the new title |
364 */ | 364 */ |
365 | 365 |
366 void titleChanged(int title,const QString& newTitle); | 366 void titleChanged(int title,const QString& newTitle); |
367 | 367 |
368 /** | 368 /** |
369 * Emitted when the program running in the terminal changes the | 369 * Emitted when the program running in the terminal changes the |
370 * screen size. | 370 * screen size. |
371 */ | 371 */ |
372 void imageSizeChanged(int lineCount , int columnCount); | 372 void imageSizeChanged(int lineCount , int columnCount); |
373 | 373 |
374 /** | 374 /** |
375 * Emitted when the terminal program requests to change various properties | 375 * Emitted when the terminal program requests to change various properties |
376 * of the terminal display. | 376 * of the terminal display. |
377 * | 377 * |
378 * A profile change command occurs when a special escape sequence, followed | 378 * A profile change command occurs when a special escape sequence, followed |
379 * by a string containing a series of name and value pairs is received. | 379 * by a string containing a series of name and value pairs is received. |
380 * This string can be parsed using a ProfileCommandParser instance. | 380 * This string can be parsed using a ProfileCommandParser instance. |
381 * | 381 * |
385 void profileChangeCommandReceived(const QString& text); | 385 void profileChangeCommandReceived(const QString& text); |
386 | 386 |
387 protected: | 387 protected: |
388 virtual void setMode (int mode) = 0; | 388 virtual void setMode (int mode) = 0; |
389 virtual void resetMode(int mode) = 0; | 389 virtual void resetMode(int mode) = 0; |
390 | 390 |
391 /** | 391 /** |
392 * Processes an incoming character. See receiveData() | 392 * Processes an incoming character. See receiveData() |
393 * @p ch A unicode character code. | 393 * @p ch A unicode character code. |
394 */ | 394 */ |
395 virtual void receiveChar(int ch); | 395 virtual void receiveChar(int ch); |
396 | 396 |
397 /** | 397 /** |
398 * Sets the active screen. The terminal has two screens, primary and alternate. | 398 * Sets the active screen. The terminal has two screens, primary and alternate. |
399 * The primary screen is used by default. When certain interactive programs such | 399 * The primary screen is used by default. When certain interactive programs such |
400 * as Vim are run, they trigger a switch to the alternate screen. | 400 * as Vim are run, they trigger a switch to the alternate screen. |
401 * | 401 * |
402 * @param index 0 to switch to the primary screen, or 1 to switch to the alternate screen | 402 * @param index 0 to switch to the primary screen, or 1 to switch to the alternate screen |
403 */ | 403 */ |
404 void setScreen(int index); | 404 void setScreen(int index); |
405 | 405 |
406 enum EmulationCodec | 406 enum EmulationCodec |
407 { | 407 { |
408 LocaleCodec = 0, | 408 LocaleCodec = 0, |
409 Utf8Codec = 1 | 409 Utf8Codec = 1 |
410 }; | 410 }; |
411 void setCodec(EmulationCodec codec); // codec number, 0 = locale, 1=utf8 | 411 void setCodec(EmulationCodec codec); // codec number, 0 = locale, 1=utf8 |
412 | 412 |
413 | 413 |
414 QList<ScreenWindow*> _windows; | 414 QList<ScreenWindow*> _windows; |
415 | 415 |
416 Screen* _currentScreen; // pointer to the screen which is currently active, | 416 Screen* _currentScreen; // pointer to the screen which is currently active, |
417 // this is one of the elements in the screen[] array | 417 // this is one of the elements in the screen[] array |
418 | 418 |
419 Screen* _screen[2]; // 0 = primary screen ( used by most programs, including the shell | 419 Screen* _screen[2]; // 0 = primary screen ( used by most programs, including the shell |
420 // scrollbars are enabled in this mode ) | 420 // scrollbars are enabled in this mode ) |
421 // 1 = alternate ( used by vi , emacs etc. | 421 // 1 = alternate ( used by vi , emacs etc. |
422 // scrollbars are not enabled in this mode ) | 422 // scrollbars are not enabled in this mode ) |
423 | 423 |
424 | 424 |
425 //decodes an incoming C-style character stream into a unicode QString using | 425 //decodes an incoming C-style character stream into a unicode QString using |
426 //the current text codec. (this allows for rendering of non-ASCII characters in text files etc.) | 426 //the current text codec. (this allows for rendering of non-ASCII characters in text files etc.) |
427 const QTextCodec* _codec; | 427 const QTextCodec* _codec; |
428 QTextDecoder* _decoder; | 428 QTextDecoder* _decoder; |
429 | 429 |
430 const KeyboardTranslator* _keyTranslator; // the keyboard layout | 430 const KeyboardTranslator* _keyTranslator; // the keyboard layout |
431 | 431 |
432 protected slots: | 432 protected slots: |
433 /** | 433 /** |
434 * Schedules an update of attached views. | 434 * Schedules an update of attached views. |
435 * Repeated calls to bufferedUpdate() in close succession will result in only a single update, | 435 * Repeated calls to bufferedUpdate() in close succession will result in only a single update, |
436 * much like the Qt buffered update of widgets. | 436 * much like the Qt buffered update of widgets. |
437 */ | 437 */ |
438 void bufferedUpdate(); | 438 void bufferedUpdate(); |
439 | 439 |
440 private slots: | 440 private slots: |
441 | 441 |
442 // triggered by timer, causes the emulation to send an updated screen image to each | 442 // triggered by timer, causes the emulation to send an updated screen image to each |
443 // view | 443 // view |
444 void showBulk(); | 444 void showBulk(); |
445 | 445 |
446 void usesMouseChanged(bool usesMouse); | 446 void usesMouseChanged(bool usesMouse); |
447 | 447 |
448 private: | 448 private: |
449 | 449 |
450 bool _usesMouse; | 450 bool _usesMouse; |
451 QTimer _bulkTimer1; | 451 QTimer _bulkTimer1; |
452 QTimer _bulkTimer2; | 452 QTimer _bulkTimer2; |
453 | 453 |
454 }; | 454 }; |
455 | 455 |
456 #endif // ifndef EMULATION_H | 456 #endif // ifndef EMULATION_H |