tree-sitter-analyzer 0.6.2__py3-none-any.whl → 0.8.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of tree-sitter-analyzer might be problematic. Click here for more details.

Files changed (69) hide show
  1. tree_sitter_analyzer/__init__.py +132 -132
  2. tree_sitter_analyzer/__main__.py +11 -11
  3. tree_sitter_analyzer/api.py +533 -533
  4. tree_sitter_analyzer/cli/__init__.py +39 -39
  5. tree_sitter_analyzer/cli/__main__.py +12 -12
  6. tree_sitter_analyzer/cli/commands/__init__.py +26 -26
  7. tree_sitter_analyzer/cli/commands/advanced_command.py +88 -88
  8. tree_sitter_analyzer/cli/commands/base_command.py +160 -160
  9. tree_sitter_analyzer/cli/commands/default_command.py +18 -18
  10. tree_sitter_analyzer/cli/commands/partial_read_command.py +141 -141
  11. tree_sitter_analyzer/cli/commands/query_command.py +81 -81
  12. tree_sitter_analyzer/cli/commands/structure_command.py +138 -138
  13. tree_sitter_analyzer/cli/commands/summary_command.py +101 -101
  14. tree_sitter_analyzer/cli/commands/table_command.py +235 -235
  15. tree_sitter_analyzer/cli/info_commands.py +121 -121
  16. tree_sitter_analyzer/cli_main.py +297 -297
  17. tree_sitter_analyzer/core/__init__.py +15 -15
  18. tree_sitter_analyzer/core/analysis_engine.py +555 -555
  19. tree_sitter_analyzer/core/cache_service.py +320 -320
  20. tree_sitter_analyzer/core/engine.py +566 -566
  21. tree_sitter_analyzer/core/parser.py +293 -293
  22. tree_sitter_analyzer/encoding_utils.py +459 -459
  23. tree_sitter_analyzer/exceptions.py +406 -337
  24. tree_sitter_analyzer/file_handler.py +210 -210
  25. tree_sitter_analyzer/formatters/__init__.py +1 -1
  26. tree_sitter_analyzer/formatters/base_formatter.py +167 -167
  27. tree_sitter_analyzer/formatters/formatter_factory.py +78 -78
  28. tree_sitter_analyzer/interfaces/__init__.py +9 -9
  29. tree_sitter_analyzer/interfaces/cli.py +528 -528
  30. tree_sitter_analyzer/interfaces/cli_adapter.py +343 -343
  31. tree_sitter_analyzer/interfaces/mcp_adapter.py +206 -206
  32. tree_sitter_analyzer/interfaces/mcp_server.py +425 -405
  33. tree_sitter_analyzer/languages/__init__.py +10 -10
  34. tree_sitter_analyzer/languages/javascript_plugin.py +446 -446
  35. tree_sitter_analyzer/languages/python_plugin.py +755 -755
  36. tree_sitter_analyzer/mcp/__init__.py +31 -31
  37. tree_sitter_analyzer/mcp/resources/__init__.py +44 -44
  38. tree_sitter_analyzer/mcp/resources/code_file_resource.py +209 -209
  39. tree_sitter_analyzer/mcp/server.py +346 -333
  40. tree_sitter_analyzer/mcp/tools/__init__.py +30 -30
  41. tree_sitter_analyzer/mcp/tools/analyze_scale_tool.py +654 -654
  42. tree_sitter_analyzer/mcp/tools/analyze_scale_tool_cli_compatible.py +247 -247
  43. tree_sitter_analyzer/mcp/tools/base_tool.py +54 -54
  44. tree_sitter_analyzer/mcp/tools/read_partial_tool.py +300 -300
  45. tree_sitter_analyzer/mcp/tools/table_format_tool.py +362 -362
  46. tree_sitter_analyzer/mcp/tools/universal_analyze_tool.py +543 -543
  47. tree_sitter_analyzer/mcp/utils/__init__.py +107 -107
  48. tree_sitter_analyzer/mcp/utils/error_handler.py +549 -549
  49. tree_sitter_analyzer/output_manager.py +253 -253
  50. tree_sitter_analyzer/plugins/__init__.py +280 -280
  51. tree_sitter_analyzer/plugins/base.py +529 -529
  52. tree_sitter_analyzer/plugins/manager.py +379 -379
  53. tree_sitter_analyzer/queries/__init__.py +26 -26
  54. tree_sitter_analyzer/queries/java.py +391 -391
  55. tree_sitter_analyzer/queries/javascript.py +148 -148
  56. tree_sitter_analyzer/queries/python.py +285 -285
  57. tree_sitter_analyzer/queries/typescript.py +229 -229
  58. tree_sitter_analyzer/query_loader.py +257 -257
  59. tree_sitter_analyzer/security/__init__.py +22 -0
  60. tree_sitter_analyzer/security/boundary_manager.py +237 -0
  61. tree_sitter_analyzer/security/regex_checker.py +292 -0
  62. tree_sitter_analyzer/security/validator.py +224 -0
  63. tree_sitter_analyzer/table_formatter.py +652 -473
  64. tree_sitter_analyzer/utils.py +277 -277
  65. {tree_sitter_analyzer-0.6.2.dist-info → tree_sitter_analyzer-0.8.0.dist-info}/METADATA +4 -1
  66. tree_sitter_analyzer-0.8.0.dist-info/RECORD +76 -0
  67. tree_sitter_analyzer-0.6.2.dist-info/RECORD +0 -72
  68. {tree_sitter_analyzer-0.6.2.dist-info → tree_sitter_analyzer-0.8.0.dist-info}/WHEEL +0 -0
  69. {tree_sitter_analyzer-0.6.2.dist-info → tree_sitter_analyzer-0.8.0.dist-info}/entry_points.txt +0 -0
