summaryrefslogtreecommitdiffstats
path: root/SlickEdit
diff options
context:
space:
mode:
Diffstat (limited to 'SlickEdit')
-rw-r--r--SlickEdit/beautifier-profiles.cfg.xml551
-rw-r--r--SlickEdit/color_profiles.cfg.xml96
-rw-r--r--SlickEdit/kdev.e3972
-rw-r--r--SlickEdit/kkeys.e427
-rw-r--r--SlickEdit/lexer-def.cfg.xml7
-rw-r--r--SlickEdit/lexer-kmk-v2.cfg.xml147
-rw-r--r--SlickEdit/lexer-kmk.cfg.xml135
-rw-r--r--SlickEdit/uscheme.ini257
-rw-r--r--SlickEdit/user.vlx16
-rw-r--r--SlickEdit/usrprjtemplates.vpt52
-rw-r--r--SlickEdit/vusr_beautifier.xml447
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,&amp;"/>
+ <p n="op,*"/>
+ <p n="op,+"/>
+ <p n="op,,"/>
+ <p n="op,-"/>
+ <p n="op,."/>
+ <p n="op,/"/>
+ <p n="op,&lt;"/>
+ <p n="op,="/>
+ <p n="op,&gt;"/>
+ <p n="op,?"/>
+ <p n="op,^"/>
+ <p n="op,`"/>
+ <p n="op,|"/>
+ <p n="op,~"/>
+ <p n="op,:="/>
+ <p n="op,+="/>
+ <p n="op,&gt;="/>
+ <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,&amp;"/>
+ <p n="op,*"/>
+ <p n="op,+"/>
+ <p n="op,,"/>
+ <p n="op,-"/>
+ <p n="op,."/>
+ <p n="op,/"/>
+ <p n="op,&lt;"/>
+ <p n="op,="/>
+ <p n="op,&gt;"/>
+ <p n="op,?"/>
+ <p n="op,^"/>
+ <p n="op,`"/>
+ <p n="op,|"/>
+ <p n="op,~"/>
+ <p n="op,:="/>
+ <p n="op,+="/>
+ <p n="op,&gt;="/>
+ <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="&amp;Compile"
+ CaptureOutputWith="ProcessBuffer"
+ SaveOption="SaveCurrent"
+ RunFromDir="%p"
+ ClearProcessBuffer="1">
+ <Exec CmdLine="kmk -C %p %n.o"/>
+ </Target>
+ <Target
+ Name="Build"
+ MenuCaption="&amp;Build"
+ CaptureOutputWith="ProcessBuffer"
+ SaveOption="SaveWorkspaceFiles"
+ RunFromDir="%rw"
+ ClearProcessBuffer="1">
+ <Exec CmdLine="kmk"/>
+ </Target>
+ <Target
+ Name="Rebuild"
+ MenuCaption="&amp;Rebuild"
+ CaptureOutputWith="ProcessBuffer"
+ SaveOption="SaveWorkspaceFiles"
+ RunFromDir="%rw"
+ ClearProcessBuffer="1">
+ <Exec CmdLine="kmk rebuild"/>
+ </Target>
+ <Target
+ Name="Debug"
+ MenuCaption="&amp;Debug"
+ SaveOption="SaveNone"
+ RunFromDir="%rw">
+ <Exec/>
+ </Target>
+ <Target
+ Name="Execute"
+ MenuCaption="E&amp;xecute"
+ SaveOption="SaveNone"
+ RunFromDir="%rw">
+ <Exec CmdLine='"%&lt;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>