Show More
@@ -124,19 +124,42 b' class HistoryManager(Configurable):' | |||
|
124 | 124 | name='session_number'""", (self.session_number+1,)) |
|
125 | 125 | self.db.commit() |
|
126 | 126 | |
|
127 |
def get_hist_ |
|
|
128 |
""" |
|
|
127 | def _get_hist_sql(self, sql, params, raw=True, output=False): | |
|
128 | """Prepares and runs an SQL query for the history database. | |
|
129 | ||
|
130 | Parameters | |
|
131 | ---------- | |
|
132 | sql : str | |
|
133 | Any filtering expressions to go after SELECT ... FROM ... | |
|
134 | params : tuple | |
|
135 | Parameters passed to the SQL query (to replace "?") | |
|
136 | raw : bool | |
|
137 | If True, get raw input. | |
|
138 | output : | |
|
139 | If True, include output where available. | |
|
140 | ||
|
141 | Returns | |
|
142 | ------- | |
|
143 | An iterator over 3-tuples: (session, line_number, command), or if output | |
|
144 | is True, (session, line_number, (command, output)). | |
|
145 | """ | |
|
129 | 146 | toget = 'source_raw' if raw else 'source' |
|
130 | 147 | sqlfrom = "history" |
|
131 | 148 | if output: |
|
132 | 149 | sqlfrom = "history LEFT JOIN output_history USING (session, line)" |
|
133 | 150 | toget = "history.%s, output_history.output" % toget |
|
134 |
cur = self.db.execute("SELECT session, line, " |
|
|
135 | " FROM "+sqlfrom+" ORDER BY session DESC, line DESC LIMIT ?", (n,)) | |
|
136 | hist = reversed(cur.fetchall()) | |
|
137 | if output: | |
|
138 | return ((ses, lin, (inp, out)) for ses, lin, inp, out in hist) | |
|
139 | return hist | |
|
151 | cur = self.db.execute("SELECT session, line, %s FROM %s " %\ | |
|
152 | (toget, sqlfrom) + sql, params) | |
|
153 | if output: # Regroup into 3-tuples | |
|
154 | return ((ses, lin, (inp, out)) for ses, lin, inp, out in cur) | |
|
155 | return cur | |
|
156 | ||
|
157 | ||
|
158 | def get_hist_tail(self, n=10, raw=True, output=False): | |
|
159 | """Get the last n lines from the history database.""" | |
|
160 | cur = self._get_hist_sql("ORDER BY session DESC, line DESC LIMIT ?", | |
|
161 | (n,), raw=raw, output=output) | |
|
162 | return reversed(list(cur)) | |
|
140 | 163 | |
|
141 | 164 | def get_hist_search(self, pattern="*", raw=True, output=False): |
|
142 | 165 | """Search the database using unix glob-style matching (wildcards * and |
@@ -146,18 +169,11 b' class HistoryManager(Configurable):' | |||
|
146 | 169 | ------- |
|
147 | 170 | An iterator over tuples: (session, line_number, command) |
|
148 | 171 | """ |
|
149 |
to |
|
|
150 | tosearch = toget | |
|
151 | sqlfrom = "history" | |
|
172 | tosearch = "source_raw" if raw else "source" | |
|
152 | 173 | if output: |
|
153 | sqlfrom = "history LEFT JOIN output_history USING (session, line)" | |
|
154 | toget = "history.%s, output_history.output" % toget | |
|
155 | 174 | tosearch = "history." + tosearch |
|
156 | hist = self.db.execute("SELECT session, line, " +toget+ \ | |
|
157 | " FROM "+sqlfrom+" WHERE " +tosearch+ " GLOB ?", (pattern,)) | |
|
158 | if output: | |
|
159 | return ((ses, lin, (inp, out)) for ses, lin, inp, out in hist) | |
|
160 | return hist | |
|
175 | return self._get_hist_sql("WHERE %s GLOB ?" % tosearch, (pattern,), | |
|
176 | raw=raw, output=output) | |
|
161 | 177 | |
|
162 | 178 | def _get_hist_session(self, start=1, stop=None, raw=True, output=False): |
|
163 | 179 | """Get input and output history from the current session. Called by |
@@ -211,12 +227,6 b' class HistoryManager(Configurable):' | |||
|
211 | 227 | if session < 0: |
|
212 | 228 | session += self.session_number |
|
213 | 229 | |
|
214 | # Assemble the SQL query: | |
|
215 | sqlfrom = "history" | |
|
216 | toget = 'source_raw' if raw else 'source' | |
|
217 | if output: | |
|
218 | sqlfrom = "history LEFT JOIN output_history USING (session, line)" | |
|
219 | toget = "history.%s, output_history.output" % toget | |
|
220 | 230 | if stop: |
|
221 | 231 | lineclause = "line >= ? AND line < ?" |
|
222 | 232 | params = (session, start, stop) |
@@ -224,11 +234,8 b' class HistoryManager(Configurable):' | |||
|
224 | 234 | lineclause = "line>=?" |
|
225 | 235 | params = (session, start) |
|
226 | 236 | |
|
227 | cur = self.db.execute("""SELECT session, line, %s FROM %s WHERE | |
|
228 | session==? AND %s""" %(toget, sqlfrom, lineclause), params) | |
|
229 | if output: # Regroup into 3-tuples | |
|
230 | return ((ses, lin, (inp, out)) for ses, lin, inp, out in cur) | |
|
231 | return cur | |
|
237 | return self._get_hist_sql("WHERE session==? AND %s""" % lineclause, | |
|
238 | params, raw=raw, output=output) | |
|
232 | 239 | |
|
233 | 240 | def get_hist_from_rangestr(self, rangestr, raw=True, output=False): |
|
234 | 241 | """Get lines of history from a string of ranges, as used by magic |
General Comments 0
You need to be logged in to leave comments.
Login now