1#![allow(unused_variables)]
2
3use super::{
4 Assignment, Assignments, Association, Condition, Cte, Delete, Expr, ExprAllOp, ExprAnd,
5 ExprAny, ExprAnyOp, ExprArg, ExprBinaryOp, ExprCast, ExprColumn, ExprError, ExprExists,
6 ExprFunc, ExprInList, ExprInSubquery, ExprIntersects, ExprIsNull, ExprIsSuperset,
7 ExprIsVariant, ExprLength, ExprLet, ExprLike, ExprList, ExprMap, ExprMatch, ExprNot, ExprOr,
8 ExprProject, ExprRecord, ExprReference, ExprSet, ExprSetOp, ExprStartsWith, ExprStmt, Filter,
9 FuncCount, FuncLastInsertId, Insert, InsertTarget, Join, JoinOp, Limit, LimitCursor,
10 LimitOffset, Node, OrderBy, OrderByExpr, Path, Projection, Query, Returning, Select, Source,
11 SourceModel, SourceTable, SourceTableId, Statement, TableDerived, TableFactor, TableRef,
12 TableWithJoins, Type, Update, UpdateTarget, Value, ValueRecord, Values, With,
13};
14
15pub trait Visit {
37 fn visit<N: Node>(&mut self, i: &N)
39 where
40 Self: Sized,
41 {
42 i.visit(self);
43 }
44
45 fn visit_assignment(&mut self, i: &Assignment) {
49 visit_assignment(self, i);
50 }
51
52 fn visit_assignments(&mut self, i: &Assignments) {
56 visit_assignments(self, i);
57 }
58
59 fn visit_association(&mut self, i: &Association) {
63 visit_association(self, i);
64 }
65
66 fn visit_cte(&mut self, i: &Cte) {
70 visit_cte(self, i);
71 }
72
73 fn visit_expr(&mut self, i: &Expr) {
77 visit_expr(self, i);
78 }
79
80 fn visit_expr_and(&mut self, i: &ExprAnd) {
84 visit_expr_and(self, i);
85 }
86
87 fn visit_expr_any(&mut self, i: &ExprAny) {
91 visit_expr_any(self, i);
92 }
93
94 fn visit_expr_arg(&mut self, i: &ExprArg) {
98 visit_expr_arg(self, i);
99 }
100
101 fn visit_expr_any_op(&mut self, i: &ExprAnyOp) {
105 visit_expr_any_op(self, i);
106 }
107
108 fn visit_expr_all_op(&mut self, i: &ExprAllOp) {
112 visit_expr_all_op(self, i);
113 }
114
115 fn visit_expr_binary_op(&mut self, i: &ExprBinaryOp) {
119 visit_expr_binary_op(self, i);
120 }
121
122 fn visit_expr_cast(&mut self, i: &ExprCast) {
126 visit_expr_cast(self, i);
127 }
128
129 fn visit_expr_column(&mut self, i: &ExprColumn) {
133 visit_expr_column(self, i);
134 }
135
136 fn visit_expr_default(&mut self) {
140 visit_expr_default(self);
141 }
142
143 fn visit_expr_error(&mut self, i: &ExprError) {
147 visit_expr_error(self, i);
148 }
149
150 fn visit_expr_exists(&mut self, i: &ExprExists) {
154 visit_expr_exists(self, i);
155 }
156
157 fn visit_expr_func(&mut self, i: &ExprFunc) {
161 visit_expr_func(self, i);
162 }
163
164 fn visit_expr_func_count(&mut self, i: &FuncCount) {
168 visit_expr_func_count(self, i);
169 }
170
171 fn visit_expr_func_last_insert_id(&mut self, i: &FuncLastInsertId) {
175 visit_expr_func_last_insert_id(self, i);
176 }
177
178 fn visit_expr_in_list(&mut self, i: &ExprInList) {
182 visit_expr_in_list(self, i);
183 }
184
185 fn visit_expr_in_subquery(&mut self, i: &ExprInSubquery) {
189 visit_expr_in_subquery(self, i);
190 }
191
192 fn visit_expr_intersects(&mut self, i: &ExprIntersects) {
196 visit_expr_intersects(self, i);
197 }
198
199 fn visit_expr_is_null(&mut self, i: &ExprIsNull) {
203 visit_expr_is_null(self, i);
204 }
205
206 fn visit_expr_is_superset(&mut self, i: &ExprIsSuperset) {
210 visit_expr_is_superset(self, i);
211 }
212
213 fn visit_expr_is_variant(&mut self, i: &ExprIsVariant) {
217 visit_expr_is_variant(self, i);
218 }
219
220 fn visit_expr_length(&mut self, i: &ExprLength) {
224 visit_expr_length(self, i);
225 }
226
227 fn visit_expr_let(&mut self, i: &ExprLet) {
231 visit_expr_let(self, i);
232 }
233
234 fn visit_expr_like(&mut self, i: &ExprLike) {
238 visit_expr_like(self, i);
239 }
240
241 fn visit_expr_map(&mut self, i: &ExprMap) {
245 visit_expr_map(self, i);
246 }
247
248 fn visit_expr_match(&mut self, i: &ExprMatch) {
252 visit_expr_match(self, i);
253 }
254
255 fn visit_expr_not(&mut self, i: &ExprNot) {
259 visit_expr_not(self, i);
260 }
261
262 fn visit_expr_or(&mut self, i: &ExprOr) {
266 visit_expr_or(self, i);
267 }
268
269 fn visit_expr_list(&mut self, i: &ExprList) {
273 visit_expr_list(self, i);
274 }
275
276 fn visit_expr_record(&mut self, i: &ExprRecord) {
280 visit_expr_record(self, i);
281 }
282
283 fn visit_expr_reference(&mut self, i: &ExprReference) {
287 visit_expr_reference(self, i);
288 }
289
290 fn visit_expr_set(&mut self, i: &ExprSet) {
294 visit_expr_set(self, i);
295 }
296
297 fn visit_expr_set_op(&mut self, i: &ExprSetOp) {
301 visit_expr_set_op(self, i);
302 }
303
304 fn visit_expr_starts_with(&mut self, i: &ExprStartsWith) {
308 visit_expr_starts_with(self, i);
309 }
310
311 fn visit_expr_stmt(&mut self, i: &ExprStmt) {
315 visit_expr_stmt(self, i);
316 }
317
318 fn visit_filter(&mut self, i: &Filter) {
322 visit_filter(self, i);
323 }
324
325 fn visit_condition(&mut self, i: &Condition) {
329 visit_condition(self, i);
330 }
331
332 fn visit_expr_project(&mut self, i: &ExprProject) {
336 visit_expr_project(self, i);
337 }
338
339 fn visit_insert_target(&mut self, i: &InsertTarget) {
343 visit_insert_target(self, i);
344 }
345
346 fn visit_join(&mut self, i: &Join) {
350 visit_join(self, i);
351 }
352
353 fn visit_limit(&mut self, i: &Limit) {
357 visit_limit(self, i);
358 }
359
360 fn visit_limit_cursor(&mut self, i: &LimitCursor) {
364 visit_limit_cursor(self, i);
365 }
366
367 fn visit_limit_offset(&mut self, i: &LimitOffset) {
371 visit_limit_offset(self, i);
372 }
373
374 fn visit_order_by(&mut self, i: &OrderBy) {
378 visit_order_by(self, i);
379 }
380
381 fn visit_order_by_expr(&mut self, i: &OrderByExpr) {
385 visit_order_by_expr(self, i);
386 }
387
388 fn visit_path(&mut self, i: &Path) {
392 visit_path(self, i);
393 }
394
395 fn visit_projection(&mut self, i: &Projection) {
399 visit_projection(self, i);
400 }
401
402 fn visit_returning(&mut self, i: &Returning) {
406 visit_returning(self, i);
407 }
408
409 fn visit_source(&mut self, i: &Source) {
413 visit_source(self, i);
414 }
415
416 fn visit_source_model(&mut self, i: &SourceModel) {
420 visit_source_model(self, i);
421 }
422
423 fn visit_source_table(&mut self, i: &SourceTable) {
427 visit_source_table(self, i);
428 }
429
430 fn visit_source_table_id(&mut self, i: &SourceTableId) {
434 visit_source_table_id(self, i);
435 }
436
437 fn visit_stmt(&mut self, i: &Statement) {
441 visit_stmt(self, i);
442 }
443
444 fn visit_stmt_delete(&mut self, i: &Delete) {
448 visit_stmt_delete(self, i);
449 }
450
451 fn visit_stmt_insert(&mut self, i: &Insert) {
455 visit_stmt_insert(self, i);
456 }
457
458 fn visit_stmt_query(&mut self, i: &Query) {
462 visit_stmt_query(self, i);
463 }
464
465 fn visit_stmt_select(&mut self, i: &Select) {
469 visit_stmt_select(self, i);
470 }
471
472 fn visit_stmt_update(&mut self, i: &Update) {
476 visit_stmt_update(self, i);
477 }
478
479 fn visit_table_derived(&mut self, i: &TableDerived) {
483 visit_table_derived(self, i);
484 }
485
486 fn visit_table_ref(&mut self, i: &TableRef) {
490 visit_table_ref(self, i);
491 }
492
493 fn visit_table_factor(&mut self, i: &TableFactor) {
497 visit_table_factor(self, i);
498 }
499
500 fn visit_table_with_joins(&mut self, i: &TableWithJoins) {
504 visit_table_with_joins(self, i);
505 }
506
507 fn visit_type(&mut self, i: &Type) {
511 visit_type(self, i);
512 }
513
514 fn visit_update_target(&mut self, i: &UpdateTarget) {
518 visit_update_target(self, i);
519 }
520
521 fn visit_value(&mut self, i: &Value) {
525 visit_value(self, i);
526 }
527
528 fn visit_value_record(&mut self, i: &ValueRecord) {
532 visit_value_record(self, i);
533 }
534
535 fn visit_values(&mut self, i: &Values) {
539 visit_values(self, i);
540 }
541
542 fn visit_with(&mut self, i: &With) {
546 visit_with(self, i);
547 }
548}
549
550impl<V: Visit> Visit for &mut V {
551 fn visit_assignment(&mut self, i: &Assignment) {
552 Visit::visit_assignment(&mut **self, i);
553 }
554
555 fn visit_assignments(&mut self, i: &Assignments) {
556 Visit::visit_assignments(&mut **self, i);
557 }
558
559 fn visit_association(&mut self, i: &Association) {
560 Visit::visit_association(&mut **self, i);
561 }
562
563 fn visit_cte(&mut self, i: &Cte) {
564 Visit::visit_cte(&mut **self, i);
565 }
566
567 fn visit_expr(&mut self, i: &Expr) {
568 Visit::visit_expr(&mut **self, i);
569 }
570
571 fn visit_expr_and(&mut self, i: &ExprAnd) {
572 Visit::visit_expr_and(&mut **self, i);
573 }
574
575 fn visit_expr_arg(&mut self, i: &ExprArg) {
576 Visit::visit_expr_arg(&mut **self, i);
577 }
578
579 fn visit_expr_any_op(&mut self, i: &ExprAnyOp) {
580 Visit::visit_expr_any_op(&mut **self, i);
581 }
582
583 fn visit_expr_all_op(&mut self, i: &ExprAllOp) {
584 Visit::visit_expr_all_op(&mut **self, i);
585 }
586
587 fn visit_expr_binary_op(&mut self, i: &ExprBinaryOp) {
588 Visit::visit_expr_binary_op(&mut **self, i);
589 }
590
591 fn visit_expr_cast(&mut self, i: &ExprCast) {
592 Visit::visit_expr_cast(&mut **self, i);
593 }
594
595 fn visit_expr_column(&mut self, i: &ExprColumn) {
596 Visit::visit_expr_column(&mut **self, i);
597 }
598
599 fn visit_expr_default(&mut self) {
600 Visit::visit_expr_default(&mut **self);
601 }
602
603 fn visit_expr_error(&mut self, i: &ExprError) {
604 Visit::visit_expr_error(&mut **self, i);
605 }
606
607 fn visit_expr_exists(&mut self, i: &ExprExists) {
608 Visit::visit_expr_exists(&mut **self, i);
609 }
610
611 fn visit_expr_func(&mut self, i: &ExprFunc) {
612 Visit::visit_expr_func(&mut **self, i);
613 }
614
615 fn visit_expr_func_count(&mut self, i: &FuncCount) {
616 Visit::visit_expr_func_count(&mut **self, i);
617 }
618
619 fn visit_expr_in_list(&mut self, i: &ExprInList) {
620 Visit::visit_expr_in_list(&mut **self, i);
621 }
622
623 fn visit_expr_in_subquery(&mut self, i: &ExprInSubquery) {
624 Visit::visit_expr_in_subquery(&mut **self, i);
625 }
626
627 fn visit_expr_intersects(&mut self, i: &ExprIntersects) {
628 Visit::visit_expr_intersects(&mut **self, i);
629 }
630
631 fn visit_expr_is_null(&mut self, i: &ExprIsNull) {
632 Visit::visit_expr_is_null(&mut **self, i);
633 }
634
635 fn visit_expr_is_superset(&mut self, i: &ExprIsSuperset) {
636 Visit::visit_expr_is_superset(&mut **self, i);
637 }
638
639 fn visit_expr_is_variant(&mut self, i: &ExprIsVariant) {
640 Visit::visit_expr_is_variant(&mut **self, i);
641 }
642
643 fn visit_expr_length(&mut self, i: &ExprLength) {
644 Visit::visit_expr_length(&mut **self, i);
645 }
646
647 fn visit_expr_let(&mut self, i: &ExprLet) {
648 Visit::visit_expr_let(&mut **self, i);
649 }
650
651 fn visit_expr_like(&mut self, i: &ExprLike) {
652 Visit::visit_expr_like(&mut **self, i);
653 }
654
655 fn visit_expr_map(&mut self, i: &ExprMap) {
656 Visit::visit_expr_map(&mut **self, i);
657 }
658
659 fn visit_expr_match(&mut self, i: &ExprMatch) {
660 Visit::visit_expr_match(&mut **self, i);
661 }
662
663 fn visit_expr_not(&mut self, i: &ExprNot) {
664 Visit::visit_expr_not(&mut **self, i);
665 }
666
667 fn visit_expr_or(&mut self, i: &ExprOr) {
668 Visit::visit_expr_or(&mut **self, i);
669 }
670
671 fn visit_expr_list(&mut self, i: &ExprList) {
672 Visit::visit_expr_list(&mut **self, i);
673 }
674
675 fn visit_expr_record(&mut self, i: &ExprRecord) {
676 Visit::visit_expr_record(&mut **self, i);
677 }
678
679 fn visit_expr_reference(&mut self, i: &ExprReference) {
680 Visit::visit_expr_reference(&mut **self, i);
681 }
682
683 fn visit_expr_set(&mut self, i: &ExprSet) {
684 Visit::visit_expr_set(&mut **self, i);
685 }
686
687 fn visit_expr_set_op(&mut self, i: &ExprSetOp) {
688 Visit::visit_expr_set_op(&mut **self, i);
689 }
690
691 fn visit_expr_starts_with(&mut self, i: &ExprStartsWith) {
692 Visit::visit_expr_starts_with(&mut **self, i);
693 }
694
695 fn visit_expr_stmt(&mut self, i: &ExprStmt) {
696 Visit::visit_expr_stmt(&mut **self, i);
697 }
698
699 fn visit_filter(&mut self, i: &Filter) {
700 Visit::visit_filter(&mut **self, i);
701 }
702
703 fn visit_condition(&mut self, i: &Condition) {
704 Visit::visit_condition(&mut **self, i);
705 }
706
707 fn visit_expr_project(&mut self, i: &ExprProject) {
708 Visit::visit_expr_project(&mut **self, i);
709 }
710
711 fn visit_insert_target(&mut self, i: &InsertTarget) {
712 Visit::visit_insert_target(&mut **self, i);
713 }
714
715 fn visit_join(&mut self, i: &Join) {
716 Visit::visit_join(&mut **self, i);
717 }
718
719 fn visit_limit(&mut self, i: &Limit) {
720 Visit::visit_limit(&mut **self, i);
721 }
722
723 fn visit_limit_cursor(&mut self, i: &LimitCursor) {
724 Visit::visit_limit_cursor(&mut **self, i);
725 }
726
727 fn visit_limit_offset(&mut self, i: &LimitOffset) {
728 Visit::visit_limit_offset(&mut **self, i);
729 }
730
731 fn visit_order_by(&mut self, i: &OrderBy) {
732 Visit::visit_order_by(&mut **self, i);
733 }
734
735 fn visit_order_by_expr(&mut self, i: &OrderByExpr) {
736 Visit::visit_order_by_expr(&mut **self, i);
737 }
738
739 fn visit_path(&mut self, i: &Path) {
740 Visit::visit_path(&mut **self, i);
741 }
742
743 fn visit_projection(&mut self, i: &Projection) {
744 Visit::visit_projection(&mut **self, i);
745 }
746
747 fn visit_returning(&mut self, i: &Returning) {
748 Visit::visit_returning(&mut **self, i);
749 }
750
751 fn visit_source(&mut self, i: &Source) {
752 Visit::visit_source(&mut **self, i);
753 }
754
755 fn visit_source_model(&mut self, i: &SourceModel) {
756 Visit::visit_source_model(&mut **self, i);
757 }
758
759 fn visit_source_table(&mut self, i: &SourceTable) {
760 Visit::visit_source_table(&mut **self, i);
761 }
762
763 fn visit_source_table_id(&mut self, i: &SourceTableId) {
764 Visit::visit_source_table_id(&mut **self, i);
765 }
766
767 fn visit_stmt(&mut self, i: &Statement) {
768 Visit::visit_stmt(&mut **self, i);
769 }
770
771 fn visit_stmt_delete(&mut self, i: &Delete) {
772 Visit::visit_stmt_delete(&mut **self, i);
773 }
774
775 fn visit_stmt_insert(&mut self, i: &Insert) {
776 Visit::visit_stmt_insert(&mut **self, i);
777 }
778
779 fn visit_stmt_query(&mut self, i: &Query) {
780 Visit::visit_stmt_query(&mut **self, i);
781 }
782
783 fn visit_stmt_select(&mut self, i: &Select) {
784 Visit::visit_stmt_select(&mut **self, i);
785 }
786
787 fn visit_stmt_update(&mut self, i: &Update) {
788 Visit::visit_stmt_update(&mut **self, i);
789 }
790
791 fn visit_table_derived(&mut self, i: &TableDerived) {
792 Visit::visit_table_derived(&mut **self, i);
793 }
794
795 fn visit_table_ref(&mut self, i: &TableRef) {
796 Visit::visit_table_ref(&mut **self, i);
797 }
798
799 fn visit_table_factor(&mut self, i: &TableFactor) {
800 Visit::visit_table_factor(&mut **self, i);
801 }
802
803 fn visit_table_with_joins(&mut self, i: &TableWithJoins) {
804 Visit::visit_table_with_joins(&mut **self, i);
805 }
806
807 fn visit_type(&mut self, i: &Type) {
808 Visit::visit_type(&mut **self, i);
809 }
810
811 fn visit_update_target(&mut self, i: &UpdateTarget) {
812 Visit::visit_update_target(&mut **self, i);
813 }
814
815 fn visit_value(&mut self, i: &Value) {
816 Visit::visit_value(&mut **self, i);
817 }
818
819 fn visit_value_record(&mut self, i: &ValueRecord) {
820 Visit::visit_value_record(&mut **self, i);
821 }
822
823 fn visit_values(&mut self, i: &Values) {
824 Visit::visit_values(&mut **self, i);
825 }
826
827 fn visit_with(&mut self, i: &With) {
828 Visit::visit_with(&mut **self, i);
829 }
830}
831
832pub fn visit_assignment<V>(v: &mut V, node: &Assignment)
834where
835 V: Visit + ?Sized,
836{
837 match node {
838 Assignment::Set(expr)
839 | Assignment::Insert(expr)
840 | Assignment::Remove(expr)
841 | Assignment::Append(expr)
842 | Assignment::RemoveAt(expr) => {
843 v.visit_expr(expr);
844 }
845 Assignment::Pop => {}
846 Assignment::Batch(entries) => {
847 for entry in entries {
848 visit_assignment(v, entry);
849 }
850 }
851 }
852}
853
854pub fn visit_assignments<V>(v: &mut V, node: &Assignments)
856where
857 V: Visit + ?Sized,
858{
859 for (_, assignment) in node.iter() {
860 v.visit_assignment(assignment);
861 }
862}
863
864pub fn visit_association<V>(v: &mut V, node: &Association)
866where
867 V: Visit + ?Sized,
868{
869 v.visit_stmt_query(&node.source);
870}
871
872pub fn visit_cte<V>(v: &mut V, node: &Cte)
874where
875 V: Visit + ?Sized,
876{
877 v.visit_stmt_query(&node.query);
878}
879
880pub fn visit_expr<V>(v: &mut V, node: &Expr)
882where
883 V: Visit + ?Sized,
884{
885 match node {
886 Expr::AllOp(expr) => v.visit_expr_all_op(expr),
887 Expr::And(expr) => v.visit_expr_and(expr),
888 Expr::Any(expr) => v.visit_expr_any(expr),
889 Expr::AnyOp(expr) => v.visit_expr_any_op(expr),
890 Expr::Arg(expr) => v.visit_expr_arg(expr),
891 Expr::BinaryOp(expr) => v.visit_expr_binary_op(expr),
892 Expr::Cast(expr) => v.visit_expr_cast(expr),
893 Expr::Default => v.visit_expr_default(),
894 Expr::Error(expr) => v.visit_expr_error(expr),
895 Expr::Exists(expr) => v.visit_expr_exists(expr),
896 Expr::Func(expr) => v.visit_expr_func(expr),
897 Expr::Ident(_) => {}
898 Expr::InList(expr) => v.visit_expr_in_list(expr),
899 Expr::InSubquery(expr) => v.visit_expr_in_subquery(expr),
900 Expr::Intersects(expr) => v.visit_expr_intersects(expr),
901 Expr::IsNull(expr) => v.visit_expr_is_null(expr),
902 Expr::IsSuperset(expr) => v.visit_expr_is_superset(expr),
903 Expr::IsVariant(expr) => v.visit_expr_is_variant(expr),
904 Expr::Length(expr) => v.visit_expr_length(expr),
905 Expr::Let(expr) => v.visit_expr_let(expr),
906 Expr::Like(expr) => v.visit_expr_like(expr),
907 Expr::Map(expr) => v.visit_expr_map(expr),
908 Expr::Match(expr) => v.visit_expr_match(expr),
909 Expr::Not(expr) => v.visit_expr_not(expr),
910 Expr::Or(expr) => v.visit_expr_or(expr),
911 Expr::Project(expr) => v.visit_expr_project(expr),
912 Expr::Record(expr) => v.visit_expr_record(expr),
913 Expr::Reference(expr) => v.visit_expr_reference(expr),
914 Expr::List(expr) => v.visit_expr_list(expr),
915 Expr::StartsWith(expr) => v.visit_expr_starts_with(expr),
916 Expr::Stmt(expr) => v.visit_expr_stmt(expr),
917 Expr::Value(expr) => v.visit_value(expr),
918 }
919}
920
921pub fn visit_expr_and<V>(v: &mut V, node: &ExprAnd)
923where
924 V: Visit + ?Sized,
925{
926 for expr in node {
927 v.visit_expr(expr);
928 }
929}
930
931pub fn visit_expr_any<V>(v: &mut V, node: &ExprAny)
933where
934 V: Visit + ?Sized,
935{
936 v.visit_expr(&node.expr);
937}
938
939pub fn visit_expr_arg<V>(v: &mut V, node: &ExprArg)
941where
942 V: Visit + ?Sized,
943{
944}
945
946pub fn visit_expr_binary_op<V>(v: &mut V, node: &ExprBinaryOp)
948where
949 V: Visit + ?Sized,
950{
951 v.visit_expr(&node.lhs);
952 v.visit_expr(&node.rhs);
953}
954
955pub fn visit_expr_any_op<V>(v: &mut V, node: &ExprAnyOp)
957where
958 V: Visit + ?Sized,
959{
960 v.visit_expr(&node.lhs);
961 v.visit_expr(&node.rhs);
962}
963
964pub fn visit_expr_all_op<V>(v: &mut V, node: &ExprAllOp)
966where
967 V: Visit + ?Sized,
968{
969 v.visit_expr(&node.lhs);
970 v.visit_expr(&node.rhs);
971}
972
973pub fn visit_expr_cast<V>(v: &mut V, node: &ExprCast)
975where
976 V: Visit + ?Sized,
977{
978 v.visit_expr(&node.expr);
979 v.visit_type(&node.ty);
980}
981
982pub fn visit_expr_column<V>(v: &mut V, node: &ExprColumn)
984where
985 V: Visit + ?Sized,
986{
987}
988
989pub fn visit_expr_default<V>(v: &mut V)
991where
992 V: Visit + ?Sized,
993{
994}
995
996pub fn visit_expr_error<V>(v: &mut V, node: &ExprError)
998where
999 V: Visit + ?Sized,
1000{
1001 }
1003
1004pub fn visit_expr_exists<V>(v: &mut V, node: &ExprExists)
1006where
1007 V: Visit + ?Sized,
1008{
1009 v.visit_stmt_query(&node.subquery);
1010}
1011
1012pub fn visit_expr_func<V>(v: &mut V, node: &ExprFunc)
1014where
1015 V: Visit + ?Sized,
1016{
1017 match node {
1018 ExprFunc::Count(func) => v.visit_expr_func_count(func),
1019 ExprFunc::LastInsertId(func) => v.visit_expr_func_last_insert_id(func),
1020 }
1021}
1022
1023pub fn visit_expr_func_count<V>(v: &mut V, node: &FuncCount)
1025where
1026 V: Visit + ?Sized,
1027{
1028 if let Some(expr) = &node.arg {
1029 v.visit_expr(expr);
1030 }
1031
1032 if let Some(expr) = &node.filter {
1033 v.visit_expr(expr);
1034 }
1035}
1036
1037pub fn visit_expr_func_last_insert_id<V>(_v: &mut V, _node: &FuncLastInsertId)
1039where
1040 V: Visit + ?Sized,
1041{
1042 }
1044
1045pub fn visit_expr_in_list<V>(v: &mut V, node: &ExprInList)
1047where
1048 V: Visit + ?Sized,
1049{
1050 v.visit_expr(&node.expr);
1051 v.visit_expr(&node.list);
1052}
1053
1054pub fn visit_expr_in_subquery<V>(v: &mut V, node: &ExprInSubquery)
1056where
1057 V: Visit + ?Sized,
1058{
1059 v.visit_expr(&node.expr);
1060 v.visit_stmt_query(&node.query);
1061}
1062
1063pub fn visit_expr_intersects<V>(v: &mut V, node: &ExprIntersects)
1065where
1066 V: Visit + ?Sized,
1067{
1068 v.visit_expr(&node.lhs);
1069 v.visit_expr(&node.rhs);
1070}
1071
1072pub fn visit_expr_is_null<V>(v: &mut V, node: &ExprIsNull)
1074where
1075 V: Visit + ?Sized,
1076{
1077 v.visit_expr(&node.expr);
1078}
1079
1080pub fn visit_expr_is_superset<V>(v: &mut V, node: &ExprIsSuperset)
1082where
1083 V: Visit + ?Sized,
1084{
1085 v.visit_expr(&node.lhs);
1086 v.visit_expr(&node.rhs);
1087}
1088
1089pub fn visit_expr_length<V>(v: &mut V, node: &ExprLength)
1091where
1092 V: Visit + ?Sized,
1093{
1094 v.visit_expr(&node.expr);
1095}
1096
1097pub fn visit_expr_is_variant<V>(v: &mut V, node: &ExprIsVariant)
1099where
1100 V: Visit + ?Sized,
1101{
1102 v.visit_expr(&node.expr);
1103}
1104
1105pub fn visit_expr_let<V>(v: &mut V, node: &ExprLet)
1107where
1108 V: Visit + ?Sized,
1109{
1110 for binding in &node.bindings {
1111 v.visit_expr(binding);
1112 }
1113 v.visit_expr(&node.body);
1114}
1115
1116pub fn visit_expr_like<V>(v: &mut V, node: &ExprLike)
1118where
1119 V: Visit + ?Sized,
1120{
1121 v.visit_expr(&node.expr);
1122 v.visit_expr(&node.pattern);
1123}
1124
1125pub fn visit_expr_map<V>(v: &mut V, node: &ExprMap)
1127where
1128 V: Visit + ?Sized,
1129{
1130 v.visit_expr(&node.base);
1131 v.visit_expr(&node.map);
1132}
1133
1134pub fn visit_expr_match<V>(v: &mut V, node: &ExprMatch)
1136where
1137 V: Visit + ?Sized,
1138{
1139 v.visit_expr(&node.subject);
1140 for arm in &node.arms {
1141 v.visit_expr(&arm.expr);
1142 }
1143 v.visit_expr(&node.else_expr);
1144}
1145
1146pub fn visit_expr_not<V>(v: &mut V, node: &ExprNot)
1148where
1149 V: Visit + ?Sized,
1150{
1151 v.visit_expr(&node.expr);
1152}
1153
1154pub fn visit_expr_or<V>(v: &mut V, node: &ExprOr)
1156where
1157 V: Visit + ?Sized,
1158{
1159 for expr in node {
1160 v.visit_expr(expr);
1161 }
1162}
1163
1164pub fn visit_expr_list<V>(v: &mut V, node: &ExprList)
1166where
1167 V: Visit + ?Sized,
1168{
1169 for expr in &node.items {
1170 v.visit_expr(expr);
1171 }
1172}
1173
1174pub fn visit_expr_record<V>(v: &mut V, node: &ExprRecord)
1176where
1177 V: Visit + ?Sized,
1178{
1179 for expr in &**node {
1180 v.visit_expr(expr);
1181 }
1182}
1183
1184pub fn visit_expr_reference<V>(v: &mut V, node: &ExprReference)
1186where
1187 V: Visit + ?Sized,
1188{
1189 match node {
1190 ExprReference::Model { .. } => {}
1191 ExprReference::Field { .. } => {}
1192 ExprReference::Column(expr_column) => v.visit_expr_column(expr_column),
1193 }
1194}
1195
1196pub fn visit_expr_set<V>(v: &mut V, node: &ExprSet)
1198where
1199 V: Visit + ?Sized,
1200{
1201 match node {
1202 ExprSet::Select(expr) => v.visit_stmt_select(expr),
1203 ExprSet::SetOp(expr) => v.visit_expr_set_op(expr),
1204 ExprSet::Update(expr) => v.visit_stmt_update(expr),
1205 ExprSet::Values(expr) => v.visit_values(expr),
1206 ExprSet::Insert(expr) => v.visit_stmt_insert(expr),
1207 }
1208}
1209
1210pub fn visit_expr_set_op<V>(v: &mut V, node: &ExprSetOp)
1212where
1213 V: Visit + ?Sized,
1214{
1215 for operand in &node.operands {
1216 v.visit_expr_set(operand);
1217 }
1218}
1219
1220pub fn visit_expr_starts_with<V>(v: &mut V, node: &ExprStartsWith)
1222where
1223 V: Visit + ?Sized,
1224{
1225 v.visit_expr(&node.expr);
1226 v.visit_expr(&node.prefix);
1227}
1228
1229pub fn visit_expr_stmt<V>(v: &mut V, node: &ExprStmt)
1231where
1232 V: Visit + ?Sized,
1233{
1234 v.visit_stmt(&node.stmt);
1235}
1236
1237pub fn visit_expr_project<V>(v: &mut V, node: &ExprProject)
1239where
1240 V: Visit + ?Sized,
1241{
1242 v.visit_expr(&node.base);
1243 v.visit_projection(&node.projection);
1244}
1245
1246pub fn visit_filter<V>(v: &mut V, node: &Filter)
1248where
1249 V: Visit + ?Sized,
1250{
1251 if let Some(expr) = &node.expr {
1252 v.visit_expr(expr);
1253 }
1254}
1255
1256pub fn visit_condition<V>(v: &mut V, node: &Condition)
1258where
1259 V: Visit + ?Sized,
1260{
1261 if let Some(expr) = &node.expr {
1262 v.visit_expr(expr);
1263 }
1264}
1265
1266pub fn visit_insert_target<V>(v: &mut V, node: &InsertTarget)
1268where
1269 V: Visit + ?Sized,
1270{
1271 if let InsertTarget::Scope(stmt) = node {
1272 v.visit_stmt_query(stmt);
1273 }
1274}
1275
1276pub fn visit_join<V>(v: &mut V, node: &Join)
1278where
1279 V: Visit + ?Sized,
1280{
1281 v.visit_source_table_id(&node.table);
1282 match &node.constraint {
1283 JoinOp::Inner(expr) | JoinOp::Left(expr) => v.visit_expr(expr),
1284 }
1285}
1286
1287pub fn visit_limit<V>(v: &mut V, node: &Limit)
1289where
1290 V: Visit + ?Sized,
1291{
1292 match node {
1293 Limit::Cursor(cursor) => v.visit_limit_cursor(cursor),
1294 Limit::Offset(offset) => v.visit_limit_offset(offset),
1295 }
1296}
1297
1298pub fn visit_limit_cursor<V>(v: &mut V, node: &LimitCursor)
1300where
1301 V: Visit + ?Sized,
1302{
1303 v.visit_expr(&node.page_size);
1304 if let Some(after) = &node.after {
1305 v.visit_expr(after);
1306 }
1307}
1308
1309pub fn visit_limit_offset<V>(v: &mut V, node: &LimitOffset)
1311where
1312 V: Visit + ?Sized,
1313{
1314 v.visit_expr(&node.limit);
1315 if let Some(offset) = &node.offset {
1316 v.visit_expr(offset);
1317 }
1318}
1319
1320pub fn visit_order_by<V>(v: &mut V, node: &OrderBy)
1322where
1323 V: Visit + ?Sized,
1324{
1325 for expr in &node.exprs {
1326 v.visit_order_by_expr(expr);
1327 }
1328}
1329
1330pub fn visit_order_by_expr<V>(v: &mut V, node: &OrderByExpr)
1332where
1333 V: Visit + ?Sized,
1334{
1335 v.visit_expr(&node.expr);
1336}
1337
1338pub fn visit_path<V>(v: &mut V, node: &Path)
1340where
1341 V: Visit + ?Sized,
1342{
1343 v.visit_projection(&node.projection);
1344}
1345
1346pub fn visit_projection<V>(v: &mut V, node: &Projection)
1348where
1349 V: Visit + ?Sized,
1350{
1351}
1352
1353pub fn visit_returning<V>(v: &mut V, node: &Returning)
1355where
1356 V: Visit + ?Sized,
1357{
1358 match node {
1359 Returning::Model { include } => {
1360 for path in include {
1361 v.visit_path(path);
1362 }
1363 }
1364 Returning::Changed => {}
1365 Returning::Project(expr) => v.visit_expr(expr),
1366 Returning::Expr(expr) => v.visit_expr(expr),
1367 }
1368}
1369
1370pub fn visit_source<V>(v: &mut V, node: &Source)
1372where
1373 V: Visit + ?Sized,
1374{
1375 match node {
1376 Source::Model(source_model) => v.visit_source_model(source_model),
1377 Source::Table(source_table) => v.visit_source_table(source_table),
1378 }
1379}
1380
1381pub fn visit_source_model<V>(v: &mut V, node: &SourceModel)
1383where
1384 V: Visit + ?Sized,
1385{
1386 if let Some(association) = &node.via {
1387 v.visit_association(association);
1388 }
1389}
1390
1391pub fn visit_source_table<V>(v: &mut V, node: &SourceTable)
1393where
1394 V: Visit + ?Sized,
1395{
1396 for table_ref in &node.tables {
1397 v.visit_table_ref(table_ref);
1398 }
1399 for table_with_joins in &node.from {
1400 v.visit_table_with_joins(table_with_joins);
1401 }
1402}
1403
1404pub fn visit_source_table_id<V>(v: &mut V, node: &SourceTableId)
1406where
1407 V: Visit + ?Sized,
1408{
1409 }
1411
1412pub fn visit_table_factor<V>(v: &mut V, node: &TableFactor)
1414where
1415 V: Visit + ?Sized,
1416{
1417 match node {
1418 TableFactor::Table(table_id) => v.visit_source_table_id(table_id),
1419 }
1420}
1421
1422pub fn visit_stmt<V>(v: &mut V, node: &Statement)
1424where
1425 V: Visit + ?Sized,
1426{
1427 match node {
1428 Statement::Delete(stmt) => v.visit_stmt_delete(stmt),
1429 Statement::Insert(stmt) => v.visit_stmt_insert(stmt),
1430 Statement::Query(stmt) => v.visit_stmt_query(stmt),
1431 Statement::Update(stmt) => v.visit_stmt_update(stmt),
1432 }
1433}
1434
1435pub fn visit_stmt_delete<V>(v: &mut V, node: &Delete)
1437where
1438 V: Visit + ?Sized,
1439{
1440 v.visit_source(&node.from);
1441 v.visit_filter(&node.filter);
1442 v.visit_condition(&node.condition);
1443
1444 if let Some(returning) = &node.returning {
1445 v.visit_returning(returning);
1446 }
1447}
1448
1449pub fn visit_stmt_insert<V>(v: &mut V, node: &Insert)
1451where
1452 V: Visit + ?Sized,
1453{
1454 if let InsertTarget::Scope(scope) = &node.target {
1455 v.visit_stmt_query(scope);
1456 }
1457 v.visit_stmt_query(&node.source);
1458
1459 if let Some(returning) = &node.returning {
1460 v.visit_returning(returning);
1461 }
1462}
1463
1464pub fn visit_stmt_query<V>(v: &mut V, node: &Query)
1466where
1467 V: Visit + ?Sized,
1468{
1469 if let Some(with) = &node.with {
1470 v.visit_with(with);
1471 }
1472
1473 v.visit_expr_set(&node.body);
1474
1475 if let Some(order_by) = &node.order_by {
1476 v.visit_order_by(order_by);
1477 }
1478
1479 if let Some(limit) = &node.limit {
1480 v.visit_limit(limit);
1481 }
1482}
1483
1484pub fn visit_stmt_select<V>(v: &mut V, node: &Select)
1486where
1487 V: Visit + ?Sized,
1488{
1489 v.visit_source(&node.source);
1490 v.visit_filter(&node.filter);
1491 v.visit_returning(&node.returning);
1492}
1493
1494pub fn visit_stmt_update<V>(v: &mut V, node: &Update)
1496where
1497 V: Visit + ?Sized,
1498{
1499 v.visit_update_target(&node.target);
1500 v.visit_assignments(&node.assignments);
1501 v.visit_filter(&node.filter);
1502 v.visit_condition(&node.condition);
1503}
1504
1505pub fn visit_table_derived<V>(v: &mut V, node: &TableDerived)
1507where
1508 V: Visit + ?Sized,
1509{
1510 v.visit_stmt_query(&node.subquery);
1511}
1512
1513pub fn visit_table_ref<V>(v: &mut V, node: &TableRef)
1515where
1516 V: Visit + ?Sized,
1517{
1518 match node {
1519 TableRef::Cte { .. } => {}
1520 TableRef::Derived(table_derived) => v.visit_table_derived(table_derived),
1521 TableRef::Table(_) => {}
1522 TableRef::Arg(expr_arg) => v.visit_expr_arg(expr_arg),
1523 }
1524}
1525
1526pub fn visit_table_with_joins<V>(v: &mut V, node: &TableWithJoins)
1528where
1529 V: Visit + ?Sized,
1530{
1531 v.visit_table_factor(&node.relation);
1532 for join in &node.joins {
1533 v.visit_join(join);
1534 }
1535}
1536
1537pub fn visit_type<V>(v: &mut V, node: &Type)
1539where
1540 V: Visit + ?Sized,
1541{
1542 }
1544
1545pub fn visit_update_target<V>(v: &mut V, node: &UpdateTarget)
1547where
1548 V: Visit + ?Sized,
1549{
1550 if let UpdateTarget::Query(query) = node {
1551 v.visit_stmt_query(query)
1552 }
1553}
1554
1555pub fn visit_value<V>(v: &mut V, node: &Value)
1557where
1558 V: Visit + ?Sized,
1559{
1560 if let Value::Record(node) = node {
1561 v.visit_value_record(node)
1562 }
1563}
1564
1565pub fn visit_value_record<V>(v: &mut V, node: &ValueRecord)
1567where
1568 V: Visit + ?Sized,
1569{
1570 for value in node.iter() {
1571 v.visit_value(value);
1572 }
1573}
1574
1575pub fn visit_values<V>(v: &mut V, node: &Values)
1577where
1578 V: Visit + ?Sized,
1579{
1580 for expr in &node.rows {
1581 v.visit_expr(expr);
1582 }
1583}
1584
1585pub fn visit_with<V>(v: &mut V, node: &With)
1587where
1588 V: Visit + ?Sized,
1589{
1590 for cte in &node.ctes {
1591 v.visit_cte(cte);
1592 }
1593}
1594
1595pub fn for_each_expr<F>(node: &impl Node, f: F)
1600where
1601 F: FnMut(&Expr),
1602{
1603 struct ForEach<F> {
1604 f: F,
1605 }
1606
1607 impl<F> Visit for ForEach<F>
1608 where
1609 F: FnMut(&Expr),
1610 {
1611 fn visit_expr(&mut self, node: &Expr) {
1612 visit_expr(self, node);
1613 (self.f)(node);
1614 }
1615 }
1616
1617 node.visit(ForEach { f });
1618}