@@ -1,253 +1,253 @@
1
- #!/usr/bin/env python3
2
- """
3
- Output Manager for CLI
4
-
5
- Handles different types of outputs: user information, errors, and structured data.
6
- """
7
-
8
- import json
9
- import sys
10
- from typing import Any
11
-
12
- from .utils import log_error, log_warning
13
-
14
-
15
- class OutputManager:
16
- """Manages different types of output for CLI"""
17
-
18
- def __init__(self, quiet: bool = False, json_output: bool = False):
19
- self.quiet = quiet
20
- self.json_output = json_output
21
-
22
- def info(self, message: str) -> None:
23
- """Output informational message to user"""
24
- if not self.quiet:
25
- print(message)
26
-
27
- def warning(self, message: str) -> None:
28
- """Output warning message"""
29
- if not self.quiet:
30
- print(f"WARNING: {message}", file=sys.stderr)
31
- log_warning(message)
32
-
33
- def error(self, message: str) -> None:
34
- """Output error message"""
35
- print(f"ERROR: {message}", file=sys.stderr)
36
- log_error(message)
37
-
38
- def success(self, message: str) -> None:
39
- """Output success message"""
40
- if not self.quiet:
41
- print(f"✓ {message}")
42
-
43
- def output_info(self, message: str) -> None:
44
- """Output info message (alias for info)"""
45
- self.info(message)
46
-
47
- def output_warning(self, message: str) -> None:
48
- """Output warning message (alias for warning)"""
49
- self.warning(message)
50
-
51
- def output_error(self, message: str) -> None:
52
- """Output error message (alias for error)"""
53
- self.error(message)
54
-
55
- def output_success(self, message: str) -> None:
56
- """Output success message (alias for success)"""
57
- self.success(message)
58
-
59
- def data(self, data: Any, format_type: str = "json") -> None:
60
- """Output structured data"""
61
- if self.json_output or format_type == "json":
62
- print(json.dumps(data, indent=2, ensure_ascii=False))
63
- else:
64
- self._format_data(data)
65
-
66
- def _format_data(self, data: Any) -> None:
67
- """Format data for human-readable output"""
68
- if isinstance(data, dict):
69
- for key, value in data.items():
70
- print(f"{key}: {value}")
71
- elif isinstance(data, list):
72
- for i, item in enumerate(data, 1):
73
- print(f"{i}. {item}")
74
- else:
75
- print(str(data))
76
-
77
- def results_header(self, title: str) -> None:
78
- """Output results section header"""
79
- if not self.quiet:
80
- print(f"\n--- {title} ---")
81
-
82
- def query_result(self, index: int, result: dict[str, Any]) -> None:
83
- """Output query result in formatted way"""
84
- if not self.quiet:
85
- print(
86
- f"\n{index}. {result.get('capture_name', 'Unknown')} ({result.get('node_type', 'Unknown')})"
87
- )
88
- print(
89
- f" Position: Line {result.get('start_line', '?')}-{result.get('end_line', '?')}"
90
- )
91
- if "content" in result:
92
- print(f" Content:\n{result['content']}")
93
-
94
- def analysis_summary(self, stats: dict[str, Any]) -> None:
95
- """Output analysis summary"""
96
- if self.json_output:
97
- self.data(stats)
98
- else:
99
- self.results_header("Statistics")
100
- for key, value in stats.items():
101
- print(f"{key}: {value}")
102
-
103
- def language_list(
104
- self, languages: list[str], title: str = "Supported Languages"
105
- ) -> None:
106
- """Output language list"""
107
- if not self.quiet:
108
- print(f"{title}:")
109
- for lang in languages:
110
- print(f" {lang}")
111
-
112
- def query_list(self, queries: dict[str, str], language: str) -> None:
113
- """Output query list for a language"""
114
- if not self.quiet:
115
- print(f"Available query keys ({language}):")
116
- for query_key, description in queries.items():
117
- print(f" {query_key:<20} - {description}")
118
-
119
- def extension_list(self, extensions: list[str]) -> None:
120
- """Output supported extensions"""
121
- if not self.quiet:
122
- print("Supported file extensions:")
123
- for i in range(0, len(extensions), 10):
124
- chunk = extensions[i : i + 10]
125
- print(f" {' '.join(chunk)}")
126
- print(f"Total {len(extensions)} extensions supported")
127
-
128
- def output_json(self, data: Any) -> None:
129
- """Output JSON data"""
130
- print(json.dumps(data, indent=2, ensure_ascii=False))
131
-
132
- def output_list(self, items: str | list[Any], title: str | None = None) -> None:
133
- """Output a list of items"""
134
- if title and not self.quiet:
135
- print(f"{title}:")
136
- # 文字列が単一要素として渡された場合の処理
137
- if isinstance(items, str):
138
- items = [items]
139
- for item in items:
140
- if not self.quiet:
141
- print(f" {item}")
142
-
143
- def output_section(self, title: str) -> None:
144
- """Output a section header"""
145
- if not self.quiet:
146
- print(f"\n--- {title} ---")
147
-
148
- def output_query_results(self, results: Any) -> None:
149
- """Output query results"""
150
- self.data(results)
151
-
152
- def output_statistics(self, stats: dict[str, Any]) -> None:
153
- """Output statistics"""
154
- self.analysis_summary(stats)
155
-
156
- def output_languages(self, languages: list[str]) -> None:
157
- """Output available languages"""
158
- self.language_list(languages)
159
-
160
- def output_queries(self, queries: list[str]) -> None:
161
- """Output available queries"""
162
- query_dict = {q: f"Query {q}" for q in queries}
163
- self.query_list(query_dict, "All")
164
-
165
- def output_extensions(self, extensions: list[str]) -> None:
166
- """Output file extensions"""
167
- self.extension_list(extensions)
168
-
169
- def output_data(self, data: Any, format_type: str = "json") -> None:
170
- """Output data (alias for data)"""
171
- self.data(data, format_type)
172
-
173
-
174
- # Default instance for backward compatibility
175
- _output_manager = OutputManager()
176
-
177
-
178
- def set_output_mode(quiet: bool = False, json_output: bool = False) -> None:
179
- """Set global output mode"""
180
- global _output_manager
181
- _output_manager = OutputManager(quiet=quiet, json_output=json_output)
182
-
183
-
184
- def get_output_manager() -> OutputManager:
185
- """Get current output manager"""
186
- return _output_manager
187
-
188
-
189
- # Convenience functions
190
- def output_info(message: str) -> None:
191
- """Output info message"""
192
- _output_manager.info(message)
193
-
194
-
195
- def output_warning(message: str) -> None:
196
- """Output warning message"""
197
- _output_manager.warning(message)
198
-
199
-
200
- def output_error(message: str) -> None:
201
- """Output error message using the global output manager"""
202
- _output_manager.error(message)
203
-
204
-
205
- def output_success(message: str) -> None:
206
- """Output success message using the global output manager"""
207
- _output_manager.success(message)
208
-
209
-
210
- def output_json(data: Any) -> None:
211
- """Output JSON data using the global output manager"""
212
- _output_manager.output_json(data)
213
-
214
-
215
- def output_list(items: str | list[Any], title: str | None = None) -> None:
216
- """Output a list of items"""
217
- _output_manager.output_list(items, title)
218
-
219
-
220
- def output_section(title: str) -> None:
221
- """Output a section header"""
222
- _output_manager.output_section(title)
223
-
224
-
225
- def output_query_results(results: Any) -> None:
226
- """Output query results"""
227
- _output_manager.output_query_results(results)
228
-
229
-
230
- def output_statistics(stats: dict[str, Any]) -> None:
231
- """Output statistics"""
232
- _output_manager.output_statistics(stats)
233
-
234
-
235
- def output_languages(languages: list[str], title: str = "Supported Languages") -> None:
236
- """Output available languages"""
237
- _output_manager.language_list(languages, title)
238
-
239
-
240
- def output_queries(queries: list[str], language: str = "All") -> None:
241
- """Output available queries"""
242
- query_dict = {q: f"Query {q}" for q in queries}
243
- _output_manager.query_list(query_dict, language)
244
-
245
-
246
- def output_extensions(extensions: list[str]) -> None:
247
- """Output file extensions"""
248
- _output_manager.output_extensions(extensions)
249
-
250
-
251
- def output_data(data: Any, format_type: str = "json") -> None:
252
- """Output structured data"""
253
- _output_manager.data(data, format_type)
1
+ #!/usr/bin/env python3
2
+ """
3
+ Output Manager for CLI
4
+
5
+ Handles different types of outputs: user information, errors, and structured data.
6
+ """
7
+
8
+ import json
9
+ import sys
10
+ from typing import Any
11
+
12
+ from .utils import log_error, log_warning
13
+
14
+
15
+ class OutputManager:
16
+ """Manages different types of output for CLI"""
17
+
18
+ def __init__(self, quiet: bool = False, json_output: bool = False):
19
+ self.quiet = quiet
20
+ self.json_output = json_output
21
+
22
+ def info(self, message: str) -> None:
23
+ """Output informational message to user"""
24
+ if not self.quiet:
25
+ print(message)
26
+
27
+ def warning(self, message: str) -> None:
28
+ """Output warning message"""
29
+ if not self.quiet:
30
+ print(f"WARNING: {message}", file=sys.stderr)
31
+ log_warning(message)
32
+
33
+ def error(self, message: str) -> None:
34
+ """Output error message"""
35
+ print(f"ERROR: {message}", file=sys.stderr)
36
+ log_error(message)
37
+
38
+ def success(self, message: str) -> None:
39
+ """Output success message"""
40
+ if not self.quiet:
41
+ print(f"✓ {message}")
42
+
43
+ def output_info(self, message: str) -> None:
44
+ """Output info message (alias for info)"""
45
+ self.info(message)
46
+
47
+ def output_warning(self, message: str) -> None:
48
+ """Output warning message (alias for warning)"""
49
+ self.warning(message)
50
+
51
+ def output_error(self, message: str) -> None:
52
+ """Output error message (alias for error)"""
53
+ self.error(message)
54
+
55
+ def output_success(self, message: str) -> None:
56
+ """Output success message (alias for success)"""
57
+ self.success(message)
58
+
59
+ def data(self, data: Any, format_type: str = "json") -> None:
60
+ """Output structured data"""
61
+ if self.json_output or format_type == "json":
62
+ print(json.dumps(data, indent=2, ensure_ascii=False))
63
+ else:
64
+ self._format_data(data)
65
+
66
+ def _format_data(self, data: Any) -> None:
67
+ """Format data for human-readable output"""
68
+ if isinstance(data, dict):
69
+ for key, value in data.items():
70
+ print(f"{key}: {value}")
71
+ elif isinstance(data, list):
72
+ for i, item in enumerate(data, 1):
73
+ print(f"{i}. {item}")
74
+ else:
75
+ print(str(data))
76
+
77
+ def results_header(self, title: str) -> None:
78
+ """Output results section header"""
79
+ if not self.quiet:
80
+ print(f"\n--- {title} ---")
81
+
82
+ def query_result(self, index: int, result: dict[str, Any]) -> None:
83
+ """Output query result in formatted way"""
84
+ if not self.quiet:
85
+ print(
86
+ f"\n{index}. {result.get('capture_name', 'Unknown')} ({result.get('node_type', 'Unknown')})"
87
+ )
88
+ print(
89
+ f" Position: Line {result.get('start_line', '?')}-{result.get('end_line', '?')}"
90
+ )
91
+ if "content" in result:
92
+ print(f" Content:\n{result['content']}")
93
+
94
+ def analysis_summary(self, stats: dict[str, Any]) -> None:
95
+ """Output analysis summary"""
96
+ if self.json_output:
97
+ self.data(stats)
98
+ else:
99
+ self.results_header("Statistics")
100
+ for key, value in stats.items():
101
+ print(f"{key}: {value}")
102
+
103
+ def language_list(
104
+ self, languages: list[str], title: str = "Supported Languages"
105
+ ) -> None:
106
+ """Output language list"""
107
+ if not self.quiet:
108
+ print(f"{title}:")
109
+ for lang in languages:
110
+ print(f" {lang}")
111
+
112
+ def query_list(self, queries: dict[str, str], language: str) -> None:
113
+ """Output query list for a language"""
114
+ if not self.quiet:
115
+ print(f"Available query keys ({language}):")
116
+ for query_key, description in queries.items():
117
+ print(f" {query_key:<20} - {description}")
118
+
119
+ def extension_list(self, extensions: list[str]) -> None:
120
+ """Output supported extensions"""
121
+ if not self.quiet:
122
+ print("Supported file extensions:")
123
+ for i in range(0, len(extensions), 10):
124
+ chunk = extensions[i : i + 10]
125
+ print(f" {' '.join(chunk)}")
126
+ print(f"Total {len(extensions)} extensions supported")
127
+
128
+ def output_json(self, data: Any) -> None:
129
+ """Output JSON data"""
130
+ print(json.dumps(data, indent=2, ensure_ascii=False))
131
+
132
+ def output_list(self, items: str | list[Any], title: str | None = None) -> None:
133
+ """Output a list of items"""
134
+ if title and not self.quiet:
135
+ print(f"{title}:")
136
+ # 文字列が単一要素として渡された場合の処理
137
+ if isinstance(items, str):
138
+ items = [items]
139
+ for item in items:
140
+ if not self.quiet:
141
+ print(f" {item}")
142
+
143
+ def output_section(self, title: str) -> None:
144
+ """Output a section header"""
145
+ if not self.quiet:
146
+ print(f"\n--- {title} ---")
147
+
148
+ def output_query_results(self, results: Any) -> None:
149
+ """Output query results"""
150
+ self.data(results)
151
+
152
+ def output_statistics(self, stats: dict[str, Any]) -> None:
153
+ """Output statistics"""
154
+ self.analysis_summary(stats)
155
+
156
+ def output_languages(self, languages: list[str]) -> None:
157
+ """Output available languages"""
158
+ self.language_list(languages)
159
+
160
+ def output_queries(self, queries: list[str]) -> None:
161
+ """Output available queries"""
162
+ query_dict = {q: f"Query {q}" for q in queries}
163
+ self.query_list(query_dict, "All")
164
+
165
+ def output_extensions(self, extensions: list[str]) -> None:
166
+ """Output file extensions"""
167
+ self.extension_list(extensions)
168
+
169
+ def output_data(self, data: Any, format_type: str = "json") -> None:
170
+ """Output data (alias for data)"""
171
+ self.data(data, format_type)
172
+
173
+
174
+ # Default instance for backward compatibility
175
+ _output_manager = OutputManager()
176
+
177
+
178
+ def set_output_mode(quiet: bool = False, json_output: bool = False) -> None:
179
+ """Set global output mode"""
180
+ global _output_manager
181
+ _output_manager = OutputManager(quiet=quiet, json_output=json_output)
182
+
183
+
184
+ def get_output_manager() -> OutputManager:
185
+ """Get current output manager"""
186
+ return _output_manager
187
+
188
+
189
+ # Convenience functions
190
+ def output_info(message: str) -> None:
191
+ """Output info message"""
192
+ _output_manager.info(message)
193
+
194
+
195
+ def output_warning(message: str) -> None:
196
+ """Output warning message"""
197
+ _output_manager.warning(message)
198
+
199
+
200
+ def output_error(message: str) -> None:
201
+ """Output error message using the global output manager"""
202
+ _output_manager.error(message)
203
+
204
+
205
+ def output_success(message: str) -> None:
206
+ """Output success message using the global output manager"""
207
+ _output_manager.success(message)
208
+
209
+
210
+ def output_json(data: Any) -> None:
211
+ """Output JSON data using the global output manager"""
212
+ _output_manager.output_json(data)
213
+
214
+
215
+ def output_list(items: str | list[Any], title: str | None = None) -> None:
216
+ """Output a list of items"""
217
+ _output_manager.output_list(items, title)
218
+
219
+
220
+ def output_section(title: str) -> None:
221
+ """Output a section header"""
222
+ _output_manager.output_section(title)
223
+
224
+
225
+ def output_query_results(results: Any) -> None:
226
+ """Output query results"""
227
+ _output_manager.output_query_results(results)
228
+
229
+
230
+ def output_statistics(stats: dict[str, Any]) -> None:
231
+ """Output statistics"""
232
+ _output_manager.output_statistics(stats)
233
+
234
+
235
+ def output_languages(languages: list[str], title: str = "Supported Languages") -> None:
236
+ """Output available languages"""
237
+ _output_manager.language_list(languages, title)
238
+
239
+
240
+ def output_queries(queries: list[str], language: str = "All") -> None:
241
+ """Output available queries"""
242
+ query_dict = {q: f"Query {q}" for q in queries}
243
+ _output_manager.query_list(query_dict, language)
244
+
245
+
246
+ def output_extensions(extensions: list[str]) -> None:
247
+ """Output file extensions"""
248
+ _output_manager.output_extensions(extensions)
249
+
250
+
251
+ def output_data(data: Any, format_type: str = "json") -> None:
252
+ """Output structured data"""
253
+ _output_manager.data(data, format_type)