3 HEX-style pattern matching
5 Copyright (C) 2009-2016
6 Free Software Foundation, Inc.
9 Slava Zanko <slavazanko@gmail.com>, 2009.
11 This file is part of the Midnight Commander.
13 The Midnight Commander is free software: you can redistribute it
14 and/or modify it under the terms of the GNU General Public License as
15 published by the Free Software Foundation, either version 3 of the License,
16 or (at your option) any later version.
18 The Midnight Commander is distributed in the hope that it will be useful,
19 but WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 GNU General Public License for more details.
23 You should have received a copy of the GNU General Public License
24 along with this program. If not, see <http://www.gnu.org/licenses/>.
31 #include "lib/global.h"
32 #include "lib/strutil.h"
33 #include "lib/search.h"
34 #include "lib/strescape.h"
38 /*** global variables ****************************************************************************/
40 /*** file scope macro definitions ****************************************************************/
45 MC_SEARCH_HEX_E_NUM_OUT_OF_RANGE
,
46 MC_SEARCH_HEX_E_INVALID_CHARACTER
,
47 MC_SEARCH_HEX_E_UNMATCHED_QUOTES
48 } mc_search_hex_parse_error_t
;
50 /*** file scope type declarations ****************************************************************/
52 /*** file scope variables ************************************************************************/
54 /*** file scope functions ************************************************************************/
57 mc_search__hex_translate_to_regex (const GString
* astr
, mc_search_hex_parse_error_t
* error_ptr
,
61 gchar
*tmp_str
, *tmp_str2
;
64 mc_search_hex_parse_error_t error
= MC_SEARCH_HEX_E_OK
;
66 buff
= g_string_sized_new (64);
67 tmp_str
= g_strndup (astr
->str
, astr
->len
);
70 /* remove 0x prefices */
73 tmp_str2
= strstr (tmp_str2
, "0x");
81 tmp_str_len
= strlen (tmp_str
);
83 while (loop
< tmp_str_len
&& error
== MC_SEARCH_HEX_E_OK
)
88 if (g_ascii_isspace (tmp_str
[loop
]))
90 /* Eat-up whitespace between tokens. */
91 while (g_ascii_isspace (tmp_str
[loop
]))
94 /* cppcheck-suppress invalidscanf */
95 else if (sscanf (tmp_str
+ loop
, "%x%n", &val
, &ptr
) == 1)
98 error
= MC_SEARCH_HEX_E_NUM_OUT_OF_RANGE
;
101 g_string_append_printf (buff
, "\\x%02X", val
);
105 else if (tmp_str
[loop
] == '"')
111 while (loop2
< tmp_str_len
)
113 if (tmp_str
[loop2
] == '"')
115 if (tmp_str
[loop2
] == '\\' && loop2
+ 1 < tmp_str_len
)
117 g_string_append_c (buff
, tmp_str
[loop2
]);
121 if (tmp_str
[loop2
] == '\0')
122 error
= MC_SEARCH_HEX_E_UNMATCHED_QUOTES
;
127 error
= MC_SEARCH_HEX_E_INVALID_CHARACTER
;
132 if (error
!= MC_SEARCH_HEX_E_OK
)
134 g_string_free (buff
, TRUE
);
135 if (error_ptr
!= NULL
)
137 if (error_pos_ptr
!= NULL
)
138 *error_pos_ptr
= loop
;
145 /*** public functions ****************************************************************************/
148 mc_search__cond_struct_new_init_hex (const char *charset
, mc_search_t
* lc_mc_search
,
149 mc_search_cond_t
* mc_search_cond
)
152 mc_search_hex_parse_error_t error
= MC_SEARCH_HEX_E_OK
;
155 tmp
= mc_search__hex_translate_to_regex (mc_search_cond
->str
, &error
, &error_pos
);
158 g_string_free (mc_search_cond
->str
, TRUE
);
159 mc_search_cond
->str
= tmp
;
160 mc_search__cond_struct_new_init_regex (charset
, lc_mc_search
, mc_search_cond
);
168 case MC_SEARCH_HEX_E_NUM_OUT_OF_RANGE
:
171 ("Number out of range (should be in byte range, 0 <= n <= 0xFF, expressed in hex)");
173 case MC_SEARCH_HEX_E_INVALID_CHARACTER
:
174 desc
= _("Invalid character");
176 case MC_SEARCH_HEX_E_UNMATCHED_QUOTES
:
177 desc
= _("Unmatched quotes character");
183 lc_mc_search
->error
= MC_SEARCH_E_INPUT
;
184 lc_mc_search
->error_str
=
185 g_strdup_printf (_("Hex pattern error at position %d:\n%s."), error_pos
+ 1, desc
);
189 /* --------------------------------------------------------------------------------------------- */
192 mc_search__run_hex (mc_search_t
* lc_mc_search
, const void *user_data
,
193 gsize start_search
, gsize end_search
, gsize
* found_len
)
195 return mc_search__run_regex (lc_mc_search
, user_data
, start_search
, end_search
, found_len
);
198 /* --------------------------------------------------------------------------------------------- */
201 mc_search_hex_prepare_replace_str (mc_search_t
* lc_mc_search
, GString
* replace_str
)
204 return g_string_new_len (replace_str
->str
, replace_str
->len
);
207 /* --------------------------------------------------------------------------------------------- */