| 1 | /* Copyright (c) 2008, 2015, Oracle and/or its affiliates. All rights reserved. |
| 2 | |
| 3 | This program is free software; you can redistribute it and/or modify |
| 4 | it under the terms of the GNU General Public License as published by |
| 5 | the Free Software Foundation; version 2 of the License. |
| 6 | |
| 7 | This program is distributed in the hope that it will be useful, |
| 8 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 9 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 10 | GNU General Public License for more details. |
| 11 | |
| 12 | You should have received a copy of the GNU General Public License |
| 13 | along with this program; if not, write to the Free Software Foundation, |
| 14 | 51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA */ |
| 15 | |
| 16 | #ifndef SQL_DIGEST_STREAM_H |
| 17 | #define SQL_DIGEST_STREAM_H |
| 18 | |
| 19 | #include "sql_digest.h" |
| 20 | |
| 21 | /** |
| 22 | State data storage for @c digest_start, @c digest_add_token. |
| 23 | This structure extends the @c sql_digest_storage structure |
| 24 | with temporary state used only during parsing. |
| 25 | */ |
| 26 | struct sql_digest_state |
| 27 | { |
| 28 | /** |
| 29 | Index, in the digest token array, of the last identifier seen. |
| 30 | Reduce rules used in the digest computation can not |
| 31 | apply to tokens seen before an identifier. |
| 32 | @sa digest_add_token |
| 33 | */ |
| 34 | int m_last_id_index; |
| 35 | sql_digest_storage m_digest_storage; |
| 36 | |
| 37 | inline void reset(unsigned char *token_array, uint length) |
| 38 | { |
| 39 | m_last_id_index= 0; |
| 40 | m_digest_storage.reset(token_array, length); |
| 41 | } |
| 42 | |
| 43 | inline bool is_empty() |
| 44 | { |
| 45 | return m_digest_storage.is_empty(); |
| 46 | } |
| 47 | }; |
| 48 | typedef struct sql_digest_state sql_digest_state; |
| 49 | |
| 50 | #endif |
| 51 | |
| 52 | |