Hide keyboard shortcuts

Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: 

 

# Copyright 2014-2018 Florian Bruhin (The Compiler) <mail@qutebrowser.org> 

# 

# This file is part of qutebrowser. 

# 

# qutebrowser 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 3 of the License, or 

# (at your option) any later version. 

# 

# qutebrowser 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 qutebrowser. If not, see <http://www.gnu.org/licenses/>. 

 

"""Command history for the status bar.""" 

 

from PyQt5.QtCore import pyqtSlot, pyqtSignal, QObject 

 

from qutebrowser.utils import usertypes, log, standarddir, objreg 

from qutebrowser.misc import lineparser 

 

 

class HistoryEmptyError(Exception): 

 

"""Raised when the history is empty.""" 

 

pass 

 

 

class HistoryEndReachedError(Exception): 

 

"""Raised when the end of the history is reached.""" 

 

pass 

 

 

class History(QObject): 

 

"""Command history. 

 

Attributes: 

history: A list of executed commands, with newer commands at the end. 

_tmphist: Temporary history for history browsing (as NeighborList) 

 

Signals: 

changed: Emitted when an entry was added to the history. 

""" 

 

changed = pyqtSignal() 

 

def __init__(self, *, history=None, parent=None): 

"""Constructor. 

 

Args: 

history: The initial history to set. 

""" 

super().__init__(parent) 

self._tmphist = None 

if history is None: 

self.history = [] 

else: 

self.history = history 

 

def __getitem__(self, idx): 

return self.history[idx] 

 

def is_browsing(self): 

"""Check _tmphist to see if we're browsing.""" 

return self._tmphist is not None 

 

def start(self, text): 

"""Start browsing to the history. 

 

Called when the user presses the up/down key and wasn't browsing the 

history already. 

 

Args: 

text: The preset text. 

""" 

log.misc.debug("Preset text: '{}'".format(text)) 

if text: 

items = [e for e in self.history if e.startswith(text)] 

else: 

items = self.history 

if not items: 

raise HistoryEmptyError 

self._tmphist = usertypes.NeighborList(items) 

return self._tmphist.lastitem() 

 

@pyqtSlot() 

def stop(self): 

"""Stop browsing the history.""" 

self._tmphist = None 

 

def previtem(self): 

"""Get the previous item in the temp history. 

 

start() needs to be called before calling this. 

""" 

if not self.is_browsing(): 

raise ValueError("Currently not browsing history") 

try: 

return self._tmphist.previtem() 

except IndexError: 

raise HistoryEndReachedError 

 

def nextitem(self): 

"""Get the next item in the temp history. 

 

start() needs to be called before calling this. 

""" 

if not self.is_browsing(): 

raise ValueError("Currently not browsing history") 

try: 

return self._tmphist.nextitem() 

except IndexError: 

raise HistoryEndReachedError 

 

def append(self, text): 

"""Append a new item to the history. 

 

Args: 

text: The text to append. 

""" 

if not self.history or text != self.history[-1]: 

self.history.append(text) 

self.changed.emit() 

 

 

def init(): 

"""Initialize the LimitLineParser storing the history.""" 

save_manager = objreg.get('save-manager') 

command_history = lineparser.LimitLineParser( 

standarddir.data(), 'cmd-history', 

limit='completion.cmd_history_max_items') 

objreg.register('command-history', command_history) 

save_manager.add_saveable('command-history', command_history.save, 

command_history.changed)