diff options
Diffstat (limited to 'SlickEdit')
-rw-r--r-- | SlickEdit/beautifier-profiles.cfg.xml | 551 | ||||
-rw-r--r-- | SlickEdit/color_profiles.cfg.xml | 96 | ||||
-rw-r--r-- | SlickEdit/kdev.e | 3972 | ||||
-rw-r--r-- | SlickEdit/kkeys.e | 427 | ||||
-rw-r--r-- | SlickEdit/lexer-def.cfg.xml | 7 | ||||
-rw-r--r-- | SlickEdit/lexer-kmk-v2.cfg.xml | 147 | ||||
-rw-r--r-- | SlickEdit/lexer-kmk.cfg.xml | 135 | ||||
-rw-r--r-- | SlickEdit/uscheme.ini | 257 | ||||
-rw-r--r-- | SlickEdit/user.vlx | 16 | ||||
-rw-r--r-- | SlickEdit/usrprjtemplates.vpt | 52 | ||||
-rw-r--r-- | SlickEdit/vusr_beautifier.xml | 447 |
11 files changed, 6107 insertions, 0 deletions
diff --git a/SlickEdit/beautifier-profiles.cfg.xml b/SlickEdit/beautifier-profiles.cfg.xml new file mode 100644 index 0000000..6d0fdc7 --- /dev/null +++ b/SlickEdit/beautifier-profiles.cfg.xml @@ -0,0 +1,551 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE Options SYSTEM "http://www.slickedit.com/dtd/vse/14.0/options.dtd"> +<options> + <profile n="language.m.beautifier_profiles.bird's Objective-C Style" version="1"> + <p n="align_lbrace_with_case" v="1"/> + <p n="align_on_assignment_op" v="1"/> + <p n="align_trinary_branches" v="0"/> + <p n="bl_after_end_block_catch" v="0" apply="0"/> + <p n="bl_after_end_block_do" v="0" apply="0"/> + <p n="bl_after_end_block_for" v="0" apply="0"/> + <p n="bl_after_end_block_if" v="0" apply="0"/> + <p n="bl_after_end_block_switch" v="0" apply="0"/> + <p n="bl_after_end_block_while" v="0" apply="0"/> + <p n="bl_after_locals" v="1" apply="0"/> + <p n="bl_after_member_access" v="1" apply="0"/> + <p n="bl_after_start_block_catch" v="0" apply="0"/> + <p n="bl_after_start_block_do" v="0" apply="0"/> + <p n="bl_after_start_block_for" v="0" apply="0"/> + <p n="bl_after_start_block_fun" v="0" apply="0"/> + <p n="bl_after_start_block_if" v="0" apply="0"/> + <p n="bl_after_start_block_switch" v="0" apply="0"/> + <p n="bl_after_start_block_try" v="0" apply="0"/> + <p n="bl_after_start_block_while" v="0" apply="0"/> + <p n="bl_before_case" v="1" apply="0"/> + <p n="bl_before_first_decl" v="0" apply="0"/> + <p n="bl_before_locals" v="1" apply="0"/> + <p n="bl_before_member_access" v="0" apply="0"/> + <p n="bl_between_classes" v="0" apply="0"/> + <p n="bl_between_commented_member_var_decls" v="1" apply="0"/> + <p n="bl_between_different_decls" v="0" apply="0"/> + <p n="bl_between_fun_prototypes" v="1" apply="0"/> + <p n="bl_between_funs" v="0" apply="0"/> + <p n="bl_between_member_classes" v="0" apply="0"/> + <p n="bl_between_member_var_decls" v="0" apply="0"/> + <p n="braceloc_asm" v="1"/> + <p n="braceloc_catch" v="1"/> + <p n="braceloc_class" v="1"/> + <p n="braceloc_do" v="1"/> + <p n="braceloc_enum" v="1"/> + <p n="braceloc_for" v="1"/> + <p n="braceloc_fun" v="1"/> + <p n="braceloc_if" v="1"/> + <p n="braceloc_multiline_cond" v="10"/> + <p n="braceloc_namespace" v="1"/> + <p n="braceloc_struct" v="1"/> + <p n="braceloc_switch" v="1"/> + <p n="braceloc_try" v="1"/> + <p n="braceloc_union" v="1"/> + <p n="braceloc_while" v="1"/> + <p n="dox_bl_after_brief" v="1" apply="0"/> + <p n="dox_bl_between_different_tags" v="1" apply="0"/> + <p n="dox_bl_between_same_tags" v="0" apply="0"/> + <p n="dox_format_pre" v="1" apply="0"/> + <p n="dox_indent_param_desc" v="1" apply="0"/> + <p n="dox_indent_past_param_name" v="0" apply="0"/> + <p n="dox_nl_at_start_and_end" v="1" apply="0"/> + <p n="dox_rm_blank_lines" v="0" apply="0"/> + <p n="indent_case" v="1"/> + <p n="indent_class_body" v="1"/> + <p n="indent_col1_comments" v="0"/> + <p n="indent_comments" v="1"/> + <p n="indent_extern_body" v="0"/> + <p n="indent_first_level" v="1"/> + <p n="indent_from_brace" v="0"/> + <p n="indent_if_of_else_if" v="1" apply="1"/> + <p n="indent_label" v="0"/> + <p n="indent_member_access" v="0"/> + <p n="indent_member_access_relative" v="0"/> + <p n="indent_namespace_body" v="0"/> + <p n="indent_on_return_type_continuation" v="0"/> + <p n="indent_width_case" v="4"/> + <p n="indent_width_continuation" v="4"/> + <p n="indent_width_label" v="1"/> + <p n="indent_width_member_access" v="1"/> + <p n="indent_with_tabs" v="0"/> + <p n="jd_bl_before_tags" v="1" apply="0"/> + <p n="jd_bl_between_different_tags" v="1" apply="0"/> + <p n="jd_bl_between_same_tags" v="0" apply="0"/> + <p n="jd_format_html" v="1" apply="0"/> + <p n="jd_format_pre" v="1" apply="0"/> + <p n="jd_indent_param_desc" v="1" apply="0"/> + <p n="jd_indent_past_param_name" v="1" apply="0"/> + <p n="jd_nl_at_start_and_end" v="1" apply="0"/> + <p n="jd_rm_blank_lines" v="0" apply="0"/> + <p n="justify_member_var_decls" v="0" apply="0"/> + <p n="justify_var_decls" v="0" apply="0"/> + <p n="leave_class_one_line_block" v="1"/> + <p n="leave_multiple_decl" v="1"/> + <p n="leave_multiple_stmt" v="1"/> + <p n="leave_one_line_code_blocks" v="1"/> + <p n="listalign2_expr_parens" v="0"/> + <p n="listalign_fun_call_params" v="2"/> + <p n="max_line_len" v="80" apply="0"/> + <p n="nl_after_case" v="1" apply="0"/> + <p n="nl_after_extern" v="1" apply="1"/> + <p n="nl_before_else" v="1" apply="1"/> + <p n="nl_empty_block" v="0" apply="1"/> + <p n="nl_empty_class_body" v="0" apply="0"/> + <p n="nl_empty_fun_body" v="1" apply="0"/> + <p n="objc_align_meth_call_on_colon" v="1"/> + <p n="objc_align_meth_call_selectors_right" v="1"/> + <p n="objc_align_meth_decl_on_colon" v="1"/> + <p n="objc_indent_width_lambda_body" v="4"/> + <p n="objc_listalign2_meth_call_brackets" v="0"/> + <p n="objc_sp_category_before_lparen" v="1" apply="1"/> + <p n="objc_sp_category_before_rparen" v="1" apply="1"/> + <p n="objc_sp_meth_param_after_rparen" v="0" apply="1"/> + <p n="objc_sp_meth_param_before_lparen" v="0" apply="1"/> + <p n="objc_sp_meth_return_type_after_rparen" v="0" apply="1"/> + <p n="objc_sp_meth_return_type_before_lparen" v="1" apply="1"/> + <p n="objc_sp_property_after_rparen" v="1" apply="1"/> + <p n="objc_sp_property_before_lparen" v="1" apply="1"/> + <p n="objc_sp_protocol_before_lparen" v="1" apply="1"/> + <p n="objc_sp_protocol_before_rparen" v="1" apply="1"/> + <p n="objc_sp_synchronized_after_rparen" v="0" apply="1"/> + <p n="objc_sp_synchronized_before_lparen" v="0" apply="1"/> + <p n="objc_sppad_category_parens" v="0" apply="1"/> + <p n="objc_sppad_meth_param_parens" v="0" apply="1"/> + <p n="objc_sppad_meth_return_type_parens" v="0" apply="1"/> + <p n="objc_sppad_property_parens" v="0" apply="1"/> + <p n="objc_sppad_protocol_parens" v="0" apply="1"/> + <p n="objc_sppad_synchronized_parens" v="0" apply="1"/> + <p n="objc_spstyle_call_selector_colon" v="2" apply="1"/> + <p n="objc_spstyle_decl_selector_colon" v="2" apply="1"/> + <p n="objc_spstyle_dynamic_comma" v="2" apply="1"/> + <p n="objc_spstyle_finally_lbrace" v="3" apply="1"/> + <p n="objc_spstyle_property_comma" v="2" apply="1"/> + <p n="objc_spstyle_property_eq" v="0" apply="1"/> + <p n="objc_spstyle_protocol_comma" v="2" apply="1"/> + <p n="objc_spstyle_synchronized_lbrace" v="3" apply="1"/> + <p n="objc_spstyle_synthesize_comma" v="2" apply="1"/> + <p n="objc_spstyle_synthesize_eq" v="0" apply="1"/> + <p n="oneline_catch" v="0" apply="1"/> + <p n="oneline_dowhile" v="1" apply="1"/> + <p n="oneline_elseif" v="1" apply="1"/> + <p n="oneline_unblocked_else" v="0" apply="1"/> + <p n="oneline_unblocked_statement" v="0" apply="1"/> + <p n="oneline_unblocked_then" v="0" apply="1"/> + <p n="original_tab_size" v="4" apply="0"/> + <p n="pp_indent" v="0"/> + <p n="pp_indent_in_code_block" v="0"/> + <p n="pp_indent_in_header_guard" v="0"/> + <p n="pp_indent_with_code" v="0"/> + <p n="pp_keep_pound_in_col1" v="0"/> + <p n="ra_fun_void_in_empty_param_list" v="1" apply="0"/> + <p n="ra_throw_parens" v="1" apply="0"/> + <p n="rai_return_parens" v="1" apply="0"/> + <p n="require_new_line_after_member_access" v="1"/> + <p n="require_new_line_at_eof" v="1"/> + <p n="rm_dup_spaces" v="0"/> + <p n="rm_return_type_new_lines" v="0"/> + <p n="rm_trailing_spaces" v="1"/> + <p n="sp_array_decl_after_rbracket" v="0" apply="1"/> + <p n="sp_array_decl_before_lbracket" v="0" apply="1"/> + <p n="sp_array_del_before_lbracket" v="0" apply="1"/> + <p n="sp_array_del_rbracket" v="1" apply="1"/> + <p n="sp_array_expr_after_rbracket" v="0" apply="1"/> + <p n="sp_array_expr_before_lbracket" v="0" apply="1"/> + <p n="sp_cast_after_rparen" v="0" apply="1"/> + <p n="sp_cast_before_lparen" v="0" apply="1"/> + <p n="sp_catch_after_rparen" v="1" apply="1"/> + <p n="sp_catch_before_lparen" v="1" apply="1"/> + <p n="sp_cppcast_after_gt" v="0" apply="1"/> + <p n="sp_cppcast_before_lt" v="0" apply="1"/> + <p n="sp_expr_after_rparen" v="0" apply="1"/> + <p n="sp_expr_before_lparen" v="0" apply="1"/> + <p n="sp_for_after_rparen" v="1" apply="1"/> + <p n="sp_for_before_lparen" v="1" apply="1"/> + <p n="sp_fptr_after_rparen" v="0" apply="1"/> + <p n="sp_fptr_before_lparen" v="1" apply="1"/> + <p n="sp_fptr_between_star_and_id" v="1" apply="1"/> + <p n="sp_fun_after_operator" v="0" apply="1"/> + <p n="sp_fun_after_rparen" v="0" apply="1"/> + <p n="sp_fun_before_lparen" v="0" apply="1"/> + <p n="sp_fun_call_after_operator" v="0" apply="1"/> + <p n="sp_fun_call_after_rparen" v="0" apply="1"/> + <p n="sp_fun_call_before_lparen" v="0" apply="1"/> + <p n="sp_fun_call_empty_parens" v="0" apply="1"/> + <p n="sp_fun_empty_parens" v="0" apply="1"/> + <p n="sp_if_after_rparen" v="1" apply="1"/> + <p n="sp_if_before_lparen" v="1" apply="1"/> + <p n="sp_lambda_after_rbracket" v="0" apply="1"/> + <p n="sp_lambda_before_lbracket" v="0" apply="1"/> + <p n="sp_mptr_between_coloncolon_and_star" v="0" apply="1"/> + <p n="sp_new_after_rparen" v="1" apply="1"/> + <p n="sp_new_before_lparen" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_amp" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_id" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_lparen" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_qualifier" v="1" apply="1"/> + <p n="sp_ptr_between_star_and_rparen" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_star" v="0" apply="1"/> + <p n="sp_ptr_between_type_and_star" v="1" apply="1"/> + <p n="sp_ptr_cast_proto_between_type_and_star" v="1" apply="1"/> + <p n="sp_ptr_return_type_between_type_and_star" v="1" apply="1"/> + <p n="sp_ref_between_amp_and_id" v="0" apply="1"/> + <p n="sp_ref_between_amp_and_lparen" v="0" apply="1"/> + <p n="sp_ref_between_amp_and_rparen" v="0" apply="1"/> + <p n="sp_ref_between_type_and_amp" v="1" apply="1"/> + <p n="sp_ref_cast_proto_between_type_and_amp" v="1" apply="1"/> + <p n="sp_ref_return_type_between_type_and_amp" v="1" apply="1"/> + <p n="sp_return_after_rparen" v="0" apply="1"/> + <p n="sp_return_before_lparen" v="1" apply="1"/> + <p n="sp_stmt_after_semicolon" v="1" apply="1"/> + <p n="sp_stmt_before_semicolon" v="0" apply="1"/> + <p n="sp_switch_after_rparen" v="1" apply="1"/> + <p n="sp_switch_before_lparen" v="1" apply="1"/> + <p n="sp_throw_after_rparen" v="0" apply="1"/> + <p n="sp_throw_before_lparen" v="1" apply="1"/> + <p n="sp_tmpl_decl_before_lt" v="0" apply="1"/> + <p n="sp_tmpl_parm_before_lt" v="0" apply="1"/> + <p n="sp_while_after_rparen" v="1" apply="1"/> + <p n="sp_while_before_lparen" v="1" apply="1"/> + <p n="sppad_array_decl_brackets" v="0" apply="1"/> + <p n="sppad_array_del_brackets" v="0" apply="1"/> + <p n="sppad_array_expr_brackets" v="0" apply="1"/> + <p n="sppad_cast_parens" v="0" apply="1"/> + <p n="sppad_catch_parens" v="0" apply="1"/> + <p n="sppad_cppcast_angle_brackets" v="0" apply="1"/> + <p n="sppad_expr_parens" v="0" apply="1"/> + <p n="sppad_for_parens" v="0" apply="1"/> + <p n="sppad_fptr_parens" v="0" apply="1"/> + <p n="sppad_fun_call_parens" v="0" apply="1"/> + <p n="sppad_fun_parens" v="0" apply="1"/> + <p n="sppad_if_parens" v="0" apply="1"/> + <p n="sppad_lambda_braces" v="0" apply="1"/> + <p n="sppad_lambda_brackets" v="0" apply="1"/> + <p n="sppad_new_parens" v="0" apply="1"/> + <p n="sppad_return_parens" v="0" apply="1"/> + <p n="sppad_switch_parens" v="0" apply="1"/> + <p n="sppad_throw_parens" v="0" apply="1"/> + <p n="sppad_tmpl_decl_angle_brackets" v="0" apply="1"/> + <p n="sppad_tmpl_parm_angle_brackets" v="0" apply="1"/> + <p n="sppad_while_parens" v="0" apply="1"/> + <p n="spstyle_catch_lbrace" v="1" apply="1"/> + <p n="spstyle_class_colon" v="3" apply="1"/> + <p n="spstyle_class_comma" v="2" apply="1"/> + <p n="spstyle_class_lbrace" v="1" apply="1"/> + <p n="spstyle_constr_init_list_comma" v="2" apply="1"/> + <p n="spstyle_enum_colon" v="3" apply="1"/> + <p n="spstyle_enum_const_comma" v="2" apply="1"/> + <p n="spstyle_enum_const_eq" v="3" apply="1"/> + <p n="spstyle_enum_lbrace" v="1" apply="1"/> + <p n="spstyle_for_comma" v="2" apply="1"/> + <p n="spstyle_for_lbrace" v="1" apply="0"/> + <p n="spstyle_for_semicolon" v="2" apply="1"/> + <p n="spstyle_fun_call_comma" v="2" apply="1"/> + <p n="spstyle_fun_colon" v="3" apply="1"/> + <p n="spstyle_fun_comma" v="2" apply="1"/> + <p n="spstyle_fun_eq" v="3" apply="1"/> + <p n="spstyle_fun_lbrace" v="3" apply="1"/> + <p n="spstyle_if_lbrace" v="1" apply="1"/> + <p n="spstyle_init_comma" v="2" apply="1"/> + <p n="spstyle_init_list_comma" v="2" apply="1"/> + <p n="spstyle_init_rbrace" v="1" apply="1"/> + <p n="spstyle_member_dot" v="0" apply="1"/> + <p n="spstyle_namespace_lbrace" v="3" apply="1"/> + <p n="spstyle_op_addressof" v="0" apply="1"/> + <p n="spstyle_op_assignment" v="3" apply="1"/> + <p n="spstyle_op_binary" v="3" apply="1"/> + <p n="spstyle_op_bitwise" v="3" apply="1"/> + <p n="spstyle_op_comparison" v="3" apply="1"/> + <p n="spstyle_op_dashgt" v="0" apply="1"/> + <p n="spstyle_op_dashgtstar" v="0" apply="1"/> + <p n="spstyle_op_dereference" v="0" apply="1"/> + <p n="spstyle_op_dotstar" v="0" apply="1"/> + <p n="spstyle_op_logical" v="3" apply="1"/> + <p n="spstyle_op_mult" v="3" apply="1"/> + <p n="spstyle_op_postfix" v="0" apply="1"/> + <p n="spstyle_op_prefix" v="0" apply="1"/> + <p n="spstyle_op_unary" v="0" apply="1"/> + <p n="spstyle_struct_colon" v="3" apply="1"/> + <p n="spstyle_struct_comma" v="2" apply="1"/> + <p n="spstyle_struct_lbrace" v="1" apply="1"/> + <p n="spstyle_switch_lbrace" v="1" apply="1"/> + <p n="spstyle_tmpl_decl_comma" v="2" apply="1"/> + <p n="spstyle_tmpl_decl_eq" v="3" apply="1"/> + <p n="spstyle_tmplparm_comma" v="2" apply="1"/> + <p n="spstyle_try_lbrace" v="3" apply="1"/> + <p n="spstyle_union_before_lbrace" v="1" apply="1"/> + <p n="spstyle_while_lbrace" v="1" apply="1"/> + <p n="syntax_indent" v="4"/> + <p n="tab_size" v="+8"/> + <p n="trailing_comment_col" v="70"/> + <p n="trailing_comment_style" v="2"/> + <p n="xdoc_bl_between_different_tags" v="1" apply="0"/> + <p n="xdoc_bl_between_same_tags" v="0" apply="0"/> + <p n="xdoc_format_pre" v="1" apply="0"/> + <p n="xdoc_nl_after_open_tag" v="1" apply="0"/> + <p n="xdoc_nl_before_close_tag" v="1" apply="0"/> + <p n="xdoc_rm_blank_lines" v="1" apply="0"/> + </profile> + <profile n="language.c.beautifier_profiles.bird's Style" version="1"> + <p n="align_lbrace_with_case" v="1"/> + <p n="align_on_assignment_op" v="1"/> + <p n="align_trinary_branches" v="0"/> + <p n="bl_after_end_block_catch" v="0" apply="0"/> + <p n="bl_after_end_block_do" v="0" apply="0"/> + <p n="bl_after_end_block_for" v="0" apply="0"/> + <p n="bl_after_end_block_if" v="0" apply="0"/> + <p n="bl_after_end_block_switch" v="0" apply="0"/> + <p n="bl_after_end_block_while" v="0" apply="0"/> + <p n="bl_after_locals" v="1" apply="0"/> + <p n="bl_after_member_access" v="1" apply="0"/> + <p n="bl_after_start_block_catch" v="0" apply="0"/> + <p n="bl_after_start_block_do" v="0" apply="0"/> + <p n="bl_after_start_block_for" v="0" apply="0"/> + <p n="bl_after_start_block_fun" v="0" apply="0"/> + <p n="bl_after_start_block_if" v="0" apply="0"/> + <p n="bl_after_start_block_switch" v="0" apply="0"/> + <p n="bl_after_start_block_try" v="0" apply="0"/> + <p n="bl_after_start_block_while" v="0" apply="0"/> + <p n="bl_before_case" v="1" apply="0"/> + <p n="bl_before_first_decl" v="0" apply="0"/> + <p n="bl_before_locals" v="1" apply="0"/> + <p n="bl_before_member_access" v="0" apply="0"/> + <p n="bl_between_classes" v="0" apply="0"/> + <p n="bl_between_commented_member_var_decls" v="1" apply="0"/> + <p n="bl_between_different_decls" v="0" apply="0"/> + <p n="bl_between_fun_prototypes" v="1" apply="0"/> + <p n="bl_between_funs" v="0" apply="0"/> + <p n="bl_between_member_classes" v="0" apply="0"/> + <p n="bl_between_member_var_decls" v="0" apply="0"/> + <p n="braceloc_anon_class" v="1"/> + <p n="braceloc_asm" v="1"/> + <p n="braceloc_catch" v="1"/> + <p n="braceloc_class" v="1"/> + <p n="braceloc_do" v="1"/> + <p n="braceloc_enum" v="1"/> + <p n="braceloc_for" v="1"/> + <p n="braceloc_fun" v="1"/> + <p n="braceloc_if" v="1"/> + <p n="braceloc_multiline_cond" v="10"/> + <p n="braceloc_namespace" v="1"/> + <p n="braceloc_struct" v="1"/> + <p n="braceloc_switch" v="1"/> + <p n="braceloc_try" v="1"/> + <p n="braceloc_union" v="1"/> + <p n="braceloc_while" v="1"/> + <p n="dox_bl_after_brief" v="1" apply="0"/> + <p n="dox_bl_between_different_tags" v="1" apply="0"/> + <p n="dox_bl_between_same_tags" v="0" apply="0"/> + <p n="dox_format_pre" v="1" apply="0"/> + <p n="dox_indent_param_desc" v="1" apply="0"/> + <p n="dox_indent_past_param_name" v="0" apply="0"/> + <p n="dox_nl_at_start_and_end" v="1" apply="0"/> + <p n="dox_rm_blank_lines" v="0" apply="0"/> + <p n="indent_case" v="1"/> + <p n="indent_class_body" v="1"/> + <p n="indent_col1_comments" v="0"/> + <p n="indent_comments" v="1"/> + <p n="indent_extern_body" v="0"/> + <p n="indent_first_level" v="1"/> + <p n="indent_from_brace" v="0"/> + <p n="indent_if_of_else_if" v="1" apply="1"/> + <p n="indent_label" v="0"/> + <p n="indent_member_access" v="0"/> + <p n="indent_member_access_relative" v="0"/> + <p n="indent_namespace_body" v="0"/> + <p n="indent_on_return_type_continuation" v="0"/> + <p n="indent_width_case" v="4"/> + <p n="indent_width_continuation" v="4"/> + <p n="indent_width_label" v="1"/> + <p n="indent_width_member_access" v="1"/> + <p n="indent_with_tabs" v="0"/> + <p n="jd_bl_before_tags" v="1" apply="0"/> + <p n="jd_bl_between_different_tags" v="1" apply="0"/> + <p n="jd_bl_between_same_tags" v="0" apply="0"/> + <p n="jd_format_html" v="1" apply="0"/> + <p n="jd_format_pre" v="1" apply="0"/> + <p n="jd_indent_param_desc" v="1" apply="0"/> + <p n="jd_indent_past_param_name" v="1" apply="0"/> + <p n="jd_nl_at_start_and_end" v="1" apply="0"/> + <p n="jd_rm_blank_lines" v="0" apply="0"/> + <p n="justify_member_var_decls" v="0" apply="0"/> + <p n="justify_var_decls" v="0" apply="0"/> + <p n="leave_class_one_line_block" v="1"/> + <p n="leave_multiple_decl" v="1"/> + <p n="leave_multiple_stmt" v="1"/> + <p n="leave_one_line_code_blocks" v="1"/> + <p n="listalign2_expr_parens" v="0"/> + <p n="listalign_fun_call_params" v="2"/> + <p n="max_line_len" v="80" apply="0"/> + <p n="nl_after_case" v="1" apply="0"/> + <p n="nl_after_extern" v="1" apply="1"/> + <p n="nl_before_else" v="1" apply="1"/> + <p n="nl_empty_block" v="0" apply="1"/> + <p n="nl_empty_class_body" v="0" apply="0"/> + <p n="nl_empty_fun_body" v="1" apply="0"/> + <p n="oneline_catch" v="0" apply="1"/> + <p n="oneline_dowhile" v="1" apply="1"/> + <p n="oneline_elseif" v="1" apply="1"/> + <p n="oneline_unblocked_else" v="0" apply="1"/> + <p n="oneline_unblocked_statement" v="0" apply="1"/> + <p n="oneline_unblocked_then" v="0" apply="1"/> + <p n="original_tab_size" v="4" apply="0"/> + <p n="pp_indent" v="0"/> + <p n="pp_indent_in_code_block" v="0"/> + <p n="pp_indent_in_header_guard" v="0"/> + <p n="pp_indent_with_code" v="0"/> + <p n="pp_keep_pound_in_col1" v="0"/> + <p n="ra_fun_void_in_empty_param_list" v="1" apply="0"/> + <p n="ra_throw_parens" v="1" apply="0"/> + <p n="rai_return_parens" v="1" apply="0"/> + <p n="require_new_line_after_member_access" v="1"/> + <p n="require_new_line_at_eof" v="1"/> + <p n="rm_dup_spaces" v="0"/> + <p n="rm_return_type_new_lines" v="0"/> + <p n="rm_trailing_spaces" v="1"/> + <p n="sp_array_decl_after_rbracket" v="0" apply="1"/> + <p n="sp_array_decl_before_lbracket" v="0" apply="1"/> + <p n="sp_array_del_before_lbracket" v="0" apply="1"/> + <p n="sp_array_del_rbracket" v="1" apply="1"/> + <p n="sp_array_expr_after_rbracket" v="0" apply="1"/> + <p n="sp_array_expr_before_lbracket" v="0" apply="1"/> + <p n="sp_cast_after_rparen" v="0" apply="1"/> + <p n="sp_cast_before_lparen" v="0" apply="1"/> + <p n="sp_catch_after_rparen" v="1" apply="1"/> + <p n="sp_catch_before_lparen" v="1" apply="1"/> + <p n="sp_cppcast_after_gt" v="0" apply="1"/> + <p n="sp_cppcast_before_lt" v="0" apply="1"/> + <p n="sp_expr_after_rparen" v="0" apply="1"/> + <p n="sp_expr_before_lparen" v="0" apply="1"/> + <p n="sp_for_after_rparen" v="1" apply="1"/> + <p n="sp_for_before_lparen" v="1" apply="1"/> + <p n="sp_fptr_after_rparen" v="0" apply="1"/> + <p n="sp_fptr_before_lparen" v="1" apply="1"/> + <p n="sp_fptr_between_star_and_id" v="1" apply="1"/> + <p n="sp_fun_after_operator" v="0" apply="1"/> + <p n="sp_fun_after_rparen" v="0" apply="1"/> + <p n="sp_fun_before_lparen" v="0" apply="1"/> + <p n="sp_fun_call_after_operator" v="0" apply="1"/> + <p n="sp_fun_call_after_rparen" v="0" apply="1"/> + <p n="sp_fun_call_before_lparen" v="0" apply="1"/> + <p n="sp_fun_call_empty_parens" v="0" apply="1"/> + <p n="sp_fun_empty_parens" v="0" apply="1"/> + <p n="sp_if_after_rparen" v="1" apply="1"/> + <p n="sp_if_before_lparen" v="1" apply="1"/> + <p n="sp_lambda_after_rbracket" v="0" apply="1"/> + <p n="sp_lambda_before_lbracket" v="0" apply="1"/> + <p n="sp_mptr_between_coloncolon_and_star" v="0" apply="1"/> + <p n="sp_new_after_rparen" v="1" apply="1"/> + <p n="sp_new_before_lparen" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_amp" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_id" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_lparen" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_qualifier" v="1" apply="1"/> + <p n="sp_ptr_between_star_and_rparen" v="0" apply="1"/> + <p n="sp_ptr_between_star_and_star" v="0" apply="1"/> + <p n="sp_ptr_between_type_and_star" v="1" apply="1"/> + <p n="sp_ptr_cast_proto_between_type_and_star" v="1" apply="1"/> + <p n="sp_ptr_return_type_between_type_and_star" v="1" apply="1"/> + <p n="sp_ref_between_amp_and_id" v="0" apply="1"/> + <p n="sp_ref_between_amp_and_lparen" v="0" apply="1"/> + <p n="sp_ref_between_amp_and_rparen" v="0" apply="1"/> + <p n="sp_ref_between_type_and_amp" v="1" apply="1"/> + <p n="sp_ref_cast_proto_between_type_and_amp" v="1" apply="1"/> + <p n="sp_ref_return_type_between_type_and_amp" v="1" apply="1"/> + <p n="sp_return_after_rparen" v="0" apply="1"/> + <p n="sp_return_before_lparen" v="1" apply="1"/> + <p n="sp_stmt_after_semicolon" v="1" apply="1"/> + <p n="sp_stmt_before_semicolon" v="0" apply="1"/> + <p n="sp_switch_after_rparen" v="1" apply="1"/> + <p n="sp_switch_before_lparen" v="1" apply="1"/> + <p n="sp_throw_after_rparen" v="0" apply="1"/> + <p n="sp_throw_before_lparen" v="1" apply="1"/> + <p n="sp_tmpl_decl_before_lt" v="0" apply="1"/> + <p n="sp_tmpl_parm_before_lt" v="0" apply="1"/> + <p n="sp_while_after_rparen" v="1" apply="1"/> + <p n="sp_while_before_lparen" v="1" apply="1"/> + <p n="sppad_array_decl_brackets" v="0" apply="1"/> + <p n="sppad_array_del_brackets" v="0" apply="1"/> + <p n="sppad_array_expr_brackets" v="0" apply="1"/> + <p n="sppad_cast_parens" v="0" apply="1"/> + <p n="sppad_catch_parens" v="0" apply="1"/> + <p n="sppad_cppcast_angle_brackets" v="0" apply="1"/> + <p n="sppad_expr_parens" v="0" apply="1"/> + <p n="sppad_for_parens" v="0" apply="1"/> + <p n="sppad_fptr_parens" v="0" apply="1"/> + <p n="sppad_fun_call_parens" v="0" apply="1"/> + <p n="sppad_fun_parens" v="0" apply="1"/> + <p n="sppad_if_parens" v="0" apply="1"/> + <p n="sppad_lambda_braces" v="0" apply="1"/> + <p n="sppad_lambda_brackets" v="0" apply="1"/> + <p n="sppad_new_parens" v="0" apply="1"/> + <p n="sppad_return_parens" v="0" apply="1"/> + <p n="sppad_switch_parens" v="0" apply="1"/> + <p n="sppad_throw_parens" v="0" apply="1"/> + <p n="sppad_tmpl_decl_angle_brackets" v="0" apply="1"/> + <p n="sppad_tmpl_parm_angle_brackets" v="0" apply="1"/> + <p n="sppad_while_parens" v="0" apply="1"/> + <p n="spstyle_catch_lbrace" v="1" apply="1"/> + <p n="spstyle_class_colon" v="3" apply="1"/> + <p n="spstyle_class_comma" v="2" apply="1"/> + <p n="spstyle_class_lbrace" v="1" apply="1"/> + <p n="spstyle_constr_init_list_comma" v="2" apply="1"/> + <p n="spstyle_enum_colon" v="3" apply="1"/> + <p n="spstyle_enum_const_comma" v="2" apply="1"/> + <p n="spstyle_enum_const_eq" v="3" apply="1"/> + <p n="spstyle_enum_lbrace" v="1" apply="1"/> + <p n="spstyle_for_comma" v="2" apply="1"/> + <p n="spstyle_for_lbrace" v="1" apply="0"/> + <p n="spstyle_for_semicolon" v="2" apply="1"/> + <p n="spstyle_fun_call_comma" v="2" apply="1"/> + <p n="spstyle_fun_colon" v="3" apply="1"/> + <p n="spstyle_fun_comma" v="2" apply="1"/> + <p n="spstyle_fun_eq" v="3" apply="1"/> + <p n="spstyle_fun_lbrace" v="3" apply="1"/> + <p n="spstyle_if_lbrace" v="1" apply="1"/> + <p n="spstyle_init_comma" v="2" apply="1"/> + <p n="spstyle_init_list_comma" v="2" apply="1"/> + <p n="spstyle_init_rbrace" v="1" apply="1"/> + <p n="spstyle_member_dot" v="0" apply="1"/> + <p n="spstyle_namespace_lbrace" v="3" apply="1"/> + <p n="spstyle_op_addressof" v="0" apply="1"/> + <p n="spstyle_op_assignment" v="3" apply="1"/> + <p n="spstyle_op_binary" v="3" apply="1"/> + <p n="spstyle_op_bitwise" v="3" apply="1"/> + <p n="spstyle_op_comparison" v="3" apply="1"/> + <p n="spstyle_op_dashgt" v="0" apply="1"/> + <p n="spstyle_op_dashgtstar" v="0" apply="1"/> + <p n="spstyle_op_dereference" v="0" apply="1"/> + <p n="spstyle_op_dotstar" v="0" apply="1"/> + <p n="spstyle_op_logical" v="3" apply="1"/> + <p n="spstyle_op_mult" v="3" apply="1"/> + <p n="spstyle_op_postfix" v="0" apply="1"/> + <p n="spstyle_op_prefix" v="0" apply="1"/> + <p n="spstyle_op_unary" v="0" apply="1"/> + <p n="spstyle_struct_colon" v="3" apply="1"/> + <p n="spstyle_struct_comma" v="2" apply="1"/> + <p n="spstyle_struct_lbrace" v="1" apply="1"/> + <p n="spstyle_switch_lbrace" v="1" apply="1"/> + <p n="spstyle_tmpl_decl_comma" v="2" apply="1"/> + <p n="spstyle_tmpl_decl_eq" v="3" apply="1"/> + <p n="spstyle_tmplparm_comma" v="2" apply="1"/> + <p n="spstyle_try_lbrace" v="3" apply="1"/> + <p n="spstyle_union_before_lbrace" v="1" apply="1"/> + <p n="spstyle_while_lbrace" v="1" apply="1"/> + <p n="syntax_indent" v="4"/> + <p n="tab_size" v="+8"/> + <p n="trailing_comment_col" v="70"/> + <p n="trailing_comment_style" v="2"/> + <p n="xdoc_bl_between_different_tags" v="1" apply="0"/> + <p n="xdoc_bl_between_same_tags" v="0" apply="0"/> + <p n="xdoc_format_pre" v="1" apply="0"/> + <p n="xdoc_nl_after_open_tag" v="1" apply="0"/> + <p n="xdoc_nl_before_close_tag" v="1" apply="0"/> + <p n="xdoc_rm_blank_lines" v="1" apply="0"/> + </profile> +</options> + diff --git a/SlickEdit/color_profiles.cfg.xml b/SlickEdit/color_profiles.cfg.xml new file mode 100644 index 0000000..db3f5a0 --- /dev/null +++ b/SlickEdit/color_profiles.cfg.xml @@ -0,0 +1,96 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE Options SYSTEM "http://www.slickedit.com/dtd/vse/14.0/options.dtd"> +<options> + <profile n="color_profiles.Solarized Dark" version="4"> + <p n="associated_symbol_profile" v="(None)"/> + <p n="selection" fg="0x969483" bg="0x423607" flags="0x0" embg="0x63510A"/> + <p n="window_text" fg="0x969483" bg="0x2A2000" flags="0x0" embg="0x1A1400"/> + <p n="cline" fg="0xFFFFFF" bg="0x605030" flags="0x0" embg="0x908060"/> + <p n="selected_cline" fg="0xFFFF" bg="0x80C400" flags="0x0" embg="0x509400"/> + <p n="message" fg="0x80000008" bg="0x80000005" flags="0x0"/> + <p n="status" fg="0x80000008" bg="0xFFFFFF" flags="0x0"/> + <p n="cursor" fg="0x0" bg="0xE8E8C0" flags="0x0" embg="0xB8B890"/> + <p n="error" fg="0x8236D3" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="modified_line" fg="0xFFFFFF" bg="0xFF" flags="0x0" embg="0xCF"/> + <p n="inserted_line" fg="0xFFFFFF" bg="0x80" flags="0x0" embg="0x3030B0"/> + <p n="keyword" fg="0x1689B5" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="linenum" fg="0x969483" bg="0x423607" flags="0x0" embg="0x303030"/> + <p n="number" fg="0x98A12A" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="string" fg="0x9985" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="comment" fg="0xA100" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="ppkeyword" fg="0x164BCB" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="punctuation" fg="0x98A12A" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="library_symbol" fg="0xC0C000" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="operator" fg="0x2F32DC" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="user_defined" fg="0xFF" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="imaginary_line" fg="0xFFFFFF" bg="0xFF0000" flags="0x0" embg="0xCF0000"/> + <p n="function" fg="0xDB8B26" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="lineprefixarea" fg="0xA1A193" bg="0x423600" flags="0x1"/> + <p n="filename" fg="0x0" bg="0xFFFF00" flags="0x0" embg="0xCFCF00"/> + <p n="hilight" fg="0xFFFFFF" bg="0x808000" flags="0x0" embg="0x505000"/> + <p n="attribute" fg="0x9985" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="unknown_tag" fg="0x2F32DC" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="xhtmlelementinxsl" fg="0x80FF" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="specialchars" fg="0xC0C0C0" bg="0xFFFFFF" flags="0x0" embg="0xCFCFCF"/> + <p n="current_line_box" fg="0xFF8080" bg="0xFF8080" flags="0x0"/> + <p n="vertical_col_line" fg="0x164BCB" bg="0x164BCB" flags="0x0"/> + <p n="margins_col_line" fg="0x808080" bg="0x808080" flags="0x0"/> + <p n="truncation_col_line" fg="0xFF" bg="0xFF" flags="0x0"/> + <p n="prefix_area_line" fg="0x808080" bg="0x808080" flags="0x0"/> + <p n="block_matching" fg="0xFFFFFF" bg="0x837B65" flags="0x0" embg="0xCF0000"/> + <p n="inc_search_current" fg="0x0" bg="0xFFFF80" flags="0x0" embg="0xCFCF50"/> + <p n="inc_search_match" fg="0x0" bg="0x80FFFF" flags="0x0" embg="0x50CFCF"/> + <p n="hex_mode_color" fg="0x2F32DC" bg="0xF0F0F0" flags="0x1" embg="0xC0C0C0"/> + <p n="symbol_highlight" fg="0x98A12A" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="document_tab_modified" fg="0xFF" bg="0xFFFFFF" flags="0x0"/> + <p n="line_comment" fg="0xA100" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="documentation" fg="0xA100" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="doc_keyword" fg="0xA197" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="doc_punctuation" fg="0xA100" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="doc_attribute" fg="0x97A100" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="doc_attr_value" fg="0x97A100" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="identifier" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="floating_number" fg="0x98A12A" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="hex_number" fg="0x98A12A" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="singlequoted_string" fg="0x9985" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="backquoted_string" fg="0x9985" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="unterminated_string" fg="0x9985" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="inactive_code" fg="0xA100" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="inactive_keyword" fg="0xA100" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="imaginary_space" fg="0xFFFFFF" bg="0xFF0000" flags="0x0" embg="0xCF0000"/> + <p n="inactive_comment" fg="0xA100" bg="0x2A2000" flags="0x2002" embg="0x1A1400"/> + <p n="modified_item" fg="0xFF" bg="0xFFFFFF" flags="0x0"/> + <p n="navhint" fg="0x80FF" bg="0x403010" flags="0x0"/> + <p n="xml_character_ref" fg="0x98A12A" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="search_result_truncated" fg="0x969483" bg="0x2A2000" flags="0x0"/> + <p n="markdown_header" fg="0x969483" bg="0x2A2000" flags="0x0" embg="0x1A1400"/> + <p n="markdown_code" fg="0x969483" bg="0x2A2000" flags="0x0" embg="0x1A1400"/> + <p n="markdown_blockquote" fg="0x969483" bg="0x2A2000" flags="0x0" embg="0x1A1400"/> + <p n="markdown_link" fg="0x969483" bg="0x2A2000" flags="0x0" embg="0x1A1400"/> + <p n="document_tab_active" fg="0x2A2000" bg="0xA1A193" flags="0x0"/> + <p n="document_tab_selected" fg="0x2A2000" bg="0x969483" flags="0x0"/> + <p n="document_tab_unselected" fg="0x969483" bg="0x2A2000" flags="0x0"/> + <p n="selective_display_line" fg="0xB0C0B0" bg="0x2A2000" flags="0x0"/> + <p n="identifier2" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="css_class" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="css_selector" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="css_element" fg="0xDB8B26" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="css_property" fg="0x1689B5" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="markdown_link2" fg="0x969483" bg="0x2A2000" flags="0x0" embg="0x1A1400"/> + <p n="markdown_bullet" fg="0x98A12A" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="markdown_emphasis" fg="0xC0C000" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="markdown_emphasis2" fg="0xC0C000" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="tag" fg="0x1689B5" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="unknown_attribute" fg="0x969483" bg="0x2A2000" flags="0x0" embg="0x1A1400"/> + <p n="yaml_anchor_def" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="yaml_anchor_ref" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="yaml_operator" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="yaml_punctuation" fg="0x969483" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="yaml_text" fg="0x9985" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="yaml_directive" fg="0x164BCB" bg="0x2A2000" flags="0x2001" embg="0x1A1400"/> + <p n="yaml_text_colon" fg="0x1689B5" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="yaml_tag" fg="0xC0C000" bg="0x2A2000" flags="0x2000" embg="0x1A1400"/> + <p n="markdown_emphasis3" fg="0xC0C000" bg="0x2A2000" flags="0x2003" embg="0x1A1400"/> + </profile> +</options> + diff --git a/SlickEdit/kdev.e b/SlickEdit/kdev.e new file mode 100644 index 0000000..59e497e --- /dev/null +++ b/SlickEdit/kdev.e @@ -0,0 +1,3972 @@ +/* $Id: kdev.e 3589 2023-02-20 10:07:39Z bird $ -*- tab-width: 4 c-indent-level: 4 -*- */ +/** @file + * Visual SlickEdit Documentation Macros. + */ + +/* + * Copyright (c) 1999-2010 knut st. osmundsen <bird-kBuild-spamx@anduin.net> + * + * This file is part of kBuild. + * + * kBuild is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * kBuild is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with kBuild. If not, see <http://www.gnu.org/licenses/> + * + */ + +/*** + * + * This define the following keys: + *--------------------------------- + * Ctrl+Shift+C: Class description box. + * Ctrl+Shift+F: Function/method description box. + * Ctrl+Shift+M: Module(file) description box + * Ctrl+Shift+O: One-liner (comment) + * + * Ctrl+Shift+G: Global box + * Ctrl+Shift+H: Header box + * Ctrl+Shift+E: Exported Symbols + * Ctrl+Shift+I: Internal function box + * Ctrl+Shift+K: Const/macro box + * Ctrl+Shift+S: Struct/Typedef box + * + * Ctrl+Shift+A: Signature+Date marker + * Ctrl+Shift+P: Mark line as change by me + * + * Ctrl+Shift+T: Update project tagfile. + * Ctrl+Shift+L: Load document variables. + * + * Ctrl+Shift+B: KLOGENTRYX(..) + * Ctrl+Shift+E: KLOGEXIT(..) + * Ctrl+Shift+N: Do kLog stuff for the current file. No questions. + * Ctrl+Shift+Q: Do kLog stuff for the current file. Ask a lot of questions. + * + * Remember to set the correct sOdin32UserName, sOdin32UserEmail and sOdin32UserInitials + * before compiling and loading the macros into Visual SlickEdit. + * + * These macros are compatible with both 3.0(c) and 4.0(b). + * + */ +defeventtab default_keys +def 'C-S-A' = k_signature +//def 'C-S-C' = k_javadoc_classbox +def 'C-S-C' = k_calc +def 'C-S-E' = k_box_exported +def 'C-S-F' = k_javadoc_funcbox +def 'C-S-G' = k_box_globals +def 'C-S-H' = k_box_headers +def 'C-S-I' = k_box_intfuncs +def 'C-S-K' = k_box_consts +def 'C-S-N' = k_noref +def 'C-S-M' = k_javadoc_moduleheader +def 'C-S-O' = k_oneliner +def 'C-S-P' = k_mark_modified_line +def 'C-S-S' = k_box_structs +def 'C-S-T' = k_rebuild_tagfile +def 'C-S-L' = k_style_load + +//optional stuff +//def 'C-S-Q' = klib_klog_file_ask +//def 'C-S-N' = klib_klog_file_no_ask +//def 'C-S-1' = klib_klogentry +//def 'C-S-3' = klib_klogexit + + +//MARKER. Editor searches for this line! +#pragma option(redeclvars, on) +#include 'slick.sh' +#ifndef VS_TAGDETAIL_context_args +/* newer vslick version. */ +#include 'tagsdb.sh' +//#pragma option(strict,on) +/*#else: Version 4.0 (OS/2) */ +#endif + +#ifndef __MACOSX__ + #define KDEV_WITH_MENU +#endif + +/* Remeber to change these! */ +static _str skUserInitials = "bird"; +static _str skUserName = "knut st. osmundsen"; +static _str skUserEmail = "bird-kBuild-spamx@anduin.net"; + + +/******************************************************************************* +* Global Variables * +*******************************************************************************/ +static _str skCodeStyle = 'Opt2Ind4'; /* coding style scheme. */ +static _str skDocStyle = 'javadoc';/* options: javadoc, */ +static _str skLicense = 'GPLv3'; /* options: GPL, LGPL, Odin32, Confidential, ++ */ +static _str skCompany = ''; /* empty or company name for copyright */ +static _str skProgram = ''; /* Current program name - used by [L]GPL */ +static _str skChange = ''; /* Current change identifier. */ + +static int ikStyleWidth = 130; /* The page width of the style. */ +static boolean fkStyleFullHeaders = false; /* false: omit some tags. */ +static int ikStyleOneliner = 45; /* The oneline comment column. */ +static int ikStyleModifyMarkColumn = 105; +static boolean fkStyleBoxTag = false; /* true: Include tag in k_box_start. */ + + +/******************************************************************************* +* Internal Functions * +*******************************************************************************/ +/** + * Gets iso date. + * @returns ISO formatted date. + */ +static _str k_date() +{ + int i,j; + _str date; + + date = _date('U'); + i = pos("/", date); + j = pos("/", date, i+1); + _str month = substr(date, 1, i-1); + if (length(month) == 1) month = '0'month; + _str day = substr(date, i+1, j-i-1); + if (length(day) == 1) day = '0'day; + _str year = substr(date, j+1); + return year"-"month"-"day; +} + + +/** + * Get the current year. + * @returns Current year string. + */ +static _str k_year() +{ + _str date = _date('U'); + return substr(date, pos("/",date, pos("/",date)+1)+1, 4); +} + + +/** + * Aligns a value up to a given alignment. + */ +static int k_alignup(int iValue, iAlign) +{ + if (iAlign <= 0) + { + message('k_alignup: iValue='iValue ' iAlign='iAlign); + iAlign = 4; + } + return ((iValue intdiv iAlign) + 1) * iAlign; +} + + +/** + * Reads the comment setup for this lexer/extension . + * + * @returns Success indicator. + * @param sLeft Left comment. (output) + * @param sRight Right comment. (output) + * @param iColumn Comment mark column. (1-based) (output) + * @param sExt The extension to lookup defaults to the current one. + * @param sLexer The lexer to lookup defaults to the current one. + * @remark This should be exported from box.e, but unfortunately it isn't. + */ +static boolean k_commentconfig(_str &sLeft, _str &sRight, int &iColumn, _str sExt = p_extension, _str sLexer = p_lexer_name) +{ + /* init returns */ + sLeft = sRight = ''; + iColumn = 0; + + /* + * Get comment setup from the lexer. + */ + _str sLine = ''; + if (sLexer) + { + /* multiline */ +#if __VERSION__ >= 21.0 + COMMENT_TYPE aComments[]; + GetComments(aComments, "M", sLexer); + for (i = 0; i < aComments._length(); i++) +# if __VERSION__ >= 22.0 + if (aComments[i].type != 'doc_comment') +# else + if (!aComments[i].isDocumentation) +# endif + { + sLeft = aComments[i].delim1; + sRight = aComments[i].delim2; + iColumn = aComments[i].startcol; + if (sLeft != '' && sRight != '') + return true; + } +#else +# if __VERSION__ >= 14.0 + _str aComments[] = null; + GetComments(aComments, "mlcomment", sLexer); + for (i = 0; i < aComments._length(); i++) + if (pos("documentation", aComments[i]) <= 0) + { + sLine = aComments[i]; + break; + } + if (sLine != '') +# else + rc = _ini_get_value(slick_path_search("user.vlx"), sLexer, 'mlcomment', sLine); + if (rc) + rc = _ini_get_value(slick_path_search("vslick.vlx"), sLexer, 'mlcomment', sLine); + if (!rc) +# endif + { + sLeft = strip(word(sLine, 1)); + sRight = strip(word(sLine, 2)); + if (sLeft != '' && sRight != '') + return true; + } +#endif + + /* failed, try single line. */ +#if __VERSION__ >= 21.0 + GetComments(aComments, "L", sLexer); + for (i = 0; i < aComments._length(); i++) +# if __VERSION__ >= 22.0 + if (aComments[i].type != 'doc_comment') +# else + if (!aComments[i].isDocumentation) +# endif + { + sLeft = aComments[i].delim1; + sRight = ''; + iColumn = aComments[i].startcol; + if (sLeft != '') + return true; + } +#else +# if __VERSION__ >= 14.0 + GetComments(aComments, "linecomment", sLexer) + for (i = 0; i < aComments._length(); i++) + if (pos("documentation", aComments[i]) <= 0) + { + sLine = aComments[i]; + break; + } + if (sLine != '') +# else + rc = _ini_get_value(slick_path_search("user.vlx"), sLexer, 'linecomment', sLine); + if (rc) + rc = _ini_get_value(slick_path_search("vslick.vlx"), sLexer, 'linecomment', sLine); + if (!rc) +# endif + { + sLeft = strip(word(sLine, 1)); + sRight = ''; + iColumn = 0; + _str sTmp = word(sLine, 2); + if (isnumber(sTmp)) + iColumn = (int)sTmp; + if (sLeft != '') + return true; + } +#endif + } + + /* + * Read the nonboxchars and determin user or default box.ini. + */ + _str sFile = slick_path_search("ubox.ini"); + boolean frc = _ini_get_value(sFile, sExt, 'nonboxchars', sLine); + if (frc) + { + sFile = slick_path_search("box.ini"); + frc = _ini_get_value(sFile, sExt, 'nonboxchars', sLine); + } + + if (!frc) + { /* + * Found extension. + */ + sLeft = strip(eq_name2value('left',sLine)); + if (sLeft == '\e') sLeft = ''; + sRight = strip(eq_name2value('right',sLine)); + if (sRight == '\e') sRight = ''; + + /* Read comment column too */ + frc = _ini_get_value(sFile, sExt, 'comment_col', sLine); + if (frc) + { + iColumn = eq_name2value('comment_col', sLine); + if (iColumn == '\e') iColumn = 0; + } + else + iColumn = 0; + return true; + } + + /* failure */ + sLeft = sRight = ''; + iColumn = 0; + + return false; +} + + +/** + * Checks if current file only support line comments. + * @returns True / False. + * @remark Use builtin extension stuff! + */ +static boolean k_line_comment() +{ + _str sRight = ''; + _str sLeft = ''; + int iColumn; + boolean fLineComment = false; + if (k_commentconfig(sLeft, sRight, iColumn)) + fLineComment = (sRight == '' || iColumn > 0); + return fLineComment; +} + + + +#define KIC_CURSOR_BEFORE 1 +#define KIC_CURSOR_AFTER 2 +#define KIC_CURSOR_AT_END 3 + +/** + * Insert a comment at current or best fitting position in the text. + * @param sStr The comment to insert. + * @param iCursor Where to put the cursor. + * @param iPosition Where to start the comment. + * Doesn't apply to column based source. + * -1 means at cursor position. (default) + * >0 means at end of line, but not before this column (1-based). + * This also implies a min of one space to EOL. + */ +void k_insert_comment(_str sStr, int iCursor, int iPosition = -1) +{ + _str sLeft; + _str sRight; + int iColumn; + if (!k_commentconfig(sLeft, sRight, iColumn)) + { + sLeft = '/*'; sRight = '*/'; iColumn = 0; + } + + int iCol = 0; + if (iColumn <= 0) + { /* + * not column based source + */ + + /* position us first */ + if (iPosition > 0) + { + end_line(); + do { + _insert_text(" "); + } while (p_col < iPosition); + } + + /* insert comment saving the position for _BEFORE. */ + iCol = p_col; + _insert_text(sLeft:+' ':+sStr); + if (iCursor == KIC_CURSOR_AT_END) + iCol = p_col; + /* right comment delimiter? */ + if (sRight != '') + _insert_text(' ':+sRight); + } + else + { + if (p_col >= iColumn) + _insert_text("\n"); + do { _insert_text(" "); } while (p_col < iColumn); + if (iCursor == KIC_CURSOR_BEFORE) + iCol = p_col; + _insert_text(sLeft:+' ':+sStr); + if (iCursor == KIC_CURSOR_AT_END) + iCol = p_col; + } + + /* set cursor. */ + if (iCursor != KIC_CURSOR_AFTER) + p_col = iCol; +} + + +/** + * Gets the comment prefix or postfix. + * @returns Comment prefix or postfix. + * @param fRight If clear left comment string - default. + * If set right comment string. + */ +static _str k_comment(boolean fRight = false) +{ + _str sLeft, sRight; + int iColumn; + _str sComment = '/*'; + if (k_commentconfig(sLeft, sRight, iColumn)) + sComment = (!fRight || iColumn > 0 ? sLeft : sRight); + + return strip(sComment); +} + + +/******************************************************************************* +* BOXES * +*******************************************************************************/ + +/** + * Inserts the first line in a box. + * @param sTag Not used - box tag. + */ +static void k_box_start(sTag) +{ + _str sLeft, sRight; + int iColumn; + if (!k_commentconfig(sLeft, sRight, iColumn)) + return; + _begin_line(); + if (iColumn >= 0) + while (p_col < iColumn) + _insert_text(" "); + + _str sText = sLeft; + if (sTag != '' && fkStyleBoxTag) + { + if (substr(sText, length(sText)) != '*') + sText = sText:+'*'; + sText = sText:+sTag; + } + + int i; + for (i = length(sText); i <= ikStyleWidth - p_col; i++) + sText = sText:+'*'; + sText = sText:+"\n"; + + _insert_text(sText); +} + + +/** + * Places a string, sStr, into a line started and ended by '*'. + * @param sStr Text to have between the '*'s. + */ +static void k_box_line(_str sStr) +{ + _str sLeft, sRight; + int iColumn; + if (!k_commentconfig(sLeft, sRight, iColumn)) + return; + if (iColumn >= 0) + while (p_col < iColumn) + _insert_text(" "); + + _str sText = ''; + if (k_line_comment()) + sText = sLeft; + if (sText == '' || substr(sText, length(sText)) != '*') + sText = sText:+'*'; + + sText = sText:+' '; + int i; + for (i = length(sText); i < p_SyntaxIndent; i++) + sText = sText:+' '; + + sText = sText:+sStr; + + for (i = length(sText) + 1; i <= ikStyleWidth - p_col; i++) + sText = sText:+' '; + sText = sText:+"*\n"; + + _insert_text(sText); +} + + +/** + * Inserts the last line in a box. + */ +static void k_box_end() +{ + _str sLeft, sRight; + int iColumn, i; + if (!k_commentconfig(sLeft, sRight, iColumn)) + return; + if (iColumn >= 0) + while (p_col < iColumn) + _insert_text(" "); + + _str sText = ''; + if (k_line_comment()) + sText = sLeft; + for (i = length(sText) + length(sRight); i <= ikStyleWidth - p_col; i++) + sText = sText:+'*'; + sText = sText:+sRight:+"\n"; + + _insert_text(sText); +} + + + +/******************************************************************************* +* FUNCTION AND CODE PARSERS * +*******************************************************************************/ +/** + * Moves cursor to nearest function start. + * @returns 0 if ok. + * -1 on failure. + */ +static int k_func_goto_nearest_function() +{ + boolean fFix = false; /* cursor at function fix. (last function) */ + int cur_line = p_line; + int prev_line = -1; + int next_line = -1; + typeless org_pos; + _save_pos2(org_pos); + + if (!next_proc(1)) + { + next_line = p_line; + if (!prev_proc(1) && p_line == cur_line) + { + _restore_pos2(org_pos); + return 0; + } + _restore_pos2(org_pos); + _save_pos2(org_pos); + } + else + { + p_col++; /* fixes problem with single function files. */ + fFix = true; + } + + if (!prev_proc(1)) + { + prev_line = p_line; + if (!next_proc(1) && p_line == cur_line) + { + _restore_pos2(org_pos); + return 0; + } + _restore_pos2(org_pos); + _save_pos2(org_pos); + } + + + if (prev_line != -1 && (next_line == -1 || cur_line - prev_line <= next_line - cur_line)) + { + if (fFix) + p_col++; + prev_proc(1); + return 0; + } + + if (next_line != -1 && (prev_line == -1 || cur_line - prev_line > next_line - cur_line)) + { + next_proc(); + return 0; + } + + _restore_pos2(org_pos); + return -1; +} + + +/** + * Check if nearest function is a prototype. + * @returns True if function prototype. + * False if not function prototype. + */ +static boolean k_func_prototype() +{ + /* + * Check if this is a real function implementation. + */ + typeless procpos; + _save_pos2(procpos); + if (!k_func_goto_nearest_function()) + { + int proc_line = p_line; + + if (!k_func_searchcode("{")) + { + prev_proc(); + if (p_line != proc_line) + { + _restore_pos2(procpos); + return true; + } + } + } + _restore_pos2(procpos); + + return false; +} + + +/** + * Gets the name fo the current function. + * @returns The current function name. + */ +static _str k_func_getfunction_name() +{ + _str sFunctionName = current_proc(); + if (!sFunctionName) + sFunctionName = ""; + //say 'functionanme='sFunctionName; + return sFunctionName; +} + + +/** + * Goes to the neares function and gets its parameters. + * @remark Should be reimplemented to use tags (if someone can figure out how to query that stuff). + */ +static _str k_func_getparams() +{ + typeless org_pos; + _save_pos2(org_pos); + + /* + * Try use the tags first. + */ + _UpdateContext(true); + int context_id = tag_current_context(); + if (context_id <= 0) + { + k_func_goto_nearest_function(); + context_id = tag_current_context(); + } + if (context_id > 0) + { + _str args = ''; + _str type = ''; + tag_get_detail2(VS_TAGDETAIL_context_args, context_id, args); + tag_get_detail2(VS_TAGDETAIL_context_type, context_id, type); + if (tag_tree_type_is_func(type)) + return args + //caption = tag_tree_make_caption_fast(VS_TAGMATCH_context,context_id,true,true,false); + } + + /* + * Go to nearest function. + */ + if ( !k_func_goto_nearest_function() + && !k_func_searchcode("(") /* makes some assumptions. */ + ) + { + /* + * Get parameters. + */ + typeless posStart; + _save_pos2(posStart); + long offStart = _QROffset(); + if (!find_matching_paren()) + { + long offEnd = _QROffset(); + _restore_pos2(posStart); + p_col++; + _str sParamsRaw = strip(get_text((int)(offEnd - offStart - 1))); + + + /* + * Remove new lines and double spaces within params. + */ + _str sParams = ""; + + int i; + _str chPrev; + for (i = 1, chPrev = ' '; i <= length(sParamsRaw); i++) + { + _str ch = substr(sParamsRaw, i, 1); + + /* + * Do fixups. + */ + if (ch == " " && chPrev == " ") + continue; + + if ((ch :== "\n") || (ch :== "\r") || (ch :== "\t")) + { + if (chPrev == ' ') + continue; + ch = ' '; + } + + if (ch == ',' && chPrev == ' ') + { + sParams = substr(sParams, 1, length(sParams) - 1); + } + + if (ch == '*') + { + if (chPrev != ' ') + sParams = sParams :+ ' * '; + else + sParams = sParams :+ '* '; + chPrev = ' '; + } + else + { + sParams = sParams :+ ch; + chPrev = ch; + } + + } /* for */ + + sParams = strip(sParams); + if (sParams == 'void' || sParams == 'VOID') + sParams = ""; + _restore_pos2(org_pos); + return sParams; + } + else + message("find_matchin_paren failed"); + } + + _restore_pos2(org_pos); + return false; +} + + + +/** + * Enumerates the parameters to the function. + * @param sParams Parameter string from k_func_getparams. + * @param iParam The index (0-based) of the parameter to get. + * @param sType Type. (output) + * @param sName Name. (output) + * @param sDefault Default value. (output) + * @remark Doesn't perhaps handle function pointers very well (I think)? + * @remark Should be reimplemented to use tags (if someone can figure out how to query that stuff). + */ +static int k_func_enumparams(_str sParams, int iParam, _str &sType, _str &sName, _str &sDefault) +{ + int i; + int iParLevel; + int iCurParam; + int iStartParam; + + sType = sName = sDefault = ""; + + /* no use working on empty string! */ + if (length(sParams) == 0) + return -1; + + /* find the parameter in question */ + for (iStartParam = i = 1, iParLevel = iCurParam = 0; i <= length(sParams); i++) + { + _str ch = substr(sParams, i, 1); + if (ch == ',' && iParLevel == 0) + { + /* is it this parameter ? */ + if (iParam == iCurParam) + break; + + iCurParam++; + iStartParam = i + 1; + } + else if (ch == '(') + iParLevel++; + else if (ch == ')') + iParLevel--; + } + + /* did we find the parameter? */ + if (iParam == iCurParam) + { /* (yeah, we did!) */ + _str sArg = strip(substr(sParams, iStartParam, i - iStartParam)); + /* remove M$ stuff */ + sArg = stranslate(sArg, "", "IN", "E"); + sArg = stranslate(sArg, "", "OUT", "E"); + sArg = stranslate(sArg, "", "OPTIONAL", "E"); + sArg = strip(sArg); + + /* lazy approach, which doens't support function types */ + + if (pos('=', sParams) > 0) /* default */ + { + sDefault = strip(substr(sParams, pos('=', sParams) + 1)); + sArg = strip(substr(sArg, 1, pos('=', sParams) - 1)); + } + + for (i = length(sArg); i > 1; i--) + { + _str ch = substr(sArg, i, 1); + if ( !(ch >= 'a' && ch <= 'z') + && !(ch >= 'A' && ch <= 'Z') + && !(ch >= '0' && ch <= '9') + && ch != '_' && ch != '$') + break; + } + if (sArg == "...") + i = 0; + sName = strip(substr(sArg, i + 1)); + sType = strip(substr(sArg, 1, i)); + + return 0; + } + + return -1; +} + + +/** + * Counts the parameters to the function. + * @param sParams Parameter string from k_func_getparams. + * @remark Should be reimplemented to use tags (if someone can figure out how to query that stuff). + */ +static int k_func_countparams(_str sParams) +{ + int i; + int iParLevel; + int iCurParam; + _str sType = "", sName = "", sDefault = ""; + + /* check for 0 parameters */ + if (length(sParams) == 0) + return 0; + + /* find the parameter in question */ + for (i = 1, iParLevel = iCurParam = 0; i <= length(sParams); i++) + { + _str ch = substr(sParams, i, 1); + if (ch == ',' && iParLevel == 0) + { + iCurParam++; + } + else if (ch == '(') + iParLevel++; + else if (ch == ')') + iParLevel--; + } + + return iCurParam + 1; +} + + +/** + * Gets the return type. + */ +static _str k_func_getreturntype(boolean fPureType = false) +{ + typeless org_pos; + _save_pos2(org_pos); + + /* + * Go to nearest function. + */ + if (!k_func_goto_nearest_function()) + { + /* + * Return type is from function start to function name... + */ + typeless posStart; + _save_pos2(posStart); + long offStart = _QROffset(); + + if (!k_func_searchcode("(")) /* makes some assumptions. */ + { + prev_word(); + long offEnd = _QROffset(); + _restore_pos2(posStart); + _str sTypeRaw = strip(get_text((int)(offEnd - offStart))); + + //say 'sTypeRaw='sTypeRaw; + /* + * Remove static, inline, _Optlink, stdcall, EXPENTRY etc. + */ + if (fPureType) + { + sTypeRaw = stranslate(sTypeRaw, "", "__static__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__static", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "static__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "static", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__inline__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__inline", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "inline__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "inline", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "EXPENTRY", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_Optlink", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__stdcall", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__cdecl", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_cdecl", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "cdecl", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__PASCAL", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_PASCAL", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "PASCAL", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__Far32__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__Far32", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "Far32__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_Far32_", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_Far32", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "Far32_", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "Far32", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__far", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_far", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "far", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__near", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_near", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "near", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__loadds__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__loadds", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "loadds__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_loadds_", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_loadds", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "loadds_", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "loadds", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__loades__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__loades", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "loades__", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_loades_", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "_loades", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "loades_", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "loades", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "WIN32API", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "WINAPI", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "LDRCALL", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "KRNLCALL", "I"); + sTypeRaw = stranslate(sTypeRaw, "", "__operator__", "I"); /* operator fix */ + sTypeRaw = stranslate(sTypeRaw, "", "__operator", "I"); /* operator fix */ + sTypeRaw = stranslate(sTypeRaw, "", "operator__", "I"); /* operator fix */ + sTypeRaw = stranslate(sTypeRaw, "", "operator", "I"); /* operator fix */ + sTypeRaw = stranslate(sTypeRaw, "", "IN", "E"); + sTypeRaw = stranslate(sTypeRaw, "", "OUT", "E"); + sTypeRaw = stranslate(sTypeRaw, "", "OPTIONAL", "E"); + } + + /* + * Remove new lines and double spaces within params. + */ + _str sType = ""; + + int i; + _str chPrev; + for (i = 1, chPrev = ' '; i <= length(sTypeRaw); i++) + { + _str ch = substr(sTypeRaw, i, 1); + + /* + * Do fixups. + */ + if (ch == " " && chPrev == " ") + continue; + + if ((ch :== "\n") || (ch :== "\r") || (ch :== "\t")) + { + if (chPrev == ' ') + continue; + ch = ' '; + } + + if (ch == ',' && chPrev == ' ') + { + sType = substr(sType, 1, length(sType) - 1); + } + + if (ch == '*') + { + if (chPrev != ' ') + sType = sType :+ ' * '; + else + sType = sType :+ '* '; + chPrev = ' '; + } + else + { + sType = sType :+ ch; + chPrev = ch; + } + + } /* for */ + + sType = strip(sType); + + _restore_pos2(org_pos); + return sType; + } + else + message('k_func_getreturntype: can''t find ''(''.'); + } + + _restore_pos2(org_pos); + return false; +} + + +/** + * Search for some piece of code. + */ +static int k_func_searchcode(_str sSearchString, _str sOptions = "E+") +{ + int rc; + rc = search(sSearchString, sOptions); + while (!rc && !k_func_in_code()) + { + p_col++; + rc = search(sSearchString, sOptions); + } + return rc; +} + + +/** + * Checks if cursor is in code or in comment. + * @return True if cursor in code. + */ +static boolean k_func_in_code() +{ + typeless searchsave; + _save_pos2(searchsave); + boolean fRc = !_in_comment(); + _restore_pos2(searchsave); + return fRc; +} + + +/* + * Gets the next piece of code. + */ +static _str k_func_get_next_code_text() +{ + typeless searchsave; + _save_pos2(searchsave); + _str ch = k_func_get_next_code_text2(); + _restore_pos2(searchsave); + return ch; +} + + +/** + * Checks if there is more code on the line. + */ +static boolean k_func_more_code_on_line() +{ + boolean fRc; + int curline = p_line; + typeless searchsave; + _save_pos2(searchsave); + k_func_get_next_code_text2(); + fRc = curline == p_line; + _restore_pos2(searchsave); + + return fRc; +} + + +/** + * Gets the next piece of code. + * Doesn't preserver cursor position. + */ +static _str k_func_get_next_code_text2() +{ + _str ch; + do + { + int curcol = ++p_col; + end_line(); + if (p_col <= curcol) + { + p_line++; + p_col = 1; + } + else + p_col = curcol; + + ch = get_text(); + //say ch ' ('_asc(ch)')'; + while (ch == "#") /* preprocessor stuff */ + { + p_col = 1; + p_line++; + ch = get_text(); + //say ch ' ('_asc(ch)')'; + continue; + } + } while (ch :== ' ' || ch :== "\t" || ch :== "\n" || ch :== "\r" || !k_func_in_code()); + + return ch; +} + + + + +/******************************************************************************* +* JAVA DOC STYLED WORKERS * +*******************************************************************************/ + +/** starts a javadoc documentation box. */ +static void k_javadoc_box_start(_str sStr = '', boolean fDouble = true) +{ + _str sLeft, sRight; + int iColumn; + if (!k_commentconfig(sLeft, sRight, iColumn)) + return; + _begin_line(); + if (iColumn >= 0) + while (p_col < iColumn) + _insert_text(" "); + + _str sText = sLeft; + if (fDouble) + sText = sLeft:+substr(sLeft, length(sLeft), 1); + if (sStr != '') + sText = sText:+' ':+sStr; + sText = sText:+"\n"; + + _insert_text(sText); +} + +/** inserts a new line in a javadoc documentation box. */ +static void k_javadoc_box_line(_str sStr = '', int iPadd = 0, _str sStr2 = '', int iPadd2 = 0, _str sStr3 = '') +{ + _str sLeft, sRight; + int iColumn; + if (!k_commentconfig(sLeft, sRight, iColumn)) + return; + if (iColumn >= 0) + while (p_col < iColumn) + _insert_text(" "); + + _str sText; + if (k_line_comment()) + sText = sLeft; + else + { + sText = sLeft; + sText = ' ':+substr(sLeft, length(sLeft)); + } + + if (sStr != '') + sText = sText:+' ':+sStr; + if (iPadd > 0) + { + int i; + for (i = length(sText); i < iPadd; i++) + sText = sText:+' '; + + if (sStr2 != '') + sText = sText:+sStr2; + + if (iPadd2 > 0) + { + for (i = length(sText); i < iPadd2; i++) + sText = sText:+' '; + + if (sStr3 != '') + sText = sText:+sStr3; + } + } + sText = sText:+"\n"; + + _insert_text(sText); +} + +/** ends a javadoc documentation box. */ +static void k_javadoc_box_end() +{ + _str sLeft, sRight; + int iColumn; + if (!k_commentconfig(sLeft, sRight, iColumn)) + return; + if (iColumn >= 0) + while (p_col < iColumn) + _insert_text(" "); + + _str sText; + if (k_line_comment()) + sText = sLeft; + else + { + sText = sRight; + /*if (substr(sText, 1, 1) != '*') + sText = '*':+sText;*/ + sText = ' ':+sText; + } + sText = sText:+"\n"; + + _insert_text(sText); +} + + +/** + * Write a Javadoc styled classbox. + */ +void k_javadoc_classbox() +{ + int iCursorLine; + int iPadd = k_alignup(12, p_SyntaxIndent); + + k_javadoc_box_start(); + iCursorLine = p_RLine; + k_javadoc_box_line(' '); + + if (fkStyleFullHeaders) + { + k_javadoc_box_line('@shortdesc', iPadd); + k_javadoc_box_line('@dstruct', iPadd); + k_javadoc_box_line('@version', iPadd); + k_javadoc_box_line('@verdesc', iPadd); + } + k_javadoc_box_line('@author', iPadd, skUserName ' <' skUserEmail '>'); + k_javadoc_box_line('@approval', iPadd); + k_javadoc_box_end(); + + up(p_RLine - iCursorLine); + end_line(); + keyin(' '); +} + + +/** + * Javadoc - functionbox(/header). + */ +void k_javadoc_funcbox() +{ + int cArgs = 1; + _str sArgs = ""; + int iCursorLine; + int iPadd = k_alignup(11, p_SyntaxIndent); + + /* look for parameters */ + boolean fFoundFn = !k_func_goto_nearest_function(); + if (fFoundFn) + { + sArgs = k_func_getparams(); + cArgs = k_func_countparams(sArgs); + } + + k_javadoc_box_start(); + iCursorLine = p_RLine; + k_javadoc_box_line(' '); + if (file_eq(p_extension, 'asm') || file_eq(p_extension, 'masm')) + k_javadoc_box_line('@cproto', iPadd); + k_javadoc_box_line('@returns', iPadd); + if (fFoundFn) + { + /* + * Determin parameter description indent. + */ + int iPadd2 = 0; + int i; + for (i = 0; i < cArgs; i++) + { + _str sName, sType, sDefault; + if ( !k_func_enumparams(sArgs, i, sType, sName, sDefault) + && iPadd2 < length(sName)) + iPadd2 = length(sName); + } + iPadd2 = k_alignup((iPadd + iPadd2), p_SyntaxIndent); + if (iPadd2 < 28) + iPadd2 = k_alignup(28, p_SyntaxIndent); + + /* + * Insert parameter. + */ + for (i = 0; i < cArgs; i++) + { + _str sName, sType, sDefault; + if (!k_func_enumparams(sArgs, i, sType, sName, sDefault)) + { + _str sStr3 = '.'; + if (sDefault != "") + sStr3 = '(default='sDefault')'; + k_javadoc_box_line('@param', iPadd, sName, iPadd2, sStr3); + } + else + k_javadoc_box_line('@param', iPadd); + } + } + else + k_javadoc_box_line('@param', iPadd); + + if (file_eq(p_extension, 'asm') || file_eq(p_extension, 'masm')) + k_javadoc_box_line('@uses', iPadd); + if (fkStyleFullHeaders) + { + k_javadoc_box_line('@equiv', iPadd); + k_javadoc_box_line('@time', iPadd); + k_javadoc_box_line('@sketch', iPadd); + k_javadoc_box_line('@status', iPadd); + k_javadoc_box_line('@author', iPadd, skUserName ' <' skUserEmail '>'); + k_javadoc_box_line('@remark', iPadd); + } + k_javadoc_box_end(); + + up(p_RLine - iCursorLine); + end_line(); + keyin(' '); +} + + +/** + * Javadoc module header. + */ +void k_javadoc_moduleheader() +{ + int iCursorLine; + int fSplit = 0; + + _insert_text("\n"); + up(); + _begin_line(); + k_insert_comment('$':+'I':+'d: $', KIC_CURSOR_AT_END, -1); + _end_line(); + _insert_text("\n"); + + k_javadoc_box_start('@file'); + fSplit = 1; + iCursorLine = p_RLine; + k_javadoc_box_line(); + k_javadoc_box_end(); + _insert_text("\n"); + _insert_text(k_comment() "\n"); + + if (skLicense == 'Confidential') + { + k_javadoc_box_line(skCompany ' confidential'); + k_javadoc_box_line(); + } + + if (skCompany != '') + { + if (skLicense != 'Confidential') + k_javadoc_box_line('Copyright (C) ' k_year() ' ' skCompany); + else + { + k_javadoc_box_line('Copyright (c) ' k_year() ' ' skCompany); + k_javadoc_box_line(); + k_javadoc_box_line('Author: ' skUserName' <' skUserEmail '>'); + } + } + else + k_javadoc_box_line('Copyright (c) ' k_year() ' 'skUserName' <' skUserEmail '>'); + k_javadoc_box_line(); + _str sProg = skProgram; + switch (skLicense) + { + case 'Odin32': + k_javadoc_box_line('Project Odin Software License can be found in LICENSE.TXT.'); + break; + + case 'GPL': + if (!fSplit) + k_javadoc_box_line(); + if (sProg == '') + sProg = 'This program'; + else + { + k_javadoc_box_line('This file is part of ' sProg '.'); + k_javadoc_box_line(); + } + k_javadoc_box_line(sProg ' is free software; you can redistribute it and/or modify'); + k_javadoc_box_line('it under the terms of the GNU General Public License as published by'); + k_javadoc_box_line('the Free Software Foundation; either version 2 of the License, or'); + k_javadoc_box_line('(at your option) any later version.'); + k_javadoc_box_line(); + k_javadoc_box_line(sProg ' is distributed in the hope that it will be useful,'); + k_javadoc_box_line('but WITHOUT ANY WARRANTY; without even the implied warranty of'); + k_javadoc_box_line('MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the'); + k_javadoc_box_line('GNU General Public License for more details.'); + k_javadoc_box_line(); + k_javadoc_box_line('You should have received a copy of the GNU General Public License'); + k_javadoc_box_line('along with ' sProg '; if not, write to the Free Software'); + k_javadoc_box_line('Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA'); + break; + + case 'LGPL': + if (!fSplit) + k_javadoc_box_line(); + if (sProg == '') + sProg = 'This library'; + else + { + k_javadoc_box_line('This file is part of ' sProg '.'); + k_javadoc_box_line(); + } + k_javadoc_box_line(sProg ' is free software; you can redistribute it and/or'); + k_javadoc_box_line('modify it under the terms of the GNU Lesser General Public'); + k_javadoc_box_line('License as published by the Free Software Foundation; either'); + k_javadoc_box_line('version 2.1 of the License, or (at your option) any later version.'); + k_javadoc_box_line(); + k_javadoc_box_line(sProg ' is distributed in the hope that it will be useful,'); + k_javadoc_box_line('but WITHOUT ANY WARRANTY; without even the implied warranty of'); + k_javadoc_box_line('MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU'); + k_javadoc_box_line('Lesser General Public License for more details.'); + k_javadoc_box_line(); + k_javadoc_box_line('You should have received a copy of the GNU Lesser General Public'); + k_javadoc_box_line('License along with ' sProg '; if not, write to the Free Software'); + k_javadoc_box_line('Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA'); + break; + + case 'GPLv3': + if (!fSplit) + k_javadoc_box_line(); + if (sProg == '') + sProg = 'This program'; + else + { + k_javadoc_box_line('This file is part of ' sProg '.'); + k_javadoc_box_line(); + } + k_javadoc_box_line(sProg ' is free software; you can redistribute it and/or modify'); + k_javadoc_box_line('it under the terms of the GNU General Public License as published by'); + k_javadoc_box_line('the Free Software Foundation; either version 3 of the License, or'); + k_javadoc_box_line('(at your option) any later version.'); + k_javadoc_box_line(); + k_javadoc_box_line(sProg ' is distributed in the hope that it will be useful,'); + k_javadoc_box_line('but WITHOUT ANY WARRANTY; without even the implied warranty of'); + k_javadoc_box_line('MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the'); + k_javadoc_box_line('GNU General Public License for more details.'); + k_javadoc_box_line(); + k_javadoc_box_line('You should have received a copy of the GNU General Public License'); + k_javadoc_box_line('along with ' sProg '. If not, see <http://www.gnu.org/licenses/>'); + break; + + case 'LGPLv3': + if (!fSplit) + k_javadoc_box_line(); + if (sProg == '') + sProg = 'This program'; + else + { + k_javadoc_box_line('This file is part of ' sProg '.'); + k_javadoc_box_line(); + } + k_javadoc_box_line(sProg ' is free software; you can redistribute it and/or'); + k_javadoc_box_line('modify it under the terms of the GNU Lesser General Public'); + k_javadoc_box_line('License as published by the Free Software Foundation; either'); + k_javadoc_box_line('version 3 of the License, or (at your option) any later version.'); + k_javadoc_box_line(); + k_javadoc_box_line(sProg ' is distributed in the hope that it will be useful,'); + k_javadoc_box_line('but WITHOUT ANY WARRANTY; without even the implied warranty of'); + k_javadoc_box_line('MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the'); + k_javadoc_box_line('GNU Lesser General Public License for more details.'); + k_javadoc_box_line(); + k_javadoc_box_line('You should have received a copy of the GNU Lesser General Public License'); + k_javadoc_box_line('along with ' sProg '. If not, see <http://www.gnu.org/licenses/>'); + break; + + case 'Confidential': + k_javadoc_box_line('All Rights Reserved'); + break; + + case 'ConfidentialNoAuthor': + k_javadoc_box_line(skCompany ' confidential'); + k_javadoc_box_line('All Rights Reserved'); + break; + + case 'VirtualBox': + k_javadoc_box_line('This file is part of VirtualBox Open Source Edition (OSE), as') + k_javadoc_box_line('available from http://www.virtualbox.org. This file is free software;') + k_javadoc_box_line('you can redistribute it and/or modify it under the terms of the GNU') + k_javadoc_box_line('General Public License (GPL) as published by the Free Software') + k_javadoc_box_line('Foundation, in version 2 as it comes in the "COPYING" file of the') + k_javadoc_box_line('VirtualBox OSE distribution. VirtualBox OSE is distributed in the') + k_javadoc_box_line('hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.') + k_javadoc_box_line('') + k_javadoc_box_line('Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa') + k_javadoc_box_line('Clara, CA 95054 USA or visit http://www.sun.com if you need') + k_javadoc_box_line('additional information or have any questions.') + break; + + case 'VirtualBoxGPLAndCDDL': + k_javadoc_box_line('This file is part of VirtualBox Open Source Edition (OSE), as') + k_javadoc_box_line('available from http://www.virtualbox.org. This file is free software;') + k_javadoc_box_line('you can redistribute it and/or modify it under the terms of the GNU') + k_javadoc_box_line('General Public License (GPL) as published by the Free Software') + k_javadoc_box_line('Foundation, in version 2 as it comes in the "COPYING" file of the') + k_javadoc_box_line('VirtualBox OSE distribution. VirtualBox OSE is distributed in the') + k_javadoc_box_line('hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.') + k_javadoc_box_line('') + k_javadoc_box_line('The contents of this file may alternatively be used under the terms') + k_javadoc_box_line('of the Common Development and Distribution License Version 1.0') + k_javadoc_box_line('(CDDL) only, as it comes in the "COPYING.CDDL" file of the') + k_javadoc_box_line('VirtualBox OSE distribution, in which case the provisions of the') + k_javadoc_box_line('CDDL are applicable instead of those of the GPL.') + k_javadoc_box_line('') + k_javadoc_box_line('You may elect to license modified versions of this file under the') + k_javadoc_box_line('terms and conditions of either the GPL or the CDDL or both.') + k_javadoc_box_line('') + k_javadoc_box_line('Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa') + k_javadoc_box_line('Clara, CA 95054 USA or visit http://www.sun.com if you need') + k_javadoc_box_line('additional information or have any questions.') + break; + + default: + + } + k_javadoc_box_line(); + k_javadoc_box_end(); + + up(p_RLine - iCursorLine); + end_line(); + keyin(' '); +} + + + + + + + +/******************************************************************************* +* Keyboard Shortcuts * +*******************************************************************************/ +/** Makes global box. */ +void k_box_globals() +{ + k_box_start('Global'); + k_box_line('Global Variables'); + k_box_end(); +} + +/** Makes header box. */ +void k_box_headers() +{ + k_box_start("Header"); + k_box_line("Header Files"); + k_box_end(); +} + +/** Makes internal function box. */ +void k_box_intfuncs() +{ + k_box_start("IntFunc"); + k_box_line("Internal Functions"); + k_box_end(); +} + +/** Makes def/const box. */ +void k_box_consts() +{ + k_box_start("Const"); + k_box_line("Defined Constants And Macros"); + k_box_end(); +} + +/** Structure box */ +void k_box_structs() +{ + k_box_start("Struct"); + k_box_line("Structures and Typedefs"); + k_box_end(); +} + +/** Makes exported symbols box. */ +void k_box_exported() +{ + k_box_start('Exported'); + k_box_line('Exported Symbols'); + k_box_end(); +} + +/** oneliner comment */ +void k_oneliner() +{ + _str sLeft, sRight; + int iColumn; + if ( k_commentconfig(sLeft, sRight, iColumn) + && iColumn > 0) + { /* column based needs some tricky repositioning. */ + _end_line(); + if (p_col > iColumn) + { + _begin_line(); + _insert_text("\n\r"); + up(); + } + } + k_insert_comment("", KIC_CURSOR_AT_END, ikStyleOneliner); +} + +/** mark line as modified. */ +void k_mark_modified_line() +{ + /* not supported for column based sources */ + _str sLeft, sRight; + int iColumn; + if ( !k_commentconfig(sLeft, sRight, iColumn) + || iColumn > 0) + return; + _str sStr; + if (skChange != '') + sStr = skChange ' (' skUserInitials ')'; + else + sStr = skUserInitials; + k_insert_comment(sStr, KIC_CURSOR_BEFORE, ikStyleModifyMarkColumn); + down(); +} + +/** + * Inserts a signature. Form: "//Initials ISO-date:" + * @remark defeventtab + */ +void k_signature() +{ + /* kso I5-10000 2002-09-10: */ + _str sSig; + if (skChange != '') + sSig = skUserInitials ' ' skChange ' ' k_date() ': '; + else + sSig = skUserInitials ' ' k_date() ': '; + k_insert_comment(sSig, KIC_CURSOR_AT_END); +} + +/* Insert a list of NOREF() macro invocations. */ +void k_noref() +{ + typeless org_pos; + _save_pos2(org_pos); + + _str sNoRefs = ''; + boolean fFoundFn = !k_func_goto_nearest_function(); + if (fFoundFn) + { + _str sArgs = k_func_getparams(); + int cArgs = k_func_countparams(sArgs); + int fVaArgs = 1; + int i; + int offLine = 4; + for (i = 0; i < cArgs; i++) + { + _str sName, sType, sDefault; + if (!k_func_enumparams(sArgs, i, sType, sName, sDefault)) + { + if (!fVaArgs) + { + sThis = 'NOREF(' sName ');'; + if (length(sNoRefs) == 0) + { + sNoRefs = sThis; + offLine += length(sThis); + } + else if (offLine + length(sThis) < 130) + { + sNoRefs = sNoRefs ' ' sThis; + offLine += 1 + length(sThis); + } + else + { + sNoRefs = sNoRefs "\n " sThis; + offLine = 4 + length(sThis); + } + } + else if (length(sNoRefs) == 0) + { + sNoRefs = 'RT_NOREF(' sName; + offLine = length(sNoRefs); + } + else if (offLine + 2 + length(sName) < 130) + { + sNoRefs = sNoRefs ', ' sName; + offLine += 2 + length(sName); + } + else + { + sNoRefs = sNoRefs ',\n ' sName; + offLine += 4 + length(sName); + } + } + } + if (length(sNoRefs) > 0 && fVaArgs != 0) + sNoRefs = sNoRefs ');'; + } + + _restore_pos2(org_pos); + _insert_text(sNoRefs); +} + +/******************************************************************************* +* kLIB Logging * +*******************************************************************************/ +/** + * Hot-Key: Inserts a KLOGENTRY statement at start of nearest function. + */ +void klib_klogentry() +{ + typeless org_pos; + _save_pos2(org_pos); + + /* + * Go to nearest function. + */ + if (!k_func_goto_nearest_function()) + { + /* + * Get parameters. + */ + _str sParams = k_func_getparams(); + if (sParams) + { + _str sRetType = k_func_getreturntype(true); + if (!sRetType || sRetType == "") + sRetType = "void"; /* paranoia! */ + + /* + * Insert text. + */ + if (!k_func_searchcode("{")) + { + p_col++; + int cArgs = k_func_countparams(sParams); + if (cArgs > 0) + { + _str sArgs = ""; + int i; + for (i = 0; i < cArgs; i++) + { + _str sType, sName, sDefault; + if (!k_func_enumparams(sParams, i, sType, sName, sDefault)) + sArgs = sArgs', 'sName; + } + + _insert_text("\n KLOGENTRY"cArgs"(\""sRetType"\",\""sParams"\""sArgs");"); /* todo tab size.. or smart indent */ + } + else + _insert_text("\n KLOGENTRY0(\""sRetType"\");"); /* todo tab size.. or smart indent */ + + /* + * Check if the next word is KLOGENTRY. + */ + next_word(); + if (def_next_word_style == 'E') + prev_word(); + int iIgnorePos = 0; + if (substr(cur_word(iIgnorePos), 1, 9) == "KLOGENTRY") + delete_line(); + + } + else + message("didn't find {"); + } + else + message("k_func_getparams failed, sParams=" sParams); + return; + } + + _restore_pos2(org_pos); +} + + +/** + * Hot-Key: Inserts a KLOGEXIT statement at cursor location. + */ +void klib_klogexit() +{ + typeless org_pos; + _save_pos2(org_pos); + + /* + * Go to nearest function. + */ + if (!prev_proc()) + { + /* + * Get parameters. + */ + _str sType = k_func_getreturntype(true); + _restore_pos2(org_pos); + if (sType) + { + boolean fReturn = true; /* true if an return statment is following the KLOGEXIT statement. */ + + /* + * Insert text. + */ + int cur_col = p_col; + if (sType == 'void' || sType == 'VOID') + { /* procedure */ + int iIgnorePos; + fReturn = cur_word(iIgnorePos) == 'return'; + if (!fReturn) + { + while (p_col <= p_SyntaxIndent) + keyin(" "); + } + + _insert_text("KLOGEXITVOID();\n"); + + if (fReturn) + { + int i; + for (i = 1; i < cur_col; i++) + _insert_text(" "); + } + search(")","E-"); + } + else + { /* function */ + _insert_text("KLOGEXIT();\n"); + int i; + for (i = 1; i < cur_col; i++) + _insert_text(" "); + search(")","E-"); + + /* + * Insert value if possible. + */ + typeless valuepos; + _save_pos2(valuepos); + next_word(); + if (def_next_word_style == 'E') + prev_word(); + int iIgnorePos; + if (cur_word(iIgnorePos) == 'return') + { + p_col += length('return'); + typeless posStart; + _save_pos2(posStart); + long offStart = _QROffset(); + if (!k_func_searchcode(";", "E+")) + { + long offEnd = _QROffset(); + _restore_pos2(posStart); + _str sValue = strip(get_text((int)(offEnd - offStart))); + //say 'sValue = 'sValue; + _restore_pos2(valuepos); + _save_pos2(valuepos); + _insert_text(sValue); + } + } + _restore_pos2(valuepos); + } + + /* + * Remove old KLOGEXIT statement on previous line if any. + */ + typeless valuepos; + _save_pos2(valuepos); + int newexitline = p_line; + p_line--; p_col = 1; + next_word(); + if (def_next_word_style == 'E') + prev_word(); + int iIgnorePos; + if (p_line == newexitline - 1 && substr(cur_word(iIgnorePos), 1, 8) == 'KLOGEXIT') + delete_line(); + _restore_pos2(valuepos); + + /* + * Check for missing '{...}'. + */ + if (fReturn) + { + boolean fFound = false; + _save_pos2(valuepos); + p_col--; find_matching_paren(); p_col += 2; + k_func_searchcode(';', 'E+'); /* places us at the ';' of the return. (hopefully) */ + + _str ch = k_func_get_next_code_text(); + if (ch != '}') + { + _restore_pos2(valuepos); + _save_pos2(valuepos); + p_col--; find_matching_paren(); p_col += 2; + k_func_searchcode(';', 'E+'); /* places us at the ';' of the return. (hopefully) */ + p_col++; + if (k_func_more_code_on_line()) + _insert_text(' }'); + else + { + typeless returnget; + _save_pos2(returnget); + k_func_searchcode("return", "E-"); + int return_col = p_col; + _restore_pos2(returnget); + + end_line(); + _insert_text("\n"); + while (p_col < return_col - p_SyntaxIndent) + _insert_text(' '); + _insert_text('}'); + } + + _restore_pos2(valuepos); + _save_pos2(valuepos); + prev_word(); + p_col -= p_SyntaxIndent; + int codecol = p_col; + _insert_text("{\n"); + while (p_col < codecol) + _insert_text(' '); + } + + _restore_pos2(valuepos); + } + } + else + message("k_func_getreturntype failed, sType=" sType); + return; + } + + _restore_pos2(org_pos); +} + + +/** + * Processes a file - ask user all the time. + */ +void klib_klog_file_ask() +{ + klib_klog_file_int(true); +} + + +/** + * Processes a file - no questions. + */ +void klib_klog_file_no_ask() +{ + klib_klog_file_int(false); +} + + + +/** + * Processes a file. + */ +static void klib_klog_file_int(boolean fAsk) +{ + show_all(); + bottom(); + _refresh_scroll(); + + /* ask question so we can get to the right position somehow.. */ + if (fAsk && _message_box("kLog process this file?", "Visual SlickEdit", MB_YESNO | MB_ICONQUESTION) != IDYES) + return; + + /* + * Entries. + */ + while (!prev_proc()) + { + //say 'entry main loop: ' k_func_getfunction_name(); + + /* + * Skip prototypes. + */ + if (k_func_prototype()) + continue; + + /* + * Ask user. + */ + center_line(); + _refresh_scroll(); + _str sFunction = k_func_getfunction_name(); + rc = fAsk ? _message_box("Process this function ("sFunction")?", "Visual SlickEdit", MB_YESNOCANCEL | MB_ICONQUESTION) : IDYES; + if (rc == IDYES) + { + typeless procpos; + _save_pos2(procpos); + klib_klogentry(); + _restore_pos2(procpos); + } + else if (rc == IDNO) + continue; + else + break; + } + + /* + * Exits. + */ + bottom(); _refresh_scroll(); + boolean fUserCancel = false; + while (!prev_proc() && !fUserCancel) + { + typeless procpos; + _save_pos2(procpos); + _str sCurFunction = k_func_getfunction_name(); + //say 'exit main loop: ' sCurFunction + + /* + * Skip prototypes. + */ + if (k_func_prototype()) + continue; + + /* + * Select procedure. + */ + while ( !k_func_searchcode("return", "WE<+") + && k_func_getfunction_name() == sCurFunction) + { + //say 'exit sub loop: ' p_line + /* + * Ask User. + */ + center_line(); + _refresh_scroll(); + _str sFunction = k_func_getfunction_name(); + rc = fAsk ? _message_box("Process this exit from "sFunction"?", "Visual SlickEdit", MB_YESNOCANCEL | MB_ICONQUESTION) : IDYES; + deselect(); + if (rc == IDYES) + { + typeless returnpos; + _save_pos2(returnpos); + klib_klogexit(); + _restore_pos2(returnpos); + p_line++; + } + else if (rc != IDNO) + { + fUserCancel = true; + break; + } + p_line++; /* just so we won't hit it again. */ + } + + /* + * If void function we'll have to check if there is and return; prior to the ending '}'. + */ + _restore_pos2(procpos); + _save_pos2(procpos); + _str sType = k_func_getreturntype(true); + if (!fUserCancel && sType && (sType == 'void' || sType == 'VOID')) + { + if ( !k_func_searchcode("{", "E+") + && !find_matching_paren()) + { + typeless funcend; + _save_pos2(funcend); + prev_word(); + int iIgnorePos; + if (cur_word(iIgnorePos) != "return") + { + /* + * Ask User. + */ + _restore_pos2(funcend); + center_line(); + _refresh_scroll(); + _str sFunction = k_func_getfunction_name(); + rc = fAsk ? _message_box("Process this exit from "sFunction"?", "Visual SlickEdit", MB_YESNOCANCEL | MB_ICONQUESTION) : IDYES; + deselect(); + if (rc == IDYES) + { + typeless returnpos; + _save_pos2(returnpos); + klib_klogexit(); + _restore_pos2(returnpos); + } + } + } + } + + /* + * Next proc. + */ + _restore_pos2(procpos); + } +} + +/** @todo move to kkeys.e */ +_command void k_rebuild_tagfile() +{ +#if 1 /*__VERSION__ < 14.0*/ + if (file_match('-p 'maybe_quote_filename(strip_filename(_project_name,'e'):+TAG_FILE_EXT),1) != "") + _project_update_files_retag(false, false, false, false); + else + _project_update_files_retag(true, false, false, true); +#else + _str sArgs = "-refs=on"; + if (file_match('-p 'maybe_quote_filename(strip_filename(_project_name,'e'):+TAG_FILE_EXT),1) != "") + sArgs = sArgs :+ " -retag"; + sArgs = sArgs :+ " " :+ _workspace_filename; + build_workspace_tagfiles(sArgs); +#endif +} + + +/******************************************************************************* +* Styles * +*******************************************************************************/ +static _str StyleLanguages[] = +{ + "c", + "e", + "java" +}; + +struct StyleScheme +{ + _str name; + _str settings[]; +}; + +static StyleScheme StyleSchemes[] = +{ + { + "Opt2Ind4", + { + "orig_tabsize=4", + "syntax_indent=4", + "tabsize=4", + "align_on_equal=1", + "pad_condition_state=1", + "indent_with_tabs=0", + "nospace_before_paren=0", + "indent_comments=1", + "indent_case=1", + "statement_comment_col=0", + "disable_bestyle=0", + "decl_comment_col=0", + "bestyle_on_functions=0", + "use_relative_indent=1", + "nospace_before_brace=0", + "indent_fl=1", + "statement_comment_state=2", + "indent_pp=1", + "be_style=1", + "parens_on_return=0", + "eat_blank_lines=0", + "brace_indent=0", + "eat_pp_space=1", + "align_on_parens=1", + "continuation_indent=0", + "cuddle_else=0", + "nopad_condition=1", + "pad_condition=0", + "indent_col1_comments=0" + } + } + , + { + "Opt2Ind3", + { + "orig_tabsize=3", + "syntax_indent=3", + "tabsize=3", + "align_on_equal=1", + "pad_condition_state=1", + "indent_with_tabs=0", + "nospace_before_paren=0", + "indent_comments=1", + "indent_case=1", + "statement_comment_col=0", + "disable_bestyle=0", + "decl_comment_col=0", + "bestyle_on_functions=0", + "use_relative_indent=1", + "nospace_before_brace=0", + "indent_fl=1", + "statement_comment_state=2", + "indent_pp=1", + "be_style=1", + "parens_on_return=0", + "eat_blank_lines=0", + "brace_indent=0", + "eat_pp_space=1", + "align_on_parens=1", + "continuation_indent=0", + "cuddle_else=0", + "nopad_condition=1", + "pad_condition=0", + "indent_col1_comments=0" + } + } + , + { + "Opt2Ind8", + { + "orig_tabsize=8", + "syntax_indent=8", + "tabsize=8", + "align_on_equal=1", + "pad_condition_state=1", + "indent_with_tabs=0", + "nospace_before_paren=0", + "indent_comments=1", + "indent_case=1", + "statement_comment_col=0", + "disable_bestyle=0", + "decl_comment_col=0", + "bestyle_on_functions=0", + "use_relative_indent=1", + "nospace_before_brace=0", + "indent_fl=1", + "statement_comment_state=2", + "indent_pp=1", + "be_style=1", + "parens_on_return=0", + "eat_blank_lines=0", + "brace_indent=0", + "eat_pp_space=1", + "align_on_parens=1", + "continuation_indent=0", + "cuddle_else=0", + "nopad_condition=1", + "pad_condition=0", + "indent_col1_comments=0" + } + } + , + { + "Opt3Ind4", + { + "orig_tabsize=4", + "syntax_indent=4", + "tabsize=4", + "align_on_equal=1", + "pad_condition_state=1", + "indent_with_tabs=0", + "nospace_before_paren=0", + "indent_comments=1", + "indent_case=1", + "statement_comment_col=0", + "disable_bestyle=0", + "decl_comment_col=0", + "bestyle_on_functions=0", + "use_relative_indent=1", + "nospace_before_brace=0", + "indent_fl=1", + "statement_comment_state=2", + "indent_pp=1", + "be_style=2", + "parens_on_return=0", + "eat_blank_lines=0", + "brace_indent=0", + "eat_pp_space=1", + "align_on_parens=1", + "continuation_indent=0", + "cuddle_else=0", + "nopad_condition=1", + "pad_condition=0", + "indent_col1_comments=0" + } + } + , + { + "Opt3Ind3", + { + "orig_tabsize=3", + "syntax_indent=3", + "tabsize=3", + "align_on_equal=1", + "pad_condition_state=1", + "indent_with_tabs=0", + "nospace_before_paren=0", + "indent_comments=1", + "indent_case=1", + "statement_comment_col=0", + "disable_bestyle=0", + "decl_comment_col=0", + "bestyle_on_functions=0", + "use_relative_indent=1", + "nospace_before_brace=0", + "indent_fl=1", + "statement_comment_state=2", + "indent_pp=1", + "be_style=2", + "parens_on_return=0", + "eat_blank_lines=0", + "brace_indent=0", + "eat_pp_space=1", + "align_on_parens=1", + "continuation_indent=0", + "cuddle_else=0", + "nopad_condition=1", + "pad_condition=0", + "indent_col1_comments=0" + } + } +}; + + +static void k_styles_create() +{ + /* + * Find user format ini file. + */ + _str userini = maybe_quote_filename(_config_path():+'uformat.ini'); + if (file_match('-p 'userini, 1) == '') + { + _str ini = maybe_quote_filename(slick_path_search('uformat.ini')); + if (ini != '') userini = ini; + } + + + /* + * Remove any old schemes. + */ + int i,j,tv; + for (i = 0; i < StyleSchemes._length(); i++) + for (j = 0; j < StyleLanguages._length(); j++) + { + _str sectionname = StyleLanguages[j]:+'-scheme-':+StyleSchemes[i].name; + if (!_ini_get_section(userini, sectionname, tv)) + { + _ini_delete_section(userini, sectionname); + _delete_temp_view(tv); + //message("delete old scheme"); + } + } + + /* + * Create the new schemes. + */ + for (i = 0; i < StyleSchemes._length(); i++) + { + for (j = 0; j < StyleLanguages._length(); j++) + { + _str sectionname = StyleLanguages[j]:+'-scheme-':+StyleSchemes[i].name; + int temp_view_id, k; + _str orig_view_id = _create_temp_view(temp_view_id); + activate_view(temp_view_id); + for (k = 0; k < StyleSchemes[i].settings._length(); k++) + insert_line(StyleSchemes[i].settings[k]); + + /* Insert the scheme section. */ + _ini_replace_section(userini, sectionname, temp_view_id); + //message(userini) + //bogus id - activate_view(orig_view_id); + } + } + + //last_scheme = last scheme name!!! +} + + +/* + * Sets the last used beutify scheme. + */ +static k_styles_set(_str scheme) +{ + + /* + * Find user format ini file. + */ + _str userini = maybe_quote_filename(_config_path():+'uformat.ini'); + if (file_match('-p 'userini, 1) == '') + { + _str ini = maybe_quote_filename(slick_path_search('uformat.ini')); + if (ini != '') userini = ini; + } + + /* + * Set the scheme for each language. + */ + int j; + for (j = 0; j < StyleLanguages._length(); j++) + { + _ini_set_value(userini, + StyleLanguages[j]:+'-scheme-Default', + 'last_scheme', + scheme); + } +} + + +static _str defoptions[] = +{ + "def-options-sas", + "def-options-js", + "def-options-bat", + "def-options-c", + "def-options-pas", + "def-options-e", + "def-options-java", + "def-options-bourneshell", + "def-options-csh", + "def-options-vlx", + "def-options-plsql", + "def-options-sqlserver", + "def-options-cmd" +}; + +static _str defsetups[] = +{ + "def-setup-sas", + "def-setup-js", + "def-setup-bat", + "def-setup-fundamental", + "def-setup-process", + "def-setup-c", + "def-setup-pas", + "def-setup-e", + "def-setup-asm", + "def-setup-java", + "def-setup-html", + "def-setup-bourneshell", + "def-setup-csh", + "def-setup-vlx", + "def-setup-fileman", + "def-setup-plsql", + "def-setup-sqlserver", + "def-setup-s", + "def-setup-cmd" +}; + +static _str defsetupstab8[] = +{ + "def-setup-c" +}; + + +static void k_styles_setindent(int indent, int iBraceStyle, boolean iWithTabs = false) +{ + if (iBraceStyle < 1 || iBraceStyle > 3) + { + message('k_styles_setindent: iBraceStyle is bad (=' :+ iBraceStyle :+ ')'); + iBraceStyle = 2; + } + + /* + * def-options for extentions known to have that info. + */ + int i; + for (i = 0; i < defoptions._length(); i++) + { + int idx = find_index(defoptions[i], MISC_TYPE); + if (!idx) + continue; + + parse name_info(idx) with syntax_indent o2 o3 o4 flags indent_fl o7 indent_case rest; + + /* Begin/end style */ + flags = flags & ~(1|2); + flags = flags | (iBraceStyle - 1); /* Set style (0-based) */ + flags = flags & ~(16); /* no scape before parent.*/ + indent_fl = 1; /* Indent first level */ + indent_case = 1; /* Indent case from switch */ + + sNewOptions = indent' 'o2' 'o3' 'o4' 'flags' 'indent_fl' 'o7' 'indent_case' 'rest; + set_name_info(idx, sNewOptions); + _config_modify |= CFGMODIFY_DEFDATA; + } + + /* + * def-setup for known extentions. + */ + for (i = 0; i < defsetups._length(); i++) + { + idx = find_index(defsetups[i], MISC_TYPE); + if (!idx) + continue; + sExt = substr(defsetups[i], length('def-setup-') + 1); + sSetup = name_info(idx); + + /* + parse sSetup with 'MN=' mode_name ','\ + 'TABS=' tabs ',' 'MA=' margins ',' 'KEYTAB=' keytab_name ','\ + 'WW='word_wrap_style ',' 'IWT='indent_with_tabs ','\ + 'ST='show_tabs ',' 'IN='indent_style ','\ + 'WC='word_chars',' 'LN='lexer_name',' 'CF='color_flags','\ + 'LNL='line_numbers_len','rest; + + indent_with_tabs = 0; /* Indent with tabs */ + + /* Make sure all the values are legal */ + _ext_init_values(ext, lexer_name, color_flags); + if (!isinteger(line_numbers_len)) line_numbers_len = 0; + if (word_chars == '') word_chars = 'A-Za-z0-9_$'; + if (word_wrap_style == '') word_wrap_style = 3; + if (show_tabs == '') show_tabs = 0; + if (indent_style == '') indent_style = INDENT_SMART; + + /* Set new indent */ + tabs = '+'indent; + */ + + sNewSetup = sSetup; + + /* Set new indent */ + if (pos('TABS=', sNewSetup) > 0) + { + /* + * If either in defoptions or defsetupstab8 use default tab of 8 + * For those supporting separate syntax indent using the normal tabsize + * helps us a lot when reading it... + */ + fTab8 = false; + for (j = 0; !fTab8 && j < defsetupstab8._length(); j++) + if (substr(defsetupstab8[j], lastpos('-', defsetupstab8[j]) + 1) == sExt) + fTab8 = true; + for (j = 0; !fTab8 && j < defoptions._length(); j++) + if (substr(defoptions[j], lastpos('-', defoptions[j]) + 1) == sExt) + fTab8 = true; + + parse sNewSetup with sPre 'TABS=' sValue ',' sPost; + if (fTab8) + sNewSetup = sPre 'TABS=+8,' sPost + else + sNewSetup = sPre 'TABS=+' indent ',' sPost + } + + /* Set indent with tabs flag. */ + if (pos('IWT=', sNewSetup) > 0) + { + parse sNewSetup with sPre 'IWT=' sValue ',' sPost; + if (iWithTabs) + sNewSetup = sPre 'IWT=1,' sPost + else + sNewSetup = sPre 'IWT=0,' sPost + } + + /* Do the real changes */ + set_name_info(idx, sNewSetup); + _config_modify |= CFGMODIFY_DEFDATA; + _update_buffers(sExt); + } +} + + +/** + * Takes necessary steps to convert a string to integer. + */ +static int k_style_emacs_var_integer(_str sVal) +{ + int i = (int)sVal; + //say 'k_style_emacs_var_integer('sVal') -> 'i; + return (int)sVal; +} + + +/** + * Sets a Emacs style variable. + */ +static int k_style_emacs_var(_str sVar, _str sVal) +{ + /* check input. */ + if (sVar == '' || sVal == '') + return -1; + //say 'k_style_emacs_var: 'sVar'='sVal; + +#if __VERSION__ >= 21.0 + /** @todo figure out p_index. */ + return 0; +#else + + /* + * Unpack the mode style parameters. + */ + _str sStyle = name_info(_edit_window().p_index); + _str sStyleName = p_mode_name; + typeless iIndentAmount, fExpansion, iMinAbbrivation, fIndentAfterOpenParen, iBeginEndStyle, fIndent1stLevel, iMainStyle, iSwitchStyle, + sRest, sRes0, sRes1; + if (sStyleName == 'Slick-C') + { + parse sStyle with iMinAbbrivation sRes0 iBeginEndStyle fIndent1stLevel sRes1 iSwitchStyle sRest; + iIndentAmount = p_SyntaxIndent; + } + else /* C */ + parse sStyle with iIndentAmount fExpansion iMinAbbrivation fIndentAfterOpenParen iBeginEndStyle fIndent1stLevel iMainStyle iSwitchStyle sRest; + + + /* + * Process the variable. + */ + switch (sVar) + { + case 'mode': + case 'Mode': + { + switch (sVal) + { + case 'c': + case 'C': + case 'c++': + case 'C++': + case 'cpp': + case 'CPP': + case 'cxx': + case 'CXX': + p_extension = 'c'; + p_mode_name = 'C'; + break; + + case 'e': + case 'slick-c': + case 'Slick-c': + case 'Slick-C': + p_extension = 'e'; + p_mode_name = 'Slick-C'; + break; + + default: + message('emacs mode "'sVal'" is not known to us'); + return -3; + } + break; + } +/* relevant emacs code: +(defconst c-style-alist + '(("gnu" + (c-basic-offset . 2) + (c-comment-only-line-offset . (0 . 0)) + (c-offsets-alist . ((statement-block-intro . +) + (knr-argdecl-intro . 5) + (substatement-open . +) + (label . 0) + (statement-case-open . +) + (statement-cont . +) + (arglist-intro . c-lineup-arglist-intro-after-paren) + (arglist-close . c-lineup-arglist) + (inline-open . 0) + (brace-list-open . +) + )) + (c-special-indent-hook . c-gnu-impose-minimum) + (c-block-comment-prefix . "") + ) + ("k&r" + (c-basic-offset . 5) + (c-comment-only-line-offset . 0) + (c-offsets-alist . ((statement-block-intro . +) + (knr-argdecl-intro . 0) + (substatement-open . 0) + (label . 0) + (statement-cont . +) + )) + ) + ("bsd" + (c-basic-offset . 8) + (c-comment-only-line-offset . 0) + (c-offsets-alist . ((statement-block-intro . +) + (knr-argdecl-intro . +) + (substatement-open . 0) + (label . 0) + (statement-cont . +) + (inline-open . 0) + (inexpr-class . 0) + )) + ) + ("stroustrup" + (c-basic-offset . 4) + (c-comment-only-line-offset . 0) + (c-offsets-alist . ((statement-block-intro . +) + (substatement-open . 0) + (label . 0) + (statement-cont . +) + )) + ) + ("whitesmith" + (c-basic-offset . 4) + (c-comment-only-line-offset . 0) + (c-offsets-alist . ((knr-argdecl-intro . +) + (label . 0) + (statement-cont . +) + (substatement-open . +) + (block-open . +) + (statement-block-intro . c-lineup-whitesmith-in-block) + (block-close . c-lineup-whitesmith-in-block) + (inline-open . +) + (defun-open . +) + (defun-block-intro . c-lineup-whitesmith-in-block) + (defun-close . c-lineup-whitesmith-in-block) + (brace-list-open . +) + (brace-list-intro . c-lineup-whitesmith-in-block) + (brace-entry-open . c-indent-multi-line-block) + (brace-list-close . c-lineup-whitesmith-in-block) + (class-open . +) + (inclass . c-lineup-whitesmith-in-block) + (class-close . +) + (inexpr-class . 0) + (extern-lang-open . +) + (inextern-lang . c-lineup-whitesmith-in-block) + (extern-lang-close . +) + (namespace-open . +) + (innamespace . c-lineup-whitesmith-in-block) + (namespace-close . +) + )) + ) + ("ellemtel" + (c-basic-offset . 3) + (c-comment-only-line-offset . 0) + (c-hanging-braces-alist . ((substatement-open before after))) + (c-offsets-alist . ((topmost-intro . 0) + (topmost-intro-cont . 0) + (substatement . +) + (substatement-open . 0) + (case-label . +) + (access-label . -) + (inclass . ++) + (inline-open . 0) + )) + ) + ("linux" + (c-basic-offset . 8) + (c-comment-only-line-offset . 0) + (c-hanging-braces-alist . ((brace-list-open) + (brace-entry-open) + (substatement-open after) + (block-close . c-snug-do-while))) + (c-cleanup-list . (brace-else-brace)) + (c-offsets-alist . ((statement-block-intro . +) + (knr-argdecl-intro . 0) + (substatement-open . 0) + (label . 0) + (statement-cont . +) + )) + ) + ("python" + (indent-tabs-mode . t) + (fill-column . 78) + (c-basic-offset . 8) + (c-offsets-alist . ((substatement-open . 0) + (inextern-lang . 0) + (arglist-intro . +) + (knr-argdecl-intro . +) + )) + (c-hanging-braces-alist . ((brace-list-open) + (brace-list-intro) + (brace-list-close) + (brace-entry-open) + (substatement-open after) + (block-close . c-snug-do-while) + )) + (c-block-comment-prefix . "") + ) + ("java" + (c-basic-offset . 4) + (c-comment-only-line-offset . (0 . 0)) + ;; the following preserves Javadoc starter lines + (c-offsets-alist . ((inline-open . 0) + (topmost-intro-cont . +) + (statement-block-intro . +) + (knr-argdecl-intro . 5) + (substatement-open . +) + (label . +) + (statement-case-open . +) + (statement-cont . +) + (arglist-intro . c-lineup-arglist-intro-after-paren) + (arglist-close . c-lineup-arglist) + (access-label . 0) + (inher-cont . c-lineup-java-inher) + (func-decl-cont . c-lineup-java-throws) + )) + ) + ) +*/ + + case 'c-file-style': + case 'c-indentation-style': + switch (sVal) + { + case 'bsd': + case '"bsd"': + case 'BSD': + iBeginEndStyle = 1 | (iBeginEndStyle & ~3); + p_indent_with_tabs = true; + iIndentAmount = 8; + p_SyntaxIndent = 8; + p_tabs = "+8"; + //say 'bsd'; + break; + + case 'k&r': + case '"k&r"': + case 'K&R': + iBeginEndStyle = 0 | (iBeginEndStyle & ~3); + p_indent_with_tabs = false; + iIndentAmount = 4; + p_SyntaxIndent = 4; + p_tabs = "+4"; + //say 'k&r'; + break; + + case 'linux-c': + case '"linux-c"': + iBeginEndStyle = 0 | (iBeginEndStyle & ~3); + p_indent_with_tabs = true; + iIndentAmount = 4; + p_SyntaxIndent = 4; + p_tabs = "+4"; + //say 'linux-c'; + break; + + case 'yet-to-be-found': + iBeginEndStyle = 2 | (iBeginEndStyle & ~3); + p_indent_with_tabs = false; + iIndentAmount = 4; + p_SyntaxIndent = 4; + p_tabs = "+4"; + //say 'todo'; + break; + + default: + message('emacs "'sVar'" value "'sVal'" is not known to us.'); + return -3; + } + break; + + case 'c-label-offset': + { + int i = k_style_emacs_var_integer(sVal); + if (i >= -16 && i <= 16) + { + if (i == -p_SyntaxIndent) + iSwitchStyle = 0; + else + iSwitchStyle = 1; + } + break; + } + + + case 'indent-tabs-mode': + p_indent_with_tabs = sVal == 't'; + break; + + case 'c-indent-level': + case 'c-basic-offset': + { + int i = k_style_emacs_var_integer(sVal); + if (i > 0 && i <= 16) + { + iIndentAmount = i; + p_SyntaxIndent = i; + } + else + { + message('emacs "'sVar'" value "'sVal'" is out of range.'); + return -4; + } + break; + } + + case 'tab-width': + { + int i = k_style_emacs_var_integer(sVal); + if (i > 0 && i <= 16) + p_tabs = '+'i; + else + { + message('emacs "'sVar'" value "'sVal'" is out of range.'); + return -4; + } + break; + } + + case 'nuke-trailing-whitespace-p': + { +#if 0 + _str sName = 'def-koptions-'p_buf_id; + int idx = insert_name(sName, MISC_TYPE, "kstyledoc"); + if (!idx) + idx = find_index(sName, MISC_TYPE); + if (idx) + { + if (sVal == 't') + set_name_info(idx, "saveoptions: +S"); + else + set_name_info(idx, "saveoptions: -S"); + say 'sVal=' sVal; + } +#endif + break; + } + + default: + message('emacs variable "'sVar'" (value "'sVal'") is unknown to us.'); + return -5; + } + + /* + * Update the style? + */ + _str sNewStyle = ""; + if (sStyleName == 'Slick-C') + sNewStyle = iMinAbbrivation' 'sRes0' 'iBeginEndStyle' 'fIndent1stLevel' 'sRes1' 'iSwitchStyle' 'sRest; + else + sNewStyle = iIndentAmount' 'fExpansion' 'iMinAbbrivation' 'fIndentAfterOpenParen' 'iBeginEndStyle' 'fIndent1stLevel' 'iMainStyle' 'iSwitchStyle' 'sRest; + if ( sNewStyle != "" + && sNewStyle != sStyle + && sStyleName == p_mode_name) + { + _str sName = name_name(_edit_window().p_index) + //say ' sStyle='sStyle' p_mode_name='p_mode_name; + //say 'sNewStyle='sNewStyle' sName='sName; + if (pos('kstyledoc-', sName) <= 0) + { + sName = 'def-kstyledoc-'p_buf_id; + int idx = insert_name(sName, MISC_TYPE, "kstyledoc"); + if (!idx) + idx = find_index(sName, MISC_TYPE); + if (idx) + { + if (!set_name_info(idx, sNewStyle)) + _edit_window().p_index = idx; + } + //say sName'='idx; + } + else + set_name_info(_edit_window().p_index, sNewStyle); + } + + return 0; +#endif +} + + +/** + * Parses a string with emacs variables. + * + * The variables are separated by new line. Junk at + * the start and end of the line is ignored. + */ +static int k_style_emac_vars(_str sVars) +{ + /* process them line by line */ + int iLine = 0; + while (sVars != '' && iLine++ < 20) + { + int iNext, iEnd; + iEnd = iNext = pos("\n", sVars); + if (iEnd <= 0) + iEnd = iNext = length(sVars); + else + iEnd--; + iNext++; + + sLine = strip(substr(sVars, 1, iEnd), 'B', " \t\n\r"); + sVars = strip(substr(sVars, iNext), 'L', " \t\n\r"); + //say 'iLine='iLine' sVars='sVars'<eol>'; + //say 'iLine='iLine' sLine='sLine'<eol>'; + if (sLine != '') + { + rc = pos('[^a-zA-Z0-9-_]*([a-zA-Z0-9-_]+)[ \t]*:[ \t]*([^ \t]*)', sLine, 1, 'U'); + //say '0={'pos('S0')','pos('0')',"'substr(sLine,pos('S0'),pos('0'))'"' + //say '1={'pos('S1')','pos('1')',"'substr(sLine,pos('S1'),pos('1'))'"' + //say '2={'pos('S2')','pos('2')',"'substr(sLine,pos('S2'),pos('2'))'"' + //say '3={'pos('S3')','pos('3')',"'substr(sLine,pos('S3'),pos('3'))'"' + //say '4={'pos('S4')','pos('4')',"'substr(sLine,pos('S4'),pos('4'))'"' + if (rc > 0) + k_style_emacs_var(substr(sLine,pos('S1'),pos('1')), + substr(sLine,pos('S2'),pos('2'))); + } + } + return 0; +} + +/** + * Searches for Emacs style specification for the current document. + */ +void k_style_load() +{ + /* save the position before we start looking around the file. */ + typeless saved_pos; + _save_pos2(saved_pos); + + int rc; + + /* Check first line. */ + top_of_buffer(); + _str sLine; + get_line(sLine); + strip(sLine); + if (pos('-*-[ \t]+(.*:.*)[ \t]+-*-', sLine, 1, 'U')) + { + _str sVars; + sVars = substr(sLine, pos('S1'), pos('1')); + sVars = translate(sVars, "\n", ";"); + k_style_emac_vars(sVars); + } + + /* Look for the "Local Variables:" stuff from the end of the file. */ + bottom_of_buffer(); + rc = search('Local Variables:[ \t]*\n\om(.*)\ol\n.*End:.*\n', '-EU'); + if (!rc) + { + /* copy the variables out to a buffer. */ + _str sVars; + sVars = get_text(match_length("1"), match_length("S1")); + k_style_emac_vars(sVars); + } + + _restore_pos2(saved_pos); +} + + +/** + * Callback function for the event of a new buffer. + * + * This is used to make sure there are no left over per buffer options + * hanging around. + */ +void _buffer_add_kdev(int buf_id) +{ + _str sName = 'def-koptions-'buf_id; + int idx = find_index(sName, MISC_TYPE); + if (idx) + delete_name(idx); + //message("_buffer_add_kdev: " idx " name=" sName); + + sName = 'def-kstyledoc-'buf_id; + idx = find_index(sName, MISC_TYPE); + if (idx) + delete_name(idx); + + //k_style_load(); +} + + +/** + * Callback function for the event of quitting a buffer. + * + * This is used to make sure there are no left over per buffer options + * hanging around. + */ +void _cbquit2_kdev(int buf_id) +{ + _str sName = 'def-koptions-'buf_id; + int idx = find_index(sName, MISC_TYPE); + if (idx) + delete_name(idx); + //message("_cbquit2_kdev: " idx " " sName); + + sName = 'def-kstyledoc-'buf_id; + idx = find_index(sName, MISC_TYPE); + if (idx) + delete_name(idx); +} + + +/** + * Called to get save options for the current buffer. + * + * This requires a modified loadsave.e! + */ +_str _buffer_save_kdev(int buf_id) +{ + _str sRet = "" + _str sName = 'def-koptions-'buf_id; + int idx = find_index(sName, MISC_TYPE); + if (idx) + { + _str sOptions = strip(name_info(idx)); + if (sOptions != "") + parse sOptions with . "saveoptions:" sRet . + message("_buffer_save_kdev: " idx " " sName " " sOptions); + } + return sRet; +} + + +/** + * Command similar to the add() command in math.e, only this + * produces hex and doesn't do the multi line stuff. + */ +_command int k_calc() +{ + _str sLine; + filter_init(); + typeless rc = filter_get_string(sLine); + if (rc == 0) + { + _str sResultHex; + rc = eval_exp(sResultHex, sLine, 16); + if (rc == 0) + { + _str sResultDec; + rc = eval_exp(sResultDec, sLine, 10); + if (rc == 0) + { + _end_select(); + _insert_text(' = ' :+ sResultHex :+ ' (' :+ sResultDec :+ ')'); + return 0; + } + } + } + + if (isinteger(rc)) + message(get_message(rc)); + else + message(rc); + return 1; +} + + + +/******************************************************************************* +* Menu and Menu commands * +*******************************************************************************/ +#ifdef KDEV_WITH_MENU +#if __VERSION__ < 18.0 /* Something with timers are busted, so excusing my code. */ +static int iTimer = 0; +#endif +static int mhkDev = 0; +static int mhCode = 0; +static int mhDoc = 0; +static int mhLic = 0; +static int mhPre = 0; + +/* + * Creates the kDev menu. + */ +static k_menu_create() +{ +# if __VERSION__ < 18.0 /* Something with timers are busted, so excusing my code. */ + if (arg(1) == 'timer') + _kill_timer(iTimer); +# endif + menu_handle = _mdi.p_menu_handle; + menu_index = find_index(_cur_mdi_menu,oi2type(OI_MENU)); + + /* + * Remove any old menu. + */ + mhDelete = iPos = 0; + index = _menu_find(menu_handle, "kDev", mhDelete, iPos, 'C'); + //message("index="index " mhDelete="mhDelete " iPos="iPos); + if (index == 0) + _menu_delete(mhDelete, iPos); + + + /* + * Insert the "kDev" menu. + */ + mhkDev = _menu_insert(menu_handle, 9, MF_SUBMENU, "&kDev", "", "kDev"); + mhCode=_menu_insert(mhkDev, -1, MF_ENABLED | MF_SUBMENU, "Coding &Style", "", "coding"); + rc = _menu_insert(mhCode, -1, MF_ENABLED | MF_UNCHECKED, "Braces 2, Syntax Indent 4 (knut)", "k_menu_style Opt2Ind4", "Opt2Ind4"); + rc = _menu_insert(mhCode, -1, MF_ENABLED | MF_UNCHECKED, "Braces 2, Syntax Indent 3", "k_menu_style Opt2Ind3", "Opt2Ind3"); + rc = _menu_insert(mhCode, -1, MF_ENABLED | MF_UNCHECKED, "Braces 2, Syntax Indent 8", "k_menu_style Opt2Ind8", "Opt2Ind8"); + rc = _menu_insert(mhCode, -1, MF_ENABLED | MF_UNCHECKED, "Braces 3, Syntax Indent 4 (giws)", "k_menu_style Opt3Ind4", "Opt3Ind4"); + rc = _menu_insert(mhCode, -1, MF_ENABLED | MF_UNCHECKED, "Braces 3, Syntax Indent 3 (giws)", "k_menu_style Opt3Ind3", "Opt3Ind3"); + + mhDoc= _menu_insert(mhkDev, -1, MF_ENABLED | MF_SUBMENU, "&Documentation", "", "doc"); + mhDSJ= _menu_insert(mhDoc, -1, MF_ENABLED | MF_UNCHECKED, "&Javadoc Style", "k_menu_doc_style javadoc", "javadoc"); + mhDSL= _menu_insert(mhDoc, -1, MF_GRAYED | MF_UNCHECKED, "&Linux Kernel Style", "k_menu_doc_style linux", "linux"); + + mhLic= _menu_insert(mhkDev, -1, MF_ENABLED | MF_SUBMENU, "&License", "", "License"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&Odin32", "k_menu_license Odin32", "Odin32"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&GPL", "k_menu_license GPL", "GPL"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&LGPL", "k_menu_license LGPL", "LGPL"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&GPLv3", "k_menu_license GPLv3", "GPLv3"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&LGPLv3", "k_menu_license LGPLv3", "LGPLv3"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&VirtualBox", "k_menu_license VirtualBox", "VirtualBox"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&VirtualBox GPL And CDDL","k_menu_license VirtualBoxGPLAndCDDL", "VirtualBoxGPLAndCDDL"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&Confidential", "k_menu_license Confidential", "Confidential"); + rc = _menu_insert(mhLic, -1, MF_ENABLED | MF_UNCHECKED, "&Confidential No Author", "k_menu_license ConfidentialNoAuthor", "ConfidentialNoAuthor"); + + rc = _menu_insert(mhkDev, -1, MF_ENABLED, "-", "", "dash vars"); + rc = _menu_insert(mhkDev, -1, MF_ENABLED, skChange == '' ? '&Change...' : '&Change (' skChange ')...', "k_menu_change", ""); + rc = _menu_insert(mhkDev, -1, MF_ENABLED, skProgram == '' ? '&Program...' : '&Program (' skProgram ')...', "k_menu_program", ""); + rc = _menu_insert(mhkDev, -1, MF_ENABLED, skCompany == '' ? 'Co&mpany...' : 'Co&mpany (' skCompany ')...', "k_menu_company", ""); + rc = _menu_insert(mhkDev, -1, MF_ENABLED, '&User Name (' skUserName ')...', "k_menu_user_name", "username"); + rc = _menu_insert(mhkDev, -1, MF_ENABLED, 'User &e-mail (' skUserEmail ')...', "k_menu_user_email", "useremail"); + rc = _menu_insert(mhkDev, -1, MF_ENABLED, 'User &Initials (' skUserInitials ')...', "k_menu_user_initials", "userinitials"); + rc = _menu_insert(mhkDev, -1, MF_ENABLED, "-", "", "dash preset"); + mhPre= _menu_insert(mhkDev, -1, MF_SUBMENU, "P&resets", "", ""); + rc = _menu_insert(mhPre, -1, MF_ENABLED, "The Bird", "k_menu_preset javadoc, GPL, Opt2Ind4", "bird"); + rc = _menu_insert(mhPre, -1, MF_ENABLED, "kLIBC", "k_menu_preset javadoc, GPL, Opt2Ind4,, kLIBC", "kLIBC"); + rc = _menu_insert(mhPre, -1, MF_ENABLED, "kBuild", "k_menu_preset javadoc, GPLv3, Opt2Ind4,, kBuild", "kBuild"); + rc = _menu_insert(mhPre, -1, MF_ENABLED, "kStuff", "k_menu_preset javadoc, GPL, Opt2Ind4,, kStuff", "kStuff"); + rc = _menu_insert(mhPre, -1, MF_ENABLED, "sun", "k_menu_preset javadoc, ConfidentialNoAuthor, Opt2Ind4, sun", "sun"); + rc = _menu_insert(mhPre, -1, MF_ENABLED, "VirtualBox", "k_menu_preset javadoc, VirtualBox, Opt2Ind4, sun", "VirtualBox"); + + k_menu_doc_style(); + k_menu_license(); + k_menu_style(); +} + + +/** + * Change change Id. + */ +_command k_menu_change() +{ + sRc = show("-modal k_form_simple_input", "Change ID", skChange); + if (sRc != "\r") + { + skChange = sRc; + k_menu_create(); + } +} + + +/** + * Change program name. + */ +_command k_menu_program() +{ + sRc = show("-modal k_form_simple_input", "Program", skProgram); + if (sRc != "\r") + { + skProgram = sRc; + k_menu_create(); + } +} + + +/** + * Change company. + */ +_command k_menu_company() +{ + if (skCompany == '') + sRc = show("-modal k_form_simple_input", "Company", 'innotek GmbH'); + else + sRc = show("-modal k_form_simple_input", "Company", skCompany); + if (sRc != "\r") + { + skCompany = sRc; + k_menu_create(); + } +} + + +/** + * Change user name. + */ +_command k_menu_user_name() +{ + sRc = show("-modal k_form_simple_input", "User Name", skUserName); + if (sRc != "\r" && sRc != '') + { + skUserName = sRc; + k_menu_create(); + } +} + + +/** + * Change user email. + */ +_command k_menu_user_email() +{ + sRc = show("-modal k_form_simple_input", "User e-mail", skUserEmail); + if (sRc != "\r" && sRc != '') + { + skUserEmail = sRc; + k_menu_create(); + } +} + + +/** + * Change user initials. + */ +_command k_menu_user_initials() +{ + sRc = show("-modal k_form_simple_input", "User e-mail", skUserInitials); + if (sRc != "\r" && sRc != '') + { + skUserInitials = sRc; + k_menu_create(); + } +} + + + +/** + * Checks the correct menu item. + */ +_command void k_menu_doc_style(_str sNewDocStyle = '') +{ + //say 'sNewDocStyle='sNewDocStyle; + if (sNewDocStyle != '') + skDocStyle = sNewDocStyle + _menu_set_state(mhDoc, "javadoc", MF_UNCHECKED); + _menu_set_state(mhDoc, "linux", MF_UNCHECKED | MF_GRAYED); + + _menu_set_state(mhDoc, skDocStyle, MF_CHECKED); +} + + +/** + * Checks the correct menu item. + */ +_command void k_menu_license(_str sNewLicense = '') +{ + //say 'sNewLicense='sNewLicense; + if (sNewLicense != '') + skLicense = sNewLicense + _menu_set_state(mhLic, "Odin32", MF_UNCHECKED); + _menu_set_state(mhLic, "GPL", MF_UNCHECKED); + _menu_set_state(mhLic, "LGPL", MF_UNCHECKED); + _menu_set_state(mhLic, "GPLv3", MF_UNCHECKED); + _menu_set_state(mhLic, "LGPLv3", MF_UNCHECKED); + _menu_set_state(mhLic, "VirtualBox", MF_UNCHECKED); + _menu_set_state(mhLic, "VirtualBoxGPLAndCDDL", MF_UNCHECKED); + _menu_set_state(mhLic, "Confidential", MF_UNCHECKED); + _menu_set_state(mhLic, "ConfidentialNoAuthor", MF_UNCHECKED); + + _menu_set_state(mhLic, skLicense, MF_CHECKED); +} + + +/** + * Check the correct style menu item. + */ +_command void k_menu_style(_str sNewStyle = '') +{ + //say 'sNewStyle='sNewStyle; + _menu_set_state(mhCode, "Opt1Ind4", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt1Ind3", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt1Ind8", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt2Ind4", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt2Ind3", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt2Ind8", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt3Ind4", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt3Ind3", MF_UNCHECKED); + _menu_set_state(mhCode, "Opt3Ind8", MF_UNCHECKED); + + if (sNewStyle != '') + { + int iIndent = (int)substr(sNewStyle, 8, 1); + int iBraceStyle = (int)substr(sNewStyle, 4, 1); + skCodeStyle = sNewStyle; + k_styles_setindent(iIndent, iBraceStyle); + k_styles_set(sNewStyle); + } + + _menu_set_state(mhCode, skCodeStyle, MF_CHECKED); +} + + +/** + * Load a 'preset'. + */ +_command void k_menu_preset(_str sArgs = '') +{ + parse sArgs with sNewDocStyle ',' sNewLicense ',' sNewStyle ',' sNewCompany ',' sNewProgram ',' sNewChange + sNewDocStyle= strip(sNewDocStyle); + sNewLicense = strip(sNewLicense); + sNewStyle = strip(sNewStyle); + sNewCompany = strip(sNewCompany); + if (sNewCompany == 'sun') + sNewCompany = 'Sun Microsystems, Inc.' + sNewProgram = strip(sNewProgram); + sNewChange = strip(sNewChange); + + //say 'k_menu_preset('sNewDocStyle',' sNewLicense',' sNewStyle',' sNewCompany',' sNewProgram')'; + k_menu_doc_style(sNewDocStyle); + k_menu_license(sNewLicense); + k_menu_style(sNewStyle); + skCompany = sNewCompany; + skProgram = sNewProgram; + skChange = sNewChange; + k_menu_create(); +} + + + +/* future ones.. +_command k_menu_setcolor() +{ + createMyColorSchemeAndUseIt(); +} + + +_command k_menu_setkeys() +{ + rc = load("d:/knut/VSlickMacros/BoxerDef.e"); +} + +_command k_menu_settings() +{ + mySettings(); +} +*/ + + +#endif /* KDEV_WITH_MENU */ + + +/******************************************************************************* +* Dialogs * +*******************************************************************************/ +_form k_form_simple_input { + p_backcolor=0x80000005 + p_border_style=BDS_DIALOG_BOX + p_caption='Simple Input' + p_clip_controls=FALSE + p_forecolor=0x80000008 + p_height=1120 + p_width=5020 + p_x=6660 + p_y=6680 + _text_box entText { + p_auto_size=TRUE + p_backcolor=0x80000005 + p_border_style=BDS_FIXED_SINGLE + p_completion=NONE_ARG + p_font_bold=FALSE + p_font_italic=FALSE + p_font_name='MS Sans Serif' + p_font_size=8 + p_font_underline=FALSE + p_forecolor=0x80000008 + p_height=270 + p_tab_index=1 + p_tab_stop=TRUE + p_text='text' + p_width=3180 + p_x=1680 + p_y=240 + p_eventtab2=_ul2_textbox + } + _label lblLabel { + p_alignment=AL_VCENTERRIGHT + p_auto_size=FALSE + p_backcolor=0x80000005 + p_border_style=BDS_NONE + p_caption='Label' + p_font_bold=FALSE + p_font_italic=FALSE + p_font_name='MS Sans Serif' + p_font_size=8 + p_font_underline=FALSE + p_forecolor=0x80000008 + p_height=240 + p_tab_index=2 + p_width=1380 + p_word_wrap=FALSE + p_x=180 + p_y=240 + } + _command_button btnOK { + p_cancel=FALSE + p_caption='&OK' + p_default=TRUE + p_font_bold=FALSE + p_font_italic=FALSE + p_font_name='MS Sans Serif' + p_font_size=8 + p_font_underline=FALSE + p_height=360 + p_tab_index=3 + p_tab_stop=TRUE + p_width=1020 + p_x=180 + p_y=660 + } + _command_button btnCancel { + p_cancel=TRUE + p_caption='Cancel' + p_default=FALSE + p_font_bold=FALSE + p_font_italic=FALSE + p_font_name='MS Sans Serif' + p_font_size=8 + p_font_underline=FALSE + p_height=360 + p_tab_index=4 + p_tab_stop=TRUE + p_width=840 + p_x=1380 + p_y=660 + } +} + +defeventtab k_form_simple_input +btnOK.on_create(_str sLabel = '', _str sText = '') +{ + p_active_form.p_caption = sLabel; + lblLabel.p_caption = sLabel; + entText.p_text = sText; +} + +btnOK.lbutton_up() +{ + sText = entText.p_text; + p_active_form._delete_window(sText); +} +btnCancel.lbutton_up() +{ + sText = entText.p_text; + p_active_form._delete_window("\r"); +} + +static _str aCLikeIncs[] = +{ + "c", "ansic", "java", "rul", "vera", "cs", "js", "as", "idl", "asm", "s", "imakefile", "rc", "lex", "yacc", "antlr" +}; + +static _str aMyLangIds[] = +{ + "applescript", + "ansic", + "antlr", + "as", +#if __VERSION__ < 19.0 + "asm", +#endif + "c", + "cs", + "csh", + "css", + "conf", + "d", + "docbook", + "dtd", + "e", + "html", + "idl", + "imakefile", + "ini", + "java", + "js", + "lex", + "mak", + "masm", + "pas", + "phpscript", + "powershell", + "py", + "rexx", + "rc", + "rul", + "tcl", +#if __VERSION__ < 19.0 + "s", +#endif + "unixasm", + "vbs", + "xhtml", + "xml", + "xmldoc", + "xsd", + "yacc" +}; + +#if __VERSION__ >= 17.0 +# require "se/lang/api/LanguageSettings.e" +using se.lang.api.LanguageSettings; +#endif + +#if __VERSION__ >= 16.0 +int def_auto_unsurround_block; +#endif + +#if __VERSION__ >= 21.0 +int def_gui_find_default; +#endif + +static void kdev_ext_to_lang(_str sExt, _str idLang) +{ +#if __VERSION__ >= 21.0 // dunno when exactly. + _SetExtensionReferTo(sExt, idLang); +#else + replace_def_data("def-lang-for-ext-" :+ sExt, idLand); +#endif +} + +#if __VERSION__ >= 21.0 + +static _str kdev_load_lexer(_str sFilename) +{ + int rc = cload(sFilename); + if (rc == 0) + return ""; + return ' Failed to load "' sFilename "': " rc ";"; +} + +/** Doesn't seems like there is an API to just load a bunch of profiles, only I + * could find would load one named profile for a specific language, making it + * the new profile for that language. So, a little extra work here. */ +static _str kdev_load_beautifier_profiles(_str sFilename) +{ + _str sRet = ''; + int iStatus = 0; + auto hXml = _xmlcfg_open(sFilename, iStatus); + if (hXml >= 0) + { + _str asProfiles[]; + iStatus = _xmlcfg_find_simple_array(hXml, "//profile/@n", asProfiles, TREE_ROOT_INDEX, VSXMLCFG_FIND_VALUES, -1); + _xmlcfg_close(hXml); + + _str sProfile; + foreach (sProfile in asProfiles) + { + _str asElements[] = split2array(sProfile, '.'); + _str sLangId = asElements[1]; + _str sProfileName = substr(sProfile, 1 + length(asElements[0]) + + 1 + length(asElements[1]) + + 1 + length(asElements[2]) + 1); + //say("sLangId='" sLangId "' sProfileName='" sProfileName "'; "); + _str sErr = _new_beautifier_config_import_settings(sFilename, sProfileName, sLangId); + if (sErr != "") + sRet = ' Failed to load "' sProfileName "' for '" sLangId "' from '" sFilename "': " sRet ";"; + } + } + else + sRet = " Failed to open '" sFilename "': " hXml ";"; + return sRet; +} + +#endif + +/** + * Loads the standard bird settings. + */ +_command void kdev_load_settings(_str sScriptDir = "") +{ + typeless nt1; + typeless nt2; + typeless nt3; + typeless nt4; + typeless nt5; + typeless nt6; + typeless i7; + _str sRest; + _str sTmp; + _str sMsg = 'Please restart SlickEdit.'; + + /* + * Validate script dir argument. + */ + sScriptDir = _maybe_unquote_filename(sScriptDir); + if (sScriptDir == "") + { + message("Need script dir argument!"); + return; + } + if (!file_exists(sScriptDir :+ "/lexer-kmk.cfg.xml")) + { + message("Invalid script dir '" sScriptDir "' no lexer-kmk.cfg.xml file found!"); + return; + } + +#if __VERSION__ >= 21.0 + /* + * Load the color profiles (was lexer). + */ + sMsg = sMsg :+ kdev_load_lexer(sScriptDir :+ "/lexer-kmk-v2.cfg.xml"); + + /* + * Load project templates for kBuild. + */ + int rc = importProjectPacks(sScriptDir :+ "/usrprjtemplates.vpt"); + if (rc != 0) + sMsg = sMsg :+ " importProjectPacks(usrprjtemplates.vpt)->" :+ rc :+ ";"; + + /* + * Load the beautifier profiles. + */ + sMsg = sMsg :+ kdev_load_beautifier_profiles(sScriptDir :+ "/beautifier-profiles.cfg.xml"); + + /* + * Load color and select scheme. + */ + _str sErr = _color_form_import_settings(sScriptDir :+ "/color_profiles.cfg.xml", 'Solarized Dark'); + if (sErr != "") + sMsg = sMsg :+ " _color_form_import_settings(color_profiles.cfg.xml)->" :+ sErr :+ ";"; + _app_theme('Dark', true); +#endif + + /* + * General stuff. + */ + _default_option('A', '0'); /* ALT menu */ + def_alt_menu = 0; + _default_option('R', '130'); /* Vertical line in column 130. */ + def_mfsearch_init_flags = 2 | 4; /* MFSEARCH_INIT_CURWORD | MFSEARCH_INIT_SELECTION */ + def_line_insert = 'B'; /* insert before */ + def_updown_col=0; /* cursor movement */ + def_cursorwrap=0; /* ditto. */ + def_click_past_end=1; /* ditto */ + def_start_on_first=1; /* vs A B C; view A. */ + def_vc_system='Subversion' /* svn is default version control */ +#if __VERSION__ >= 16.0 + def_auto_unsurround_block=0; /* Delete line, not block. */ +#endif + _config_modify_flags(CFGMODIFY_DEFDATA); + +#if __VERSION__ < 21.0 /* I think this is obsolete... */ + def_file_types='All Files (*),' /** @todo make this prettier */ + 'C/C++ Files (*.c;*.cc;*.cpp;*.cp;*.cxx;*.c++;*.h;*.hh;*.hpp;*.hxx;*.inl;*.xpm),' + 'Assembler (*.s;*.asm;*.mac;*.S),' + 'Makefiles (*;*.mak;*.kmk)' + 'C# Files (*.cs),' + 'Ch Files (*.ch;*.chf;*.chs;*.cpp;*.h),' + 'D Files (*.d),' + 'Java Files (*.java),' + 'HTML Files (*.htm;*.html;*.shtml;*.asp;*.jsp;*.php;*.php3;*.rhtml;*.css),' + 'CFML Files (*.cfm;*.cfml;*.cfc),' + 'XML Files (*.xml;*.dtd;*.xsd;*.xmldoc;*.xsl;*.xslt;*.ent;*.tld;*.xhtml;*.build;*.plist),' + 'XML/SGML DTD Files (*.xsd;*.dtd),' + 'XML/JSP TagLib Files (*.tld;*.xml),' + 'Objective-C (*.m;*.mm;*.h),' + 'IDL Files (*.idl),' + 'Ada Files (*.ada;*.adb;*.ads),' + 'Applescript Files (*.applescript),' + 'Basic Files (*.vb;*.vbs;*.bas;*.frm),' + 'Cobol Files (*.cob;*.cbl;*.ocb),' + 'JCL Files (*.jcl),' + 'JavaScript (*.js;*.ds),' + 'ActionScript (*.as),' + 'Pascal Files (*.pas;*.dpr),' + 'Fortran Files (*.for;*.f),' + 'PL/I Files (*.pl1),' + 'InstallScript (*.rul),' + 'Perl Files (*.pl;*.pm;*.perl;*.plx),' + 'Python Files (*.py),' + 'Ruby Files (*.rb;*.rby),' + 'Java Properties (*.properties),' + 'Lua Files (*.lua),' + 'Tcl Files (*.tcl;*.tlib;*.itk;*.itcl;*.exp),' + 'PV-WAVE (*.pro),' + 'Slick-C (*.e;*.sh),' + 'SQL Files (*.sql;*.pgsql),' + 'SAS Files (*.sas),' + 'Text Files (*.txt),' + 'Verilog Files (*.v),' + 'VHDL Files (*.vhd),' + 'SystemVerilog Files (*.sv;*.svh;*.svi),' + 'Vera Files (*.vr;*.vrh),' + 'Erlang Files (*.erl;*.hrl),' + ; +#endif + + /* Make it grok: # include <stuff.h> */ + for (i = 0; i < aCLikeIncs._length(); i++) + replace_def_data("def-":+aCLikeIncs[i]:+"-include", + '^[ \t]*(\#[ \t]*include|include|\#[ \t]*line)[ \t]#({#1:i}[ \t]#|)(<{#0[~>]#}>|"{#0[~"]#}")'); + replace_def_data("def-m-include", '^[ \t]*(\#[ \t]*include|\#[ \t]*import|include|\#[ \t]*line)[ \t]#({#1:i}[ \t]#|)(<{#0[~>]#}>|"{#0[~"]#}")'); + replace_def_data("def-e-include", '^[ \t]*(\#[ \t]*include|\#[ \t]*import|\#[ \t]*require|include)[ \t]#(''{#0[~'']#}''|"{#0[~"]#}")'); + + /* Replace the default unicode proportional font with the fixed oned. */ + _str sCodeFont = _default_font(CFG_SBCS_DBCS_SOURCE_WINDOW); + _str sUnicodeFont = _default_font(CFG_UNICODE_SOURCE_WINDOW); + if (pos("Default Unicode", sUnicodeFont) > 0 && length(sCodeFont) > 5) + _default_font(CFG_UNICODE_SOURCE_WINDOW,sCodeFont); + if (machine()=='INTELSOLARIS' || machine()=='SPARCSOLARIS') + { + _default_font(CFG_MENU,'DejaVu Sans,10,0,0,'); + _default_font(CFG_DIALOG,'DejaVu Sans,10,0,,'); + _ConfigEnvVar('VSLICKDIALOGFONT','DejaVu Sans,10,0,,'); + } + + /* Not so important. */ + int fSearch = 0x400400; /* VSSEARCHFLAG_WRAP | VSSEARCHFLAG_PROMPT_WRAP */; + _default_option('S', (_str)fSearch); + + +#if __VERSION__ >= 17.0 + /* + * Language settings via API. + */ + int fNewAff = AFF_BEGIN_END_STYLE \ + | AFF_INDENT_WITH_TABS \ + | AFF_SYNTAX_INDENT \ + /*| AFF_TABS*/ \ + | AFF_NO_SPACE_BEFORE_PAREN \ + | AFF_PAD_PARENS \ + | AFF_INDENT_CASE \ + | AFF_KEYWORD_CASING \ + | AFF_TAG_CASING \ + | AFF_ATTRIBUTE_CASING \ + | AFF_VALUE_CASING \ + /*| AFF_HEX_VALUE_CASING*/; + def_adaptive_formatting_flags = ~fNewAff; + replace_def_data("def-adaptive-formatting-flags", def_adaptive_formatting_flags); + _str sLangId; + foreach (sLangId in aMyLangIds) + { + LanguageSettings.setIndentCaseFromSwitch(sLangId, true); + LanguageSettings.setBeginEndStyle(sLangId, BES_BEGIN_END_STYLE_2); + LanguageSettings.setIndentWithTabs(sLangId, false); + LanguageSettings.setUseAdaptiveFormatting(sLangId, true); + LanguageSettings.setAdaptiveFormattingFlags(sLangId, ~fNewAff); + LanguageSettings.setSaveStripTrailingSpaces(sLangId, STSO_STRIP_MODIFIED); + LanguageSettings.setTabs(sLangId, "8+"); + LanguageSettings.setSyntaxIndent(sLangId, 4); + + /* C/C++ setup, fixed comment width of 80 not 64, no max column. */ +# if __VERSION__ >= 21.0 + _SetCommentWrapFlags(CW_MAX_RIGHT, false, sLangId); + _SetCommentWrapFlags(CW_USE_FIXED_WIDTH, true, sLangId); + if (_LangGetPropertyInt32(sLangId, VSLANGPROPNAME_CW_FIXED_WIDTH_SIZE) < 80) + _LangSetPropertyInt32(sLangId, VSLANGPROPNAME_CW_FIXED_WIDTH_SIZE, 80); +# else + sTmp = LanguageSettings.getCommentWrapOptions(sLangId); + if (length(sTmp) > 10) + { + typeless ntBlockCommentWrap, ntDocCommentWrap, ntFixedWidth; + parse sTmp with ntBlockCommentWrap ntDocCommentWrap nt3 nt4 nt5 ntFixedWidth sRest; + if ((int)ntFixedWidth < 80) + LanguageSettings.setCommentWrapOptions('c', ntBlockCommentWrap:+' ':+ntDocCommentWrap:+' ':+nt3:+' ':+nt4:+' ':+nt5:+' 80 ':+sRest); + //replace_def_data("def-comment-wrap-c",'0 1 0 1 1 64 0 0 80 0 80 0 80 0 0 1 '); - default + //replace_def_data("def-comment-wrap-c",'0 1 0 1 1 80 0 0 80 0 80 0 80 0 0 0 '); - disabled + //replace_def_data("def-comment-wrap-c",'1 1 0 1 1 80 0 0 80 0 80 0 80 0 0 1 '); - enable block comment wrap. + } +# endif + + /* set the encoding to UTF-8 without any friggin useless signatures. */ + idxExt = name_match('def-lang-for-ext-', 1, MISC_TYPE); + while (idxExt > 0) + { + if (name_info(idxExt) == sLangId) + { + parse name_name(idxExt) with 'def-lang-for-ext-' auto sExt; + sVarName = 'def-encoding-' :+ sExt; + idxExtEncoding = find_index(sVarName, MISC_TYPE); + if (idxExtEncoding != 0) + delete_name(idxExtEncoding); + } + idxExt = name_match('def-lang-for-ext-', 0, MISC_TYPE); + } + //replace_def_data('def-encoding-' :+ sLangId, '+futf8 '); + idxLangEncoding = find_index('def-encoding-' :+ sLangId, MISC_TYPE); + if (idxLangEncoding != 0) + delete_name(idxLangEncoding); + + } + replace_def_data('def-encoding', '+futf8 '); + + LanguageSettings.setIndentWithTabs('mak', true); + LanguageSettings.setLexerName('mak', 'kmk'); + LanguageSettings.setSyntaxIndent('mak', 8); + + LanguageSettings.setBeautifierProfileName('c', "bird's Style"); + LanguageSettings.setBeautifierProfileName('m', "bird's Objective-C Style"); + + /* Fix .asm and add .mac, .kmk, .cmd, and .pgsql. */ + kdev_ext_to_lang("asm", 'masm'); + kdev_ext_to_lang("mac", 'masm'); + kdev_ext_to_lang("kmk", 'mak'); + kdev_ext_to_lang("cmd", 'bat'); + kdev_ext_to_lang("pgsql", 'plsql'); + + /* + * Change the codehelp default. + */ +# if __VERSION__ >= 22.0 + VSCodeHelpFlags fOldCodeHelp, fNewCodeHelp; +# else + int fOldCodeHelp, fNewCodeHelp; +# endif + fOldCodeHelp = def_codehelp_flags; + fNewCodeHelp = fOldCodeHelp \ + | VSCODEHELPFLAG_AUTO_FUNCTION_HELP \ + | VSCODEHELPFLAG_AUTO_LIST_MEMBERS \ + | VSCODEHELPFLAG_SPACE_INSERTS_SPACE \ + | VSCODEHELPFLAG_INSERT_OPEN_PAREN \ + | VSCODEHELPFLAG_DISPLAY_MEMBER_COMMENTS \ + | VSCODEHELPFLAG_DISPLAY_FUNCTION_COMMENTS \ + | VSCODEHELPFLAG_REPLACE_IDENTIFIER \ + | VSCODEHELPFLAG_PRESERVE_IDENTIFIER \ + | VSCODEHELPFLAG_AUTO_PARAMETER_COMPLETION \ + | VSCODEHELPFLAG_AUTO_LIST_PARAMS \ + | VSCODEHELPFLAG_PARAMETER_TYPE_MATCHING \ + | VSCODEHELPFLAG_NO_SPACE_AFTER_PAREN \ + | VSCODEHELPFLAG_RESERVED_ON \ + | VSCODEHELPFLAG_MOUSE_OVER_INFO \ + | VSCODEHELPFLAG_AUTO_LIST_VALUES \ + | VSCODEHELPFLAG_HIGHLIGHT_TAGS \ + | VSCODEHELPFLAG_FIND_TAG_PREFERS_ALTERNATE \ + ; + fNewCodeHelp &= ~( VSCODEHELPFLAG_SPACE_COMPLETION \ + | VSCODEHELPFLAG_AUTO_SYNTAX_HELP \ + | VSCODEHELPFLAG_NO_SPACE_AFTER_COMMA \ + | VSCODEHELPFLAG_STRICT_LIST_SELECT \ + | VSCODEHELPFLAG_AUTO_LIST_VALUES \ + | VSCODEHELPFLAG_FIND_TAG_PREFERS_DECLARATION \ + | VSCODEHELPFLAG_FIND_TAG_PREFERS_DEFINITION \ + | VSCODEHELPFLAG_FIND_TAG_HIDE_OPTIONS \ + ); + def_codehelp_flags = fNewCodeHelp; + foreach (sLangId in aMyLangIds) + { + _str sVarName = 'def-codehelp-' :+ sLangId; + int idxVar = find_index(sVarName, MISC_TYPE); + if (idxVar != 0) + replace_def_data(sVarName, fNewCodeHelp); + } +#endif + +# if __VERSION__ >= 21.0 + /* Old style search dialog, not mini. */ + def_gui_find_default = 1; +# endif + + _fso_strip_spaces(STSO_STRIP_MODIFIED); + + /** @todo + * - Auto restore clipboards + * */ + + message(sMsg) +} + + +static int kfile_to_array(_str sFile, _str (&asLines)[]) +{ + asLines._makeempty(); + + int idTempView = 0; + int idOrgView = 0; + int rc = _open_temp_view(sFile, idTempView, idOrgView); + if (!rc) + { + _GoToROffset(0); /* top of the file. */ + + int i = 0; + do + { + _str sLine = ''; + get_line(sLine); + asLines[i] = sLine; + i += 1; + } while (down() == 0); + + _delete_temp_view(idTempView); + activate_window(idOrgView); + } + return rc; +} + + +_command void kload_files(_str sFile = "file-not-specified.lst") +{ + _str sFileDir = absolute(_strip_filename(sFile, 'NE')); + _str aFiles[]; + int rc = kfile_to_array(sFile, asFiles); + if (rc == 0) + { + _str sFile; + int i; + for (i = 0; i < asFiles._length(); i++) + { + _str sFile = strip(asFiles[i]); + if (length(sFile) > 0) + { + sAbsFile = absolute(sFile, sFileDir); + message("Loading \"" :+ sAbsFile :+ "\"..."); + //say("sAbsFile=" :+ sAbsFile); + edit(sAbsFile); + } + } + } + else + message("_GetFileContents failed: " :+ rc); +} + + +/** + * Module initiation. + */ +definit() +{ + /* do cleanup. */ + for (i = 0; i < 999; i++) + { + index = name_match("def-koptions-", 1 /*find_first*/, MISC_TYPE); + if (!index) + break; + delete_name(index); + } + + /* do init */ + k_styles_create(); +#ifdef KDEV_WITH_MENU + k_menu_create(); +# if __VERSION__ < 18.0 /* Something with timers are busted, so excusing my code. */ + iTimer = _set_timer(1000, k_menu_create, "timer"); +# endif + /* createMyColorSchemeAndUseIt();*/ +#endif +} + diff --git a/SlickEdit/kkeys.e b/SlickEdit/kkeys.e new file mode 100644 index 0000000..e7f39aa --- /dev/null +++ b/SlickEdit/kkeys.e @@ -0,0 +1,427 @@ +/* $Id: kkeys.e 3555 2022-02-16 13:20:30Z bird $ */ +/** @file + * Bird's key additions to Visual Slickedit. + */ + +/* + * Copyright (c) 2004-2010 knut st. osmundsen <bird-kBuild-spamx@anduin.net> + * + * This file is part of kBuild. + * + * kBuild is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * kBuild is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with kBuild. If not, see <http://www.gnu.org/licenses/> + * + */ + +/******************************************************************************* +* Header Files * +*******************************************************************************/ +#include 'slick.sh' + + +/******************************************************************************* +* Global Variables * +*******************************************************************************/ +defeventtab default_keys +def 'A-UP' = find_prev +def 'A-DOWN' = find_next +def 'A-PGUP' = prev_proc +def 'A-PGDN' = next_proc +def 'A-d' = delete_line +def 'A-o' = kkeys_duplicate_line +def 'A-s' = kkeys_switch_lines +def 'A-u' = undo_cursor /* will cursor movement in one undo step. */ +def 'A-g' = goto_line +def 'A-z' = kkeys_fullscreen +def 'INS' = boxer_paste +def 'S-INS' = insert_toggle +def 'S- ' = kkey_space; +def 'C-UP' = kkeys_scroll_down +def 'C-DOWN' = kkeys_scroll_up +def 'C-PGUP' = prev_window +def 'C-PGDN' = next_window +def 'C-DEL' = kkeys_delete_right +#if __VERSION__ >= 15.0 +def 'S-C-=' = svn_diff_with_base +#endif +#if __VERSION__ >= 22.0 +def 'C-=' = diff; +def 'C--' = nil; +def 'S-A-C-=' = wfont_zoom_in; +def 'S-A-C--' = wfont_zoom_out; +#endif +#if __VERSION__ >= 14.0 +def 'C-/' = kkeys_push_ref +def 'S-C-/' = push_ref +def 'S-A-]' = next_buff_tab +def 'S-A-[' = prev_buff_tab +def 'S-A-U' = kkeys_gen_uuid +#endif +/* For the mac (A/M mix, all except A-z): */ +def 'M-1' = cursor_error +def 'M-UP' = find_prev +def 'M-DOWN' = find_next +def 'M-PGUP' = prev_proc +def 'M-PGDN' = next_proc +def 'M-d' = delete_line +def 'M-f' = kkeys_open_file_menu +def 'M-e' = kkeys_open_edit_menu +def 'M-o' = kkeys_duplicate_line +def 'M-s' = kkeys_switch_lines +def 'M-t' = kkeys_open_tools_menu +def 'M-u' = undo_cursor +def 'M-g' = goto_line +#if __VERSION__ >= 14.0 +def 'S-M-]' = next_buff_tab +def 'S-M-[' = prev_buff_tab +def 'S-M-U' = kkeys_gen_uuid +#endif +#if __VERSION__ >= 22.0 +def 'S-M-C-=' = wfont_zoom_in; +def 'S-M-C--' = wfont_zoom_out; +#endif +/* Fixing brainfucked slickedit silliness: */ +def 'M-v' = paste + +/* Want proper shift-space in C. */ +defeventtab c_keys +def 'S- ' = kkey_space; + + +/** Saves the cursor position. */ +static long kkeys_save_cur_pos() +{ + long offset = _QROffset(); + message(offset); + return offset; +} + +/** Restores a saved cursor position. */ +static void kkeys_restore_cur_pos(long lSavedCurPos) +{ + _GoToROffset(lSavedCurPos); +} + +/** Fixes shift-space while in block select, default slickedit since a while + * is to exit selection mode and insert a single space. A long long time + * ago, I think slickedit would ask if you wanted the normal 'space' + * behaviour for this. */ +_command void kkey_space() +{ + /** @todo figure out when these functions were added and such. */ + if (!select_active() || _select_type('') != 'BLOCK') + keyin(' '); + else + block_insert_text(' '); +} + +_command kkeys_switch_lines() +{ + /* Allocate a selection for copying the current line. */ + cursor_down(); + mark_id= _alloc_selection(); + if (mark_id>=0) + { + _select_line(mark_id); + cursor_up(); + cursor_up(); + _move_to_cursor(mark_id); + cursor_down(); + _free_selection(mark_id); + // This selection can be freed because it is not the active selection. + } + else + message(get_message(mark_id)); +} + +_command kkeys_duplicate_line() +{ + /* Allocate a selection for copying the current line. */ + mark_id= _alloc_selection(); + if (mark_id>=0) + { + _select_line(mark_id); + _copy_to_cursor(mark_id); + // This selection can be freed because it is not the active selection. + _free_selection(mark_id); + cursor_down(); + } + else + message(get_message(mark_id)); +} + +_command kkeys_delete_right() +{ + col=p_col; + + /* virtual space hack */ + keyin(" "); + left(); + _delete_char(); + + /* are we in a word, delete it? */ + ch = get_text(); + if (ch != ' ' && ch != "\t" && ch != "\r" && ch != "\n") + { + /* Delete word and any trailing spaces, but stop at new line. + (Don't use delete_word here!) */ + if (search('([[:alnum:]_]#|?)[ \t]@','r+') == 0) + { + _nrseek(match_length('s')); + _delete_text(match_length()); + } + } + else + { + /* delete spaces and newlines until the next word. */ + if (search('[ \t\n\r]#','r+') == 0) + { + _nrseek(match_length('s')); + _delete_text(match_length()); + } + } + + p_col=col + //retrieve_command_results() +} + +_command kkeys_scroll_up() +{ + if (p_cursor_y == 0) + down(); + set_scroll_pos(p_left_edge, p_cursor_y-1); +} + +_command kkeys_scroll_down() +{ + if (p_cursor_y intdiv p_font_height == p_char_height-1) + up() + set_scroll_pos(p_left_edge, p_cursor_y+p_font_height); +} + +_command boxer_paste() +{ + long lSavedCurPos = kkeys_save_cur_pos() + paste(); + kkeys_restore_cur_pos(lSavedCurPos); +} + +_command kkeys_fullscreen() +{ + fullscreen(); +} + + +/* for later, not used yet. */ + +_command boxer_select() +{ + if (command_state()) + fSelected = (p_sel_length != 0); + else + fSelected = select_active(); + + key = last_event(); + if (key :== name2event('s-down')) + { + if (!fSelected) + select_line(); + else + cursor_down(); + } + else if (key :== name2event('s-up')) + { + if (!fSelected) + select_line(); + else + cursor_up(); + } + else if (key :== name2event('s-left')) + { + if (!fSelected) + select_char(); + else + cursor_left(); + } + else if (key :== name2event('s-right')) + { + if (!fSelected) + select_char(); + else + cursor_right(); + } + else if (key :== name2event('s-home')) + { + if (!fSelected) select_char(); + begin_line_text_toggle(); + } + else if (key :== name2event('s-end')) + { + if (!fSelected) select_char(); + end_line(); + if (p_col > 0) //this is not identical with boxer... + cursor_left(); + } + else if (key :== name2event('c-s-home')) + { + if (!fSelected) select_char(); + top_of_buffer(); + } + else if (key :== name2event('c-s-end')) + { + if (!fSelected) select_char(); + bottom_of_buffer(); + } + else if (key :== name2event('c-s-left')) + { + if (!fSelected) + { + cursor_left(); + select_char(); /* start this selection non-inclusive */ + } + prev_word(); + } + else if (key :== name2event('c-s-right')) + { + if (!fSelected) + { + select_char(); /* start this selection non-inclusive */ + } + /* temporary hack */ + prevpos = p_col; + prevline = p_line; + p_col++; + next_word(); + if ((p_line == prevline && p_col > prevpos + 1) || (p_line != prevline && p_col > 0)) + p_col--; + } +} + +#if __VERSION__ >= 14.0 + +/** + * Search for references only in the current workspace. + */ +_command kkeys_push_ref() +{ + if (_isEditorCtl()) + { + sProjTagFile = project_tags_filename(); + sLangId = p_LangId; + if (sProjTagFile != '') + { + +# if __VERSION__ < 21.0 /** @todo fix me? */ + /* HACK ALERT: Make sure gtag_filelist_last_ext has the right value. */ + _update_tag_filelist_ext(sLangId); + + /* save */ + boolean saved_gtag_filelist_cache_updated = gtag_filelist_cache_updated; + _str saved_gtag_filelist_ext[] = gtag_filelist_ext; + + /* HACK ALERT: Replace the tag file list for this language. */ + gtag_filelist_ext._makeempty(); + gtag_filelist_ext[0] = sProjTagFile; + gtag_filelist_cache_updated = true; +# endif + + /* Do the reference searching. */ + push_ref('-e ' :+ sLangId); + +# if __VERSION__ < 21.0 + /* restore*/ + gtag_filelist_cache_updated = saved_gtag_filelist_cache_updated; + gtag_filelist_ext = saved_gtag_filelist_ext; +# endif + } + else + push_ref(); + } + else + push_ref(); +} + + +_command kkeys_gen_uuid() +{ + _str uuid = guid_create_string('G'); + uuid = lowcase(uuid); + + long lSavedCurPos = kkeys_save_cur_pos(); + _insert_text(uuid); + kkeys_restore_cur_pos(lSavedCurPos); +} + +#endif /* >= 14.0 */ + +/** @name Mac OS X Hacks: Alt+[fet] -> drop down menu + * + * This only works when the alt menu hotkeys are enabled in the + * settings. Al + * + * @{ + */ +_command void kkeys_open_file_menu() +{ + call_key(A_F) +} + +_command void kkeys_open_edit_menu() +{ + call_key(A_E) +} + +_command void kkeys_open_tools_menu() +{ + call_key(A_T) +} +/** @} */ + +void nop() +{ + +} + + +#if __VERSION__ >= 14.0 + +/* + * Some diff keyboard hacks for Mac OS X. + */ +defeventtab _diff_form +def 'M-f' = kkeys_diffedit_find +def 'M-n' = kkeys_diffedit_next +def 'M-p' = kkeys_diffedit_prev + +_command kkeys_diffedit_find() +{ + _nocheck _control _ctlfind; + _ctlfind.call_event(_ctlfind, LBUTTON_UP); +} + +_command kkeys_diffedit_next() +{ + _nocheck _control _ctlfile1; + _nocheck _control _ctlfile2; + _DiffNextDifference(_ctlfile1, _ctlfile2); +} + +_command kkeys_diffedit_prev() +{ + _nocheck _control _ctlfile1; + _nocheck _control _ctlfile2; + _DiffNextDifference(_ctlfile1, _ctlfile2, '-'); +} + +#endif /* >= 14.0 */ + diff --git a/SlickEdit/lexer-def.cfg.xml b/SlickEdit/lexer-def.cfg.xml new file mode 100644 index 0000000..8ec340e --- /dev/null +++ b/SlickEdit/lexer-def.cfg.xml @@ -0,0 +1,7 @@ +<profile n="colorcoding_profiles.def" version="1"> + <p n="idchars" v="a-zA-Z 0-9_"/> + <p n="case_sensitive" v="0"/> + <p n="comment,;"> + <attrs match_fun="match_comment"/> + </p> +</profile> diff --git a/SlickEdit/lexer-kmk-v2.cfg.xml b/SlickEdit/lexer-kmk-v2.cfg.xml new file mode 100644 index 0000000..e56498c --- /dev/null +++ b/SlickEdit/lexer-kmk-v2.cfg.xml @@ -0,0 +1,147 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE Options SYSTEM "http://www.slickedit.com/dtd/vse/14.0/options.dtd"> +<options> + <profile n="colorcoding_profiles.kmk" version="2"> + <p n="idchars" v="a-zA-Z 0-9_"/> + <p n="case_sensitive" v="1"/> + <p n="styles" v=""/> + <p n="pu,("/> + <p n="pu,)"/> + <p n="pu,:"/> + <p n="pu,;"/> + <p n="pu,["/> + <p n="pu,]"/> + <p n="pu,{"/> + <p n="pu,}"/> + <p n="op,!"/> + <p n="op,#"/> + <p n="op,$"/> + <p n="op,%"/> + <p n="op,&"/> + <p n="op,*"/> + <p n="op,+"/> + <p n="op,,"/> + <p n="op,-"/> + <p n="op,."/> + <p n="op,/"/> + <p n="op,<"/> + <p n="op,="/> + <p n="op,>"/> + <p n="op,?"/> + <p n="op,^"/> + <p n="op,`"/> + <p n="op,|"/> + <p n="op,~"/> + <p n="op,:="/> + <p n="op,+="/> + <p n="op,>="/> + <p n="op,|+"/> + <p n="op,:"/> + <p n="op,::"/> + <p n="k,export"/> + <p n="k,override"/> + <p n="lib,abspath"/> + <p n="lib,abspathex"/> + <p n="lib,addprefix"/> + <p n="lib,addsuffix"/> + <p n="lib,and"/> + <p n="lib,basename"/> + <p n="lib,call"/> + <p n="lib,comp-cmds"/> + <p n="lib,comp-vars"/> + <p n="lib,date"/> + <p n="lib,date-utc"/> + <p n="lib,dir"/> + <p n="lib,eq"/> + <p n="lib,error"/> + <p n="lib,eval"/> + <p n="lib,expr"/> + <p n="lib,file-size"/> + <p n="lib,filter"/> + <p n="lib,filter-out"/> + <p n="lib,findstring"/> + <p n="lib,firstword"/> + <p n="lib,flavor"/> + <p n="lib,foreach"/> + <p n="lib,if-expr"/> + <p n="lib,info"/> + <p n="lib,int-add"/> + <p n="lib,int-and"/> + <p n="lib,int-div"/> + <p n="lib,int-eq"/> + <p n="lib,int-ge"/> + <p n="lib,int-gt"/> + <p n="lib,int-le"/> + <p n="lib,int-lt"/> + <p n="lib,int-mod"/> + <p n="lib,int-mul"/> + <p n="lib,int-ne"/> + <p n="lib,int-not"/> + <p n="lib,int-or"/> + <p n="lib,int-sub"/> + <p n="lib,int-xor"/> + <p n="lib,join"/> + <p n="lib,kb-obj-base"/> + <p n="lib,kb-obj-suff"/> + <p n="lib,kb-src-one"/> + <p n="lib,kb-src-prop"/> + <p n="lib,kb-src-tool"/> + <p n="lib,lastword"/> + <p n="lib,nanots"/> + <p n="lib,not"/> + <p n="lib,notdir"/> + <p n="lib,or"/> + <p n="lib,origin"/> + <p n="lib,patsubst"/> + <p n="lib,realpath"/> + <p n="lib,rsort"/> + <p n="lib,shell"/> + <p n="lib,sort"/> + <p n="lib,stack-pop"/> + <p n="lib,stack-popv"/> + <p n="lib,stack-push"/> + <p n="lib,stack-top"/> + <p n="lib,strip"/> + <p n="lib,subst"/> + <p n="lib,suffix"/> + <p n="lib,tolower"/> + <p n="lib,toupper"/> + <p n="lib,value"/> + <p n="lib,warning"/> + <p n="lib,which"/> + <p n="lib,wildcard"/> + <p n="lib,word"/> + <p n="lib,wordlist"/> + <p n="lib,words"/> + <p n="lib,xargs"/> + <p n="pp,bool"/> + <p n="pp,define"/> + <p n="pp,defined"/> + <p n="pp,else"/> + <p n="pp,endif"/> + <p n="pp,endef"/> + <p n="pp,if"/> + <p n="pp,if1of"/> + <p n="pp,ifn1of"/> + <p n="pp,ifdef"/> + <p n="pp,ifndef"/> + <p n="pp,ifeq"/> + <p n="pp,ifneq"/> + <p n="pp,include"/> + <p n="pp,includedep"/> + <p n="pp,num"/> + <p n="pp,string"/> + <p n="pp,target"/> + <p n="comment,#"> + <attrs color_to_eol="comment"/> + </p> + <p n="string,'"> + <attrs end="'" escape_char="\"/> + </p> + <p n='string,"'> + <attrs end='"' escape_char="\"/> + </p> + <p n="mn_flags" v="digit_int digit_float dot_float"/> + </profile> +</options> + diff --git a/SlickEdit/lexer-kmk.cfg.xml b/SlickEdit/lexer-kmk.cfg.xml new file mode 100644 index 0000000..fa6f498 --- /dev/null +++ b/SlickEdit/lexer-kmk.cfg.xml @@ -0,0 +1,135 @@ +<profile n="colorcoding_profiles.kmk" version="1"> + <p n="idchars" v="a-zA-Z 0-9_"/> + <p n="case_sensitive" v="1"/> + <p n="styles" v="dqbackslash sqbackslash"/> + <p n="pu,("/> + <p n="pu,)"/> + <p n="pu,:"/> + <p n="pu,;"/> + <p n="pu,["/> + <p n="pu,]"/> + <p n="pu,{"/> + <p n="pu,}"/> + <p n="op,!"/> + <p n="op,#"/> + <p n="op,$"/> + <p n="op,%"/> + <p n="op,&"/> + <p n="op,*"/> + <p n="op,+"/> + <p n="op,,"/> + <p n="op,-"/> + <p n="op,."/> + <p n="op,/"/> + <p n="op,<"/> + <p n="op,="/> + <p n="op,>"/> + <p n="op,?"/> + <p n="op,^"/> + <p n="op,`"/> + <p n="op,|"/> + <p n="op,~"/> + <p n="op,:="/> + <p n="op,+="/> + <p n="op,>="/> + <p n="op,|+"/> + <p n="op,:"/> + <p n="op,::"/> + <p n="k,export"/> + <p n="k,override"/> + <p n="lib,abspath"/> + <p n="lib,abspathex"/> + <p n="lib,addprefix"/> + <p n="lib,addsuffix"/> + <p n="lib,and"/> + <p n="lib,basename"/> + <p n="lib,call"/> + <p n="lib,comp-cmds"/> + <p n="lib,comp-vars"/> + <p n="lib,date"/> + <p n="lib,date-utc"/> + <p n="lib,dir"/> + <p n="lib,eq"/> + <p n="lib,error"/> + <p n="lib,eval"/> + <p n="lib,expr"/> + <p n="lib,file-size"/> + <p n="lib,filter"/> + <p n="lib,filter-out"/> + <p n="lib,findstring"/> + <p n="lib,firstword"/> + <p n="lib,flavor"/> + <p n="lib,foreach"/> + <p n="lib,if-expr"/> + <p n="lib,info"/> + <p n="lib,int-add"/> + <p n="lib,int-and"/> + <p n="lib,int-div"/> + <p n="lib,int-eq"/> + <p n="lib,int-ge"/> + <p n="lib,int-gt"/> + <p n="lib,int-le"/> + <p n="lib,int-lt"/> + <p n="lib,int-mod"/> + <p n="lib,int-mul"/> + <p n="lib,int-ne"/> + <p n="lib,int-not"/> + <p n="lib,int-or"/> + <p n="lib,int-sub"/> + <p n="lib,int-xor"/> + <p n="lib,join"/> + <p n="lib,kb-obj-base"/> + <p n="lib,kb-obj-suff"/> + <p n="lib,kb-src-one"/> + <p n="lib,kb-src-prop"/> + <p n="lib,kb-src-tool"/> + <p n="lib,lastword"/> + <p n="lib,nanots"/> + <p n="lib,not"/> + <p n="lib,notdir"/> + <p n="lib,or"/> + <p n="lib,origin"/> + <p n="lib,patsubst"/> + <p n="lib,realpath"/> + <p n="lib,rsort"/> + <p n="lib,shell"/> + <p n="lib,sort"/> + <p n="lib,stack-pop"/> + <p n="lib,stack-popv"/> + <p n="lib,stack-push"/> + <p n="lib,stack-top"/> + <p n="lib,strip"/> + <p n="lib,subst"/> + <p n="lib,suffix"/> + <p n="lib,tolower"/> + <p n="lib,toupper"/> + <p n="lib,value"/> + <p n="lib,warning"/> + <p n="lib,which"/> + <p n="lib,wildcard"/> + <p n="lib,word"/> + <p n="lib,wordlist"/> + <p n="lib,words"/> + <p n="lib,xargs"/> + <p n="pp,bool"/> + <p n="pp,define"/> + <p n="pp,defined"/> + <p n="pp,else"/> + <p n="pp,endif"/> + <p n="pp,endef"/> + <p n="pp,if"/> + <p n="pp,if1of"/> + <p n="pp,ifn1of"/> + <p n="pp,ifdef"/> + <p n="pp,ifndef"/> + <p n="pp,ifeq"/> + <p n="pp,ifneq"/> + <p n="pp,include"/> + <p n="pp,includedep"/> + <p n="pp,num"/> + <p n="pp,string"/> + <p n="pp,target"/> + <p n="comment,#"> + <attrs match_fun="match_comment"/> + </p> +</profile> diff --git a/SlickEdit/uscheme.ini b/SlickEdit/uscheme.ini new file mode 100644 index 0000000..aa904cf --- /dev/null +++ b/SlickEdit/uscheme.ini @@ -0,0 +1,257 @@ +[Solarized Dark] +VERSION=22 +ASSOCIATED_SYMBOL_SCHEME=(None) +CFG_SELECTIONfg=0x969483 +CFG_SELECTIONbg=0x423607 +CFG_SELECTIONff=0x0 +CFG_SELECTIONem=0x63510A +CFG_WINDOW_TEXTfg=0x969483 +CFG_WINDOW_TEXTbg=0x362B00 +CFG_WINDOW_TEXTff=0x0 +CFG_WINDOW_TEXTem=0x1A1400 +CFG_CLINEfg=0xFFFFFF +CFG_CLINEbg=0x605030 +CFG_CLINEff=0x0 +CFG_CLINEem=0x908060 +CFG_SELECTED_CLINEfg=0xFFFF +CFG_SELECTED_CLINEbg=0x80C400 +CFG_SELECTED_CLINEff=0x0 +CFG_SELECTED_CLINEem=0x509400 +CFG_MESSAGEfg=0x80000008 +CFG_MESSAGEbg=0x80000005 +CFG_MESSAGEff=0x0 +CFG_STATUSfg=0x80000008 +CFG_STATUSbg=0xFFFFFF +CFG_STATUSff=0x0 +CFG_CURSORfg=0x0 +CFG_CURSORbg=0xE8E8C0 +CFG_CURSORff=0x0 +CFG_CURSORem=0xB8B890 +CFG_ERRORfg=0x8236D3 +CFG_ERRORbg=0x362B00 +CFG_ERRORff=0x2000 +CFG_ERRORem=0x1A1400 +CFG_MODIFIED_LINEfg=0xFFFFFF +CFG_MODIFIED_LINEbg=0xFF +CFG_MODIFIED_LINEff=0x0 +CFG_MODIFIED_LINEem=0xCF +CFG_INSERTED_LINEfg=0xFFFFFF +CFG_INSERTED_LINEbg=0x80 +CFG_INSERTED_LINEff=0x0 +CFG_INSERTED_LINEem=0x3030B0 +CFG_KEYWORDfg=0x1689B5 +CFG_KEYWORDbg=0x362B00 +CFG_KEYWORDff=0x2000 +CFG_KEYWORDem=0x1A1400 +CFG_LINENUMfg=0x969483 +CFG_LINENUMbg=0x423607 +CFG_LINENUMff=0x0 +CFG_LINENUMem=0x303030 +CFG_NUMBERfg=0x98A12A +CFG_NUMBERbg=0x362B00 +CFG_NUMBERff=0x2000 +CFG_NUMBERem=0x1A1400 +CFG_STRINGfg=0x9985 +CFG_STRINGbg=0x362B00 +CFG_STRINGff=0x2000 +CFG_STRINGem=0x1A1400 +CFG_COMMENTfg=0xA100 +CFG_COMMENTbg=0x362B00 +CFG_COMMENTff=0x2000 +CFG_COMMENTem=0x1A1400 +CFG_PPKEYWORDfg=0x164BCB +CFG_PPKEYWORDbg=0x362B00 +CFG_PPKEYWORDff=0x2001 +CFG_PPKEYWORDem=0x1A1400 +CFG_PUNCTUATIONfg=0x98A12A +CFG_PUNCTUATIONbg=0x362B00 +CFG_PUNCTUATIONff=0x2000 +CFG_PUNCTUATIONem=0x1A1400 +CFG_LIBRARY_SYMBOLfg=0xC0C000 +CFG_LIBRARY_SYMBOLbg=0x362B00 +CFG_LIBRARY_SYMBOLff=0x2000 +CFG_LIBRARY_SYMBOLem=0x1A1400 +CFG_OPERATORfg=0x2F32DC +CFG_OPERATORbg=0x362B00 +CFG_OPERATORff=0x2000 +CFG_OPERATORem=0x1A1400 +CFG_USER_DEFINEDfg=0xFF +CFG_USER_DEFINEDbg=0x362B00 +CFG_USER_DEFINEDff=0x2000 +CFG_USER_DEFINEDem=0x1A1400 +CFG_IMAGINARY_LINEfg=0xFFFFFF +CFG_IMAGINARY_LINEbg=0xFF0000 +CFG_IMAGINARY_LINEff=0x0 +CFG_IMAGINARY_LINEem=0xCF0000 +CFG_FUNCTIONfg=0xDB8B26 +CFG_FUNCTIONbg=0x362B00 +CFG_FUNCTIONff=0x2001 +CFG_FUNCTIONem=0x1A1400 +CFG_LINEPREFIXAREAfg=0xA1A193 +CFG_LINEPREFIXAREAbg=0x423600 +CFG_LINEPREFIXAREAff=0x1 +CFG_FILENAMEfg=0x0 +CFG_FILENAMEbg=0xFFFF00 +CFG_FILENAMEff=0x0 +CFG_FILENAMEem=0xCFCF00 +CFG_HILIGHTfg=0xFFFFFF +CFG_HILIGHTbg=0x808000 +CFG_HILIGHTff=0x0 +CFG_HILIGHTem=0x505000 +CFG_ATTRIBUTEfg=0x9985 +CFG_ATTRIBUTEbg=0x362B00 +CFG_ATTRIBUTEff=0x2001 +CFG_ATTRIBUTEem=0x1A1400 +CFG_UNKNOWNXMLELEMENTfg=0x2F32DC +CFG_UNKNOWNXMLELEMENTbg=0x362B00 +CFG_UNKNOWNXMLELEMENTff=0x2001 +CFG_UNKNOWNXMLELEMENTem=0x1A1400 +CFG_XHTMLELEMENTINXSLfg=0x80FF +CFG_XHTMLELEMENTINXSLbg=0x362B00 +CFG_XHTMLELEMENTINXSLff=0x2001 +CFG_XHTMLELEMENTINXSLem=0x1A1400 +CFG_SPECIALCHARSfg=0xC0C0C0 +CFG_SPECIALCHARSbg=0xFFFFFF +CFG_SPECIALCHARSff=0x0 +CFG_SPECIALCHARSem=0xCFCFCF +CFG_CURRENT_LINE_BOXfg=0xFF8080 +CFG_CURRENT_LINE_BOXbg=0xFF8080 +CFG_CURRENT_LINE_BOXff=0x0 +CFG_VERTICAL_COL_LINEfg=0x164BCB +CFG_VERTICAL_COL_LINEbg=0x164BCB +CFG_VERTICAL_COL_LINEff=0x0 +CFG_MARGINS_COL_LINEfg=0x808080 +CFG_MARGINS_COL_LINEbg=0x808080 +CFG_MARGINS_COL_LINEff=0x0 +CFG_TRUNCATION_COL_LINEfg=0xFF +CFG_TRUNCATION_COL_LINEbg=0xFF +CFG_TRUNCATION_COL_LINEff=0x0 +CFG_PREFIX_AREA_LINEfg=0x808080 +CFG_PREFIX_AREA_LINEbg=0x808080 +CFG_PREFIX_AREA_LINEff=0x0 +CFG_BLOCK_MATCHINGfg=0xFFFFFF +CFG_BLOCK_MATCHINGbg=0x837B65 +CFG_BLOCK_MATCHINGff=0x0 +CFG_BLOCK_MATCHINGem=0xCF0000 +CFG_INC_SEARCH_CURRENTfg=0x0 +CFG_INC_SEARCH_CURRENTbg=0xFFFF80 +CFG_INC_SEARCH_CURRENTff=0x0 +CFG_INC_SEARCH_CURRENTem=0xCFCF50 +CFG_INC_SEARCH_MATCHfg=0x0 +CFG_INC_SEARCH_MATCHbg=0x80FFFF +CFG_INC_SEARCH_MATCHff=0x0 +CFG_INC_SEARCH_MATCHem=0x50CFCF +CFG_HEX_MODE_COLORfg=0x2F32DC +CFG_HEX_MODE_COLORbg=0xF0F0F0 +CFG_HEX_MODE_COLORff=0x1 +CFG_HEX_MODE_COLORem=0xC0C0C0 +CFG_SYMBOL_HIGHLIGHTfg=0x98A12A +CFG_SYMBOL_HIGHLIGHTbg=0x362B00 +CFG_SYMBOL_HIGHLIGHTff=0x2000 +CFG_SYMBOL_HIGHLIGHTem=0x1A1400 +CFG_DOCUMENT_TAB_MODIFIEDfg=0xFF +CFG_DOCUMENT_TAB_MODIFIEDbg=0xFFFFFF +CFG_DOCUMENT_TAB_MODIFIEDff=0x0 +CFG_LINE_COMMENTfg=0xA100 +CFG_LINE_COMMENTbg=0x362B00 +CFG_LINE_COMMENTff=0x2000 +CFG_LINE_COMMENTem=0x1A1400 +CFG_DOCUMENTATIONfg=0xA100 +CFG_DOCUMENTATIONbg=0x362B00 +CFG_DOCUMENTATIONff=0x2000 +CFG_DOCUMENTATIONem=0x1A1400 +CFG_DOC_KEYWORDfg=0xA197 +CFG_DOC_KEYWORDbg=0x362B00 +CFG_DOC_KEYWORDff=0x2001 +CFG_DOC_KEYWORDem=0x1A1400 +CFG_DOC_PUNCTUATIONfg=0xA100 +CFG_DOC_PUNCTUATIONbg=0x362B00 +CFG_DOC_PUNCTUATIONff=0x2001 +CFG_DOC_PUNCTUATIONem=0x1A1400 +CFG_DOC_ATTRIBUTEfg=0x97A100 +CFG_DOC_ATTRIBUTEbg=0x362B00 +CFG_DOC_ATTRIBUTEff=0x2001 +CFG_DOC_ATTRIBUTEem=0x1A1400 +CFG_DOC_ATTR_VALUEfg=0x97A100 +CFG_DOC_ATTR_VALUEbg=0x362B00 +CFG_DOC_ATTR_VALUEff=0x2000 +CFG_DOC_ATTR_VALUEem=0x1A1400 +CFG_IDENTIFIERfg=0x969483 +CFG_IDENTIFIERbg=0x362B00 +CFG_IDENTIFIERff=0x2000 +CFG_IDENTIFIERem=0x1A1400 +CFG_FLOATING_NUMBERfg=0x98A12A +CFG_FLOATING_NUMBERbg=0x362B00 +CFG_FLOATING_NUMBERff=0x2000 +CFG_FLOATING_NUMBERem=0x1A1400 +CFG_HEX_NUMBERfg=0x98A12A +CFG_HEX_NUMBERbg=0x362B00 +CFG_HEX_NUMBERff=0x2000 +CFG_HEX_NUMBERem=0x1A1400 +CFG_SINGLEQUOTED_STRINGfg=0x9985 +CFG_SINGLEQUOTED_STRINGbg=0x362B00 +CFG_SINGLEQUOTED_STRINGff=0x2000 +CFG_SINGLEQUOTED_STRINGem=0x1A1400 +CFG_BACKQUOTED_STRINGfg=0x9985 +CFG_BACKQUOTED_STRINGbg=0x362B00 +CFG_BACKQUOTED_STRINGff=0x2000 +CFG_BACKQUOTED_STRINGem=0x1A1400 +CFG_UNTERMINATED_STRINGfg=0x9985 +CFG_UNTERMINATED_STRINGbg=0x362B00 +CFG_UNTERMINATED_STRINGff=0x2000 +CFG_UNTERMINATED_STRINGem=0x1A1400 +CFG_INACTIVE_CODEfg=0xA100 +CFG_INACTIVE_CODEbg=0x362B00 +CFG_INACTIVE_CODEff=0x2000 +CFG_INACTIVE_CODEem=0x1A1400 +CFG_INACTIVE_KEYWORDfg=0xA100 +CFG_INACTIVE_KEYWORDbg=0x362B00 +CFG_INACTIVE_KEYWORDff=0x2001 +CFG_INACTIVE_KEYWORDem=0x1A1400 +CFG_IMAGINARY_SPACEfg=0xFFFFFF +CFG_IMAGINARY_SPACEbg=0xFF0000 +CFG_IMAGINARY_SPACEff=0x0 +CFG_IMAGINARY_SPACEem=0xCF0000 +CFG_INACTIVE_COMMENTfg=0xA100 +CFG_INACTIVE_COMMENTbg=0x362B00 +CFG_INACTIVE_COMMENTff=0x2002 +CFG_INACTIVE_COMMENTem=0x1A1400 +CFG_MODIFIED_ITEMfg=0xFF +CFG_MODIFIED_ITEMbg=0xFFFFFF +CFG_MODIFIED_ITEMff=0x0 +CFG_NAVHINTfg=0x80FF +CFG_NAVHINTbg=0x403010 +CFG_NAVHINTff=0x0 +CFG_XML_CHARACTER_REFfg=0x98A12A +CFG_XML_CHARACTER_REFbg=0x362B00 +CFG_XML_CHARACTER_REFff=0x2000 +CFG_XML_CHARACTER_REFem=0x1A1400 +CFG_SEARCH_RESULT_TRUNCATEDfg=0x969483 +CFG_SEARCH_RESULT_TRUNCATEDbg=0x362B00 +CFG_SEARCH_RESULT_TRUNCATEDff=0x0 +CFG_MARKDOWN_HEADERfg=0x969483 +CFG_MARKDOWN_HEADERbg=0x362B00 +CFG_MARKDOWN_HEADERff=0x0 +CFG_MARKDOWN_HEADERem=0x1A1400 +CFG_MARKDOWN_CODEfg=0x969483 +CFG_MARKDOWN_CODEbg=0x362B00 +CFG_MARKDOWN_CODEff=0x0 +CFG_MARKDOWN_CODEem=0x1A1400 +CFG_MARKDOWN_BLOCKQUOTEfg=0x969483 +CFG_MARKDOWN_BLOCKQUOTEbg=0x362B00 +CFG_MARKDOWN_BLOCKQUOTEff=0x0 +CFG_MARKDOWN_BLOCKQUOTEem=0x1A1400 +CFG_MARKDOWN_LINKfg=0x969483 +CFG_MARKDOWN_LINKbg=0x362B00 +CFG_MARKDOWN_LINKff=0x0 +CFG_MARKDOWN_LINKem=0x1A1400 +CFG_DOCUMENT_TAB_ACTIVEfg=0x362B00 +CFG_DOCUMENT_TAB_ACTIVEbg=0xA1A193 +CFG_DOCUMENT_TAB_ACTIVEff=0x0 +CFG_DOCUMENT_TAB_SELECTEDfg=0x362B00 +CFG_DOCUMENT_TAB_SELECTEDbg=0x969483 +CFG_DOCUMENT_TAB_SELECTEDff=0x0 +CFG_DOCUMENT_TAB_UNSELECTEDfg=0x969483 +CFG_DOCUMENT_TAB_UNSELECTEDbg=0x362B00 +CFG_DOCUMENT_TAB_UNSELECTEDff=0x0 + diff --git a/SlickEdit/user.vlx b/SlickEdit/user.vlx new file mode 100644 index 0000000..a68b96d --- /dev/null +++ b/SlickEdit/user.vlx @@ -0,0 +1,16 @@ +[kmk] +idchars=a-zA-Z 0-9_ +case-sensitive=y +styles=dqbackslash sqbackslash +punctuation= ( ) : ; [ ] { } +operators= ! # $ % & * + , - . / < = > ? ^ ` | ~ := += >= |+ : :: +keywords= export override +libkeywords= abspath abspathex addprefix addsuffix and basename call comp-cmds comp-vars date date-utc dir eq error eval expr file-size filter filter-out findstring firstword flavor foreach if-expr info int-add int-and int-div int-eq int-ge int-gt int-le int-lt int-mod int-mul int-ne int-not int-or int-sub int-xor join kb-obj-base kb-obj-suff kb-src-one kb-src-prop kb-src-tool lastword nanots not notdir or origin patsubst realpath rsort shell sort stack-pop stack-popv stack-push stack-top strip subst suffix tolower toupper value warning which wildcard word wordlist words xargs +ppkeywords= bool define defined else endif endef if if1of ifn1of ifdef ifndef ifeq ifneq include includedep num string target +linecomment=# + +[def] +idchars=a-zA-Z 0-9_ +case-sensitive=n +linecomment=; + diff --git a/SlickEdit/usrprjtemplates.vpt b/SlickEdit/usrprjtemplates.vpt new file mode 100644 index 0000000..0d01d34 --- /dev/null +++ b/SlickEdit/usrprjtemplates.vpt @@ -0,0 +1,52 @@ +<!DOCTYPE Templates SYSTEM "http://www.slickedit.com/dtd/vse/10.0/vpt.dtd"> +<Templates + Version="10.0" + VendorName="SlickEdit"> + <Template Name="kBuild"> + <Config Name="Release"> + <Menu> + <Target + Name="Compile" + MenuCaption="&Compile" + CaptureOutputWith="ProcessBuffer" + SaveOption="SaveCurrent" + RunFromDir="%p" + ClearProcessBuffer="1"> + <Exec CmdLine="kmk -C %p %n.o"/> + </Target> + <Target + Name="Build" + MenuCaption="&Build" + CaptureOutputWith="ProcessBuffer" + SaveOption="SaveWorkspaceFiles" + RunFromDir="%rw" + ClearProcessBuffer="1"> + <Exec CmdLine="kmk"/> + </Target> + <Target + Name="Rebuild" + MenuCaption="&Rebuild" + CaptureOutputWith="ProcessBuffer" + SaveOption="SaveWorkspaceFiles" + RunFromDir="%rw" + ClearProcessBuffer="1"> + <Exec CmdLine="kmk rebuild"/> + </Target> + <Target + Name="Debug" + MenuCaption="&Debug" + SaveOption="SaveNone" + RunFromDir="%rw"> + <Exec/> + </Target> + <Target + Name="Execute" + MenuCaption="E&xecute" + SaveOption="SaveNone" + RunFromDir="%rw"> + <Exec CmdLine='"%<e.exe"'/> + </Target> + </Menu> + </Config> + </Template> +</Templates> diff --git a/SlickEdit/vusr_beautifier.xml b/SlickEdit/vusr_beautifier.xml new file mode 100644 index 0000000..a05d330 --- /dev/null +++ b/SlickEdit/vusr_beautifier.xml @@ -0,0 +1,447 @@ +<profiles> + <profile name="bird's Style" lang="c"> + <P N="syntax_indent" V="4" E="1"/> + <P N="tab_indent" V="8" E="1"/> + <P N="indent_policy" V="12" E="1"/> + <P N="indent_member_access" V="0" E="1"/> + <P N="access_spec_indent" V="1" E="1"/> + <P N="member_access_relative_indent" V="0" E="1"/> + <P N="indent_case" V="1" E="1"/> + <P N="case_indent_width" V="4" E="1"/> + <P N="continuation_width" V="4" E="1"/> + <P N="funcall_param_align" V="10" E="1"/> + <P N="sp_tmpldecl_comma" V="2" E="1"/> + <P N="sp_init_comma" V="2" E="1"/> + <P N="sp_member_dotstar" V="0" E="1"/> + <P N="sp_mptr_ccs" V="5" E="1"/> + <P N="sp_delete_padbracket" V="5" E="1"/> + <P N="sp_cppcast_pad" V="5" E="1"/> + <P N="st_nl_file" V="4" E="1"/> + <P N="sp_class_lbrace" V="1" E="1"/> + <P N="st_nl_empty" V="5" E="1"/> + <P N="sp_catch_padparen" V="5" E="1"/> + <P N="sp_switch_lparen" V="4" E="1"/> + <P N="sp_ref_arp" V="5" E="1"/> + <P N="sp_member_arrowstar" V="0" E="1"/> + <P N="sp_tmpldecl_equals" V="3" E="1"/> + <P N="sp_arrayexpr_lbracket" V="5" E="1"/> + <P N="sp_tmpldecl_pad" V="5" E="1"/> + <P N="sp_tmplparm_pad" V="5" E="1"/> + <P N="sp_arraydecl_lbracket" V="5" E="1"/> + <P N="st_fundecl_nameline" V="5" E="0"/> + <P N="st_oneline_dowhile" V="4" E="1"/> + <P N="sp_op_bitwise" V="3" E="1"/> + <P N="st_oneline_catch" V="5" E="1"/> + <P N="sp_ctlstmt_rparen" V="5" E="1"/> + <P N="sp_ctlstmt_padparen" V="5" E="1"/> + <P N="st_newline_after_extern" V="4" E="1"/> + <P N="sp_for_lparen" V="4" E="1"/> + <P N="sp_funcall_voidparen" V="5" E="1"/> + <P N="sp_switch_defcolon" V="0" E="1"/> + <P N="sp_switch_padparen" V="5" E="1"/> + <P N="sp_class_colon" V="3" E="1"/> + <P N="sp_fun_padparen" V="5" E="1"/> + <P N="sp_if_rparen" V="4" E="1"/> + <P N="sp_struct_comma" V="2" E="1"/> + <P N="sp_ptr_is" V="4" E="1"/> + <P N="sp_fun_equals" V="3" E="1"/> + <P N="sp_delete_rbracket" V="4" E="1"/> + <P N="sp_op_bitand" V="3" E="1"/> + <P N="sp_op_assignment" V="3" E="1"/> + <P N="sp_ref_av" V="5" E="1"/> + <P N="sp_new_lparen" V="5" E="1"/> + <P N="sp_struct_colon" V="3" E="1"/> + <P N="sp_ptr_srp" V="5" E="1"/> + <P N="sp_for_comma" V="2" E="1"/> + <P N="sp_funcall_comma" V="2" E="1"/> + <P N="sp_class_comma" V="2" E="1"/> + <P N="sp_funcall_operator" V="0" E="1"/> + <P N="st_oneline_access" V="4" E="1"/> + <P N="sp_arrayexpr_rbracket" V="5" E="1"/> + <P N="sp_cppcast_gt" V="5" E="1"/> + <P N="sp_op_mult" V="3" E="1"/> + <P N="sp_fun_commainit" V="2" E="1"/> + <P N="sp_tmpldecl_lt" V="5" E="1"/> + <P N="sp_arraydecl_rbracket" V="5" E="1"/> + <P N="sp_for_lbrace" V="1" E="0"/> + <P N="sp_init_lbrace" V="2" E="1"/> + <P N="st_oneline_then" V="5" E="1"/> + <P N="sp_catch_lparen" V="4" E="1"/> + <P N="sp_fun_operator" V="0" E="1"/> + <P N="sp_ptr_ss" V="5" E="1"/> + <P N="sp_member_dot" V="0" E="1"/> + <P N="sp_tmplcall_pad" V="5" E="1"/> + <P N="sp_enum_lbrace" V="1" E="1"/> + <P N="sp_ptr_sv" V="5" E="1"/> + <P N="sp_for_rparen" V="4" E="1"/> + <P N="sp_while_rparen" V="4" E="1"/> + <P N="sp_ret_parexpr" V="4" E="1"/> + <P N="sp_throw_parexpr" V="4" E="1"/> + <P N="st_nl_class" V="5" E="0"/> + <P N="st_oneline_statement" V="5" E="1"/> + <P N="sp_union_lbrace" V="1" E="1"/> + <P N="st_oneline_elsif" V="4" E="1"/> + <P N="sp_op_unary" V="0" E="1"/> + <P N="sp_op_binary" V="3" E="1"/> + <P N="sp_new_rparen" V="4" E="1"/> + <P N="sp_new_padparen" V="5" E="1"/> + <P N="sp_cast_lparen" V="5" E="1"/> + <P N="sp_op_comparison" V="3" E="1"/> + <P N="sp_catch_rparen" V="4" E="1"/> + <P N="sp_fun_lparen" V="5" E="1"/> + <P N="sp_fun_voidparen" V="5" E="1"/> + <P N="sp_enum_comma" V="2" E="1"/> + <P N="sp_enum_equals" V="3" E="1"/> + <P N="sp_cppcast_lt" V="5" E="1"/> + <P N="sp_while_lbrace" V="1" E="1"/> + <P N="sp_switch_lbrace" V="1" E="1"/> + <P N="sp_op_logical" V="3" E="1"/> + <P N="sp_for_semicolon" V="2" E="1"/> + <P N="st_nl_fn" V="4" E="0"/> + <P N="sp_cast_padparen" V="5" E="1"/> + <P N="sp_funcall_rparen" V="5" E="1"/> + <P N="sp_funcall_lparen" V="5" E="1"/> + <P N="sp_switch_colon" V="0" E="1"/> + <P N="sp_enum_colon" V="3" E="1"/> + <P N="sp_ptr_slp" V="5" E="1"/> + <P N="sp_ptr_sa" V="5" E="1"/> + <P N="sp_ref_ia" V="4" E="1"/> + <P N="sp_tmplcall_comma" V="2" E="1"/> + <P N="sp_fun_comma" V="2" E="1"/> + <P N="sp_tmplparm_comma" V="2" E="1"/> + <P N="st_leave_declmult" V="4" E="1"/> + <P N="sp_tmplcall_lt" V="5" E="1"/> + <P N="sp_catch_lbrace" V="1" E="1"/> + <P N="sp_fun_lbrace" V="3" E="1"/> + <P N="sp_if_lbrace" V="1" E="1"/> + <P N="sp_ptr_si" V="4" E="1"/> + <P N="sp_ctlstmt_lparen" V="4" E="1"/> + <P N="sp_for_padparen" V="5" E="1"/> + <P N="sp_cast_rparen" V="5" E="1"/> + <P N="sp_switch_rparen" V="4" E="1"/> + <P N="sp_fun_colon" V="3" E="1"/> + <P N="sp_delete_lbracket" V="5" E="1"/> + <P N="sp_tmplparm_lt" V="5" E="1"/> + <P N="sp_pp_eatspace" V="4" E="0"/> + <P N="sp_op_dereference" V="0" E="1"/> + <P N="sp_struct_lbrace" V="1" E="1"/> + <P N="sp_member_arrow" V="0" E="1"/> + <P N="sp_op_prefix" V="0" E="1"/> + <P N="sp_fptr_si" V="4" E="1"/> + <P N="sp_funcall_padparen" V="5" E="1"/> + <P N="sp_while_padparen" V="5" E="1"/> + <P N="sp_while_lparen" V="4" E="1"/> + <P N="sp_fun_rparen" V="5" E="1"/> + <P N="sp_ref_alp" V="5" E="1"/> + <P N="st_leave_stmtmult" V="4" E="1"/> + <P N="sp_arrayexpr_padbracket" V="5" E="1"/> + <P N="sp_arraydecl_padbracket" V="5" E="1"/> + <P N="sp_ctlstmt_lbrace" V="3" E="1"/> + <P N="st_oneline_else" V="5" E="1"/> + <P N="st_nl_case" V="4" E="0"/> + <P N="sp_init_rbrace" V="1" E="1"/> + <P N="sp_op_addressof" V="0" E="1"/> + <P N="sp_op_postfix" V="0" E="1"/> + <P N="sp_if_lparen" V="4" E="1"/> + <P N="sp_if_padparen" V="5" E="1"/> + <P N="original_tab" V="4" E="1"/> + <P N="indent_use_tab" V="1" E="1"/> + <P N="indent_tab_custom" V="0" E="1"/> + <P N="indent_first_level" V="1" E="1"/> + <P N="indent_goto" V="0" E="1"/> + <P N="indent_extern" V="0" E="1"/> + <P N="indent_namespace" V="0" E="1"/> + <P N="align_on_equals" V="1" E="1"/> + <P N="exp_paren_align" V="8" E="1"/> + <P N="indent_preprocessing" V="0" E="1"/> + <P N="indent_in_block" V="0" E="1"/> + <P N="indent_guard" V="0" E="1"/> + <P N="indent_pp_col1" V="0" E="1"/> + <P N="brace_loc_if" V="13" E="1"/> + <P N="brace_loc_for" V="13" E="1"/> + <P N="brace_loc_while" V="13" E="1"/> + <P N="brace_loc_switch" V="13" E="1"/> + <P N="brace_loc_do" V="13" E="1"/> + <P N="brace_loc_try" V="13" E="1"/> + <P N="brace_loc_catch" V="13" E="1"/> + <P N="brace_loc_asm" V="13" E="1"/> + <P N="brace_loc_namespace" V="13" E="1"/> + <P N="brace_loc_class" V="13" E="1"/> + <P N="brace_loc_enum" V="13" E="1"/> + <P N="brace_loc_fun" V="13" E="1"/> + <P N="rm_trailing_ws" V="4" E="1"/> + <P N="rm_dup_ws" V="5" E="1"/> + <P N="respace_other" V="4" E="1"/> + <P N="comment_indent" V="4" E="1"/> + <P N="comment_col1_indent" V="5" E="1"/> + <P N="parens_return" V="18" E="1"/> + <P N="parens_throw" V="5" E="0"/> + <P N="fundecl_void" V="5" E="0"/> + <P N="fun_assoc_with_ret_type" V="4" E="1"/> + <P N="cppb_sp_fptr_padparen" V="5" E="1"/> + <P N="cppb_sp_fptr_lparen" V="4" E="1"/> + <P N="cppb_sp_fptr_rparen" V="5" E="1"/> + <P N="allow_one_line_block" V="4" E="1"/> + <P N="allow_class_one_line_block" V="4" E="1"/> + <P N="st_newline_before_else" V="4" E="1"/> + <P N="cont_indent_returntype" V="0" E="1"/> + <P N="trailing_comment_align" V="2" E="1"/> + <P N="trailing_comment_value" V="70" E="1"/> + <P N="indent_from_brace" V="0" E="1"/> + <P N="label_indent" V="1" E="1"/> + <P N="sp_ty_star_prototype" V="4" E="1"/> + <P N="sp_ty_amp_prototype" V="4" E="1"/> + <P N="sp_return_padparen" V="5" E="1"/> + <P N="sp_return_rparen" V="5" E="1"/> + <P N="sp_throw_padparen" V="5" E="1"/> + <P N="sp_throw_rparen" V="5" E="1"/> + <P N="sp_expr_lparen" V="5" E="1"/> + <P N="sp_expr_padparen" V="5" E="1"/> + <P N="sp_expr_rparen" V="5" E="1"/> + <P N="sp_disassoc_ret_type_ref" V="4" E="1"/> + <P N="sp_stmt_semicolon" V="4" E="1"/> + <P N="sp_namespace_lbrace" V="3" E="1"/> + <P N="sp_try_lbrace" V="3" E="1"/> + <P N="brace_follows_case" V="1" E="1"/> + <P N="pp_indent_with_code" V="0" E="1"/> + </profile> + <profile name="bird's Objective-C Style" lang="m"> + <P N="syntax_indent" V="4" E="1"/> + <P N="tab_indent" V="8" E="1"/> + <P N="indent_policy" V="12" E="1"/> + <P N="indent_member_access" V="0" E="1"/> + <P N="access_spec_indent" V="1" E="1"/> + <P N="member_access_relative_indent" V="0" E="1"/> + <P N="indent_case" V="1" E="1"/> + <P N="case_indent_width" V="4" E="1"/> + <P N="continuation_width" V="4" E="1"/> + <P N="funcall_param_align" V="10" E="1"/> + <P N="sp_tmpldecl_comma" V="2" E="1"/> + <P N="sp_init_comma" V="2" E="1"/> + <P N="sp_member_dotstar" V="0" E="1"/> + <P N="sp_mptr_ccs" V="5" E="1"/> + <P N="sp_delete_padbracket" V="5" E="1"/> + <P N="sp_cppcast_pad" V="5" E="1"/> + <P N="st_nl_file" V="4" E="1"/> + <P N="sp_class_lbrace" V="1" E="1"/> + <P N="st_nl_empty" V="5" E="1"/> + <P N="sp_catch_padparen" V="5" E="1"/> + <P N="sp_switch_lparen" V="4" E="1"/> + <P N="sp_ref_arp" V="5" E="1"/> + <P N="sp_member_arrowstar" V="0" E="1"/> + <P N="sp_tmpldecl_equals" V="3" E="1"/> + <P N="sp_arrayexpr_lbracket" V="5" E="1"/> + <P N="sp_tmpldecl_pad" V="5" E="1"/> + <P N="sp_tmplparm_pad" V="5" E="1"/> + <P N="sp_arraydecl_lbracket" V="5" E="1"/> + <P N="st_fundecl_nameline" V="5" E="0"/> + <P N="st_oneline_dowhile" V="4" E="1"/> + <P N="sp_op_bitwise" V="3" E="1"/> + <P N="st_oneline_catch" V="5" E="1"/> + <P N="sp_ctlstmt_rparen" V="5" E="1"/> + <P N="sp_ctlstmt_padparen" V="5" E="1"/> + <P N="st_newline_after_extern" V="4" E="1"/> + <P N="sp_for_lparen" V="4" E="1"/> + <P N="sp_funcall_voidparen" V="5" E="1"/> + <P N="sp_switch_defcolon" V="0" E="1"/> + <P N="sp_switch_padparen" V="5" E="1"/> + <P N="sp_class_colon" V="3" E="1"/> + <P N="sp_fun_padparen" V="5" E="1"/> + <P N="sp_if_rparen" V="4" E="1"/> + <P N="sp_struct_comma" V="2" E="1"/> + <P N="sp_ptr_is" V="4" E="1"/> + <P N="sp_fun_equals" V="3" E="1"/> + <P N="sp_delete_rbracket" V="4" E="1"/> + <P N="sp_op_bitand" V="3" E="1"/> + <P N="sp_op_assignment" V="3" E="1"/> + <P N="sp_ref_av" V="5" E="1"/> + <P N="sp_new_lparen" V="5" E="1"/> + <P N="sp_struct_colon" V="3" E="1"/> + <P N="sp_ptr_srp" V="5" E="1"/> + <P N="sp_for_comma" V="2" E="1"/> + <P N="sp_funcall_comma" V="2" E="1"/> + <P N="sp_class_comma" V="2" E="1"/> + <P N="sp_funcall_operator" V="0" E="1"/> + <P N="st_oneline_access" V="4" E="1"/> + <P N="sp_arrayexpr_rbracket" V="5" E="1"/> + <P N="sp_cppcast_gt" V="5" E="1"/> + <P N="sp_op_mult" V="3" E="1"/> + <P N="sp_fun_commainit" V="2" E="1"/> + <P N="sp_tmpldecl_lt" V="5" E="1"/> + <P N="sp_arraydecl_rbracket" V="5" E="1"/> + <P N="sp_for_lbrace" V="1" E="0"/> + <P N="sp_init_lbrace" V="2" E="1"/> + <P N="st_oneline_then" V="5" E="1"/> + <P N="sp_catch_lparen" V="4" E="1"/> + <P N="sp_fun_operator" V="0" E="1"/> + <P N="sp_ptr_ss" V="5" E="1"/> + <P N="sp_member_dot" V="0" E="1"/> + <P N="sp_tmplcall_pad" V="5" E="1"/> + <P N="sp_enum_lbrace" V="1" E="1"/> + <P N="sp_ptr_sv" V="5" E="1"/> + <P N="sp_for_rparen" V="4" E="1"/> + <P N="sp_while_rparen" V="4" E="1"/> + <P N="sp_ret_parexpr" V="4" E="1"/> + <P N="sp_throw_parexpr" V="4" E="1"/> + <P N="st_nl_class" V="5" E="0"/> + <P N="st_oneline_statement" V="5" E="1"/> + <P N="sp_union_lbrace" V="1" E="1"/> + <P N="st_oneline_elsif" V="4" E="1"/> + <P N="sp_op_unary" V="0" E="1"/> + <P N="sp_op_binary" V="3" E="1"/> + <P N="sp_new_rparen" V="4" E="1"/> + <P N="sp_new_padparen" V="5" E="1"/> + <P N="sp_cast_lparen" V="5" E="1"/> + <P N="sp_op_comparison" V="3" E="1"/> + <P N="sp_catch_rparen" V="4" E="1"/> + <P N="sp_fun_lparen" V="5" E="1"/> + <P N="sp_fun_voidparen" V="5" E="1"/> + <P N="sp_enum_comma" V="2" E="1"/> + <P N="sp_enum_equals" V="3" E="1"/> + <P N="sp_cppcast_lt" V="5" E="1"/> + <P N="sp_while_lbrace" V="1" E="1"/> + <P N="sp_switch_lbrace" V="1" E="1"/> + <P N="sp_op_logical" V="3" E="1"/> + <P N="sp_for_semicolon" V="2" E="1"/> + <P N="st_nl_fn" V="4" E="0"/> + <P N="sp_cast_padparen" V="5" E="1"/> + <P N="sp_funcall_rparen" V="5" E="1"/> + <P N="sp_funcall_lparen" V="5" E="1"/> + <P N="sp_switch_colon" V="0" E="1"/> + <P N="sp_enum_colon" V="3" E="1"/> + <P N="sp_ptr_slp" V="5" E="1"/> + <P N="sp_ptr_sa" V="5" E="1"/> + <P N="sp_ref_ia" V="4" E="1"/> + <P N="sp_tmplcall_comma" V="2" E="1"/> + <P N="sp_fun_comma" V="2" E="1"/> + <P N="sp_tmplparm_comma" V="2" E="1"/> + <P N="st_leave_declmult" V="4" E="1"/> + <P N="sp_tmplcall_lt" V="5" E="1"/> + <P N="sp_catch_lbrace" V="1" E="1"/> + <P N="sp_fun_lbrace" V="3" E="1"/> + <P N="sp_if_lbrace" V="1" E="1"/> + <P N="sp_ptr_si" V="4" E="1"/> + <P N="sp_ctlstmt_lparen" V="4" E="1"/> + <P N="sp_for_padparen" V="5" E="1"/> + <P N="sp_cast_rparen" V="5" E="1"/> + <P N="sp_switch_rparen" V="4" E="1"/> + <P N="sp_fun_colon" V="3" E="1"/> + <P N="sp_delete_lbracket" V="5" E="1"/> + <P N="sp_tmplparm_lt" V="5" E="1"/> + <P N="sp_pp_eatspace" V="4" E="0"/> + <P N="sp_op_dereference" V="0" E="1"/> + <P N="sp_struct_lbrace" V="1" E="1"/> + <P N="sp_member_arrow" V="0" E="1"/> + <P N="sp_op_prefix" V="0" E="1"/> + <P N="sp_fptr_si" V="4" E="1"/> + <P N="sp_funcall_padparen" V="5" E="1"/> + <P N="sp_while_padparen" V="5" E="1"/> + <P N="sp_while_lparen" V="4" E="1"/> + <P N="sp_fun_rparen" V="5" E="1"/> + <P N="sp_ref_alp" V="5" E="1"/> + <P N="st_leave_stmtmult" V="4" E="1"/> + <P N="sp_arrayexpr_padbracket" V="5" E="1"/> + <P N="sp_arraydecl_padbracket" V="5" E="1"/> + <P N="sp_ctlstmt_lbrace" V="3" E="1"/> + <P N="st_oneline_else" V="5" E="1"/> + <P N="st_nl_case" V="4" E="0"/> + <P N="sp_init_rbrace" V="1" E="1"/> + <P N="sp_op_addressof" V="0" E="1"/> + <P N="sp_op_postfix" V="0" E="1"/> + <P N="sp_if_lparen" V="4" E="1"/> + <P N="sp_if_padparen" V="5" E="1"/> + <P N="original_tab" V="4" E="1"/> + <P N="indent_use_tab" V="1" E="1"/> + <P N="indent_tab_custom" V="0" E="1"/> + <P N="indent_first_level" V="1" E="1"/> + <P N="indent_goto" V="0" E="1"/> + <P N="indent_extern" V="0" E="1"/> + <P N="indent_namespace" V="0" E="1"/> + <P N="align_on_equals" V="1" E="1"/> + <P N="exp_paren_align" V="8" E="1"/> + <P N="indent_preprocessing" V="0" E="1"/> + <P N="indent_in_block" V="0" E="1"/> + <P N="indent_guard" V="0" E="1"/> + <P N="indent_pp_col1" V="0" E="1"/> + <P N="brace_loc_if" V="13" E="1"/> + <P N="brace_loc_for" V="13" E="1"/> + <P N="brace_loc_while" V="13" E="1"/> + <P N="brace_loc_switch" V="13" E="1"/> + <P N="brace_loc_do" V="13" E="1"/> + <P N="brace_loc_try" V="13" E="1"/> + <P N="brace_loc_catch" V="13" E="1"/> + <P N="brace_loc_asm" V="13" E="1"/> + <P N="brace_loc_namespace" V="13" E="1"/> + <P N="brace_loc_class" V="13" E="1"/> + <P N="brace_loc_enum" V="13" E="1"/> + <P N="brace_loc_fun" V="13" E="1"/> + <P N="rm_trailing_ws" V="4" E="1"/> + <P N="rm_dup_ws" V="5" E="1"/> + <P N="respace_other" V="4" E="1"/> + <P N="comment_indent" V="4" E="1"/> + <P N="comment_col1_indent" V="5" E="1"/> + <P N="parens_return" V="18" E="1"/> + <P N="parens_throw" V="5" E="0"/> + <P N="fundecl_void" V="5" E="0"/> + <P N="fun_assoc_with_ret_type" V="4" E="1"/> + <P N="cppb_sp_fptr_padparen" V="5" E="1"/> + <P N="cppb_sp_fptr_lparen" V="4" E="1"/> + <P N="cppb_sp_fptr_rparen" V="5" E="1"/> + <P N="allow_one_line_block" V="4" E="1"/> + <P N="allow_class_one_line_block" V="4" E="1"/> + <P N="st_newline_before_else" V="4" E="1"/> + <P N="cont_indent_returntype" V="0" E="1"/> + <P N="trailing_comment_align" V="2" E="1"/> + <P N="trailing_comment_value" V="70" E="1"/> + <P N="indent_from_brace" V="0" E="1"/> + <P N="label_indent" V="1" E="1"/> + <P N="sp_ty_star_prototype" V="4" E="1"/> + <P N="sp_ty_amp_prototype" V="4" E="1"/> + <P N="sp_return_padparen" V="5" E="1"/> + <P N="sp_return_rparen" V="5" E="1"/> + <P N="sp_throw_padparen" V="5" E="1"/> + <P N="sp_throw_rparen" V="5" E="1"/> + <P N="sp_expr_lparen" V="5" E="1"/> + <P N="sp_expr_padparen" V="5" E="1"/> + <P N="sp_expr_rparen" V="5" E="1"/> + <P N="sp_disassoc_ret_type_ref" V="4" E="1"/> + <P N="sp_stmt_semicolon" V="4" E="1"/> + <P N="sp_namespace_lbrace" V="3" E="1"/> + <P N="sp_try_lbrace" V="3" E="1"/> + <P N="brace_follows_case" V="1" E="1"/> + <P N="pp_indent_with_code" V="0" E="1"/> + <P N="meth_decl_align" V="19" E="1"/> + <P N="meth_call_align" V="19" E="1"/> + <P N="category_padparen" V="5" E="1"/> + <P N="category_lparen" V="4" E="1"/> + <P N="category_rparen" V="4" E="1"/> + <P N="sp_decl_selector_colon" V="2" E="1"/> + <P N="sp_call_selector_colon" V="2" E="1"/> + <P N="protocol_padparen" V="5" E="1"/> + <P N="protocol_lparen" V="4" E="1"/> + <P N="protocol_rparen" V="4" E="1"/> + <P N="protocol_comma" V="2" E="1"/> + <P N="meth_call_bracket_align" V="8" E="1"/> + <P N="meth_call_selalign_force" V="1" E="1"/> + <P N="prop_padparen" V="5" E="1"/> + <P N="prop_lparen" V="4" E="1"/> + <P N="prop_rparen" V="4" E="1"/> + <P N="prop_comma" V="2" E="1"/> + <P N="synth_comma" V="2" E="1"/> + <P N="synth_eq" V="0" E="1"/> + <P N="dynamic_comma" V="2" E="1"/> + <P N="meth_return_lparen" V="4" E="1"/> + <P N="meth_return_padparen" V="5" E="1"/> + <P N="meth_return_rparen" V="5" E="1"/> + <P N="meth_param_lparen" V="5" E="1"/> + <P N="meth_param_padparen" V="5" E="1"/> + <P N="meth_param_rparen" V="5" E="1"/> + <P N="block_initial_indent" V="4" E="1"/> + <P N="finally_lbrace" V="3" E="1"/> + <P N="synchronized_lparen" V="5" E="1"/> + <P N="synchronized_padparen" V="5" E="1"/> + <P N="synchronized_rparen" V="5" E="1"/> + <P N="synchronized_lbrace" V="3" E="1"/> + <P N="prop_eq" V="0" E="1"/> + </profile> +</profiles> |