radxide.tcl 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. #! /usr/bin/env tclsh
  2. ###########################################################
  3. # Name: radxide.tcl
  4. # Author: Daniele Bonini (posta@elettronica.lol)
  5. # Date: 05/12/2023
  6. # Desc: Bootstrap file of RadXIDE.
  7. #
  8. # Bootstrap file and most of the code
  9. # here presented and distributed contains excerpts
  10. # from [alited](https://github.com/aplsimple/alited
  11. # by Alex Plotnikov and contributors to the project.
  12. # The original code of these excerpts could be
  13. # borrowed from other sources which the author
  14. # and the contributors to this RadXIDE have no
  15. # knowledge about.
  16. #
  17. # Code Library scaffolding and most of its code contains
  18. # excerpts from "Practical Programming in Tcl and Tk, 4th Ed."
  19. # by Brent B. Welch, Ken Jones, Jeffrey Hebbs.
  20. # The original code of these excerpts could be
  21. # borrowed from other sources which the author
  22. # and the contributors to RadXIDE have no
  23. # knowledge about. For the related copyright notice
  24. # refer <eglib.tcl> part of this software.
  25. #
  26. # License: MIT. Copyrights 5 Mode (Last implementation and adaptations.)
  27. # Copyright (c) 2021-2023 Alex Plotnikov https://aplsimple.github.io (original scaffolding and excerpts.)
  28. #
  29. ###########################################################
  30. package provide radxide 1.2.2
  31. set _ [package require Tk]
  32. wm withdraw .
  33. if {![package vsatisfies $_ 8.6.10-]} {
  34. tk_messageBox -message "\nradxide needs Tcl/Tk v8.6.10+ \
  35. \n\nwhile the current is v$_\n"
  36. exit
  37. }
  38. unset -nocomplain _
  39. # __________________________ radxide:: Main _________________________ #
  40. namespace eval radxide {
  41. variable dan; array set dan [list]
  42. variable tcltk_version "Tcl/Tk [package versions Tk]"
  43. ## ________________________ Main variables _________________________ ##
  44. set DEBUG no ;# debug mode
  45. set dan(WIN) .danwin ;# main form
  46. set dan(WORKDIR) "/home/YourUser/.radxwork" ;# root working dir
  47. set dan(TITLE) RADXIDE
  48. # Check workdir existance..
  49. if {![file exists $dan(WORKDIR)]} {
  50. file mkdir $dan(WORKDIR)
  51. }
  52. # Check Code Library dir existance.. (WORKDIR)/.examples)
  53. if {![file exists $dan(WORKDIR)/.snippets]} {
  54. file mkdir $dan(WORKDIR)/.snippets
  55. }
  56. set dan(TREEVIEW) "" ;# ide project tree
  57. set dan(GUTTEXT) "" ;# ide guttext control
  58. set dan(GUTTERWIDTH) 12
  59. set dan(TEXT) "" ;# ide text control
  60. set dan(TEXTBG) "#222223"
  61. set dan(TEXTFG) "#55ff55"
  62. set dan(TEXTSELFG) "red"
  63. set dan(CURSORCOLOR) "red"
  64. set dan(CURSORWIDTH) "4"
  65. set dan(prjdirignore) {.git .bak} ;# ignored subdirectories of project
  66. set project(NAME) "" ;# project default name
  67. set project(ROOT) "" ;# project default root
  68. set project(PATH) "" ;# project default path
  69. set project(CUR_FILE_PATH) "" ;# project current file path
  70. set project(TREE_PROJECT_ROOT) "" ;# Treeview: Project root node
  71. set project(TREE_PRIVATE_ROOT) "" ;# Treeview: Private node
  72. set project(TREE_PUBLIC_ROOT) "" ;# Treeview: Public node
  73. set files(FILE1) "" ;# Array files
  74. set files(FILE2) ""
  75. set files(FILE3) ""
  76. set files(FILE4) ""
  77. set files(FILE5) ""
  78. # main data of radxide (others are in ini.tcl)
  79. variable SCRIPT [info script]
  80. variable SCRIPTNORMAL [file normalize $SCRIPT]
  81. variable FILEDIR [file dirname $SCRIPTNORMAL]
  82. variable DIR [file dirname $FILEDIR]
  83. # directories of sources
  84. variable SRCDIR [file join $DIR src]
  85. variable LIBDIR [file join $DIR lib]
  86. # misc. vars
  87. variable pID 0
  88. # directory tree's content
  89. variable _dirtree [list]
  90. set dan(TITLE_TEMPL) {%f :: %t} ;# radxide title's template
  91. set dan(WIDTH) 1280
  92. set dan(HEIGHT) 760
  93. #set al(MOVEFG) "black"
  94. #set al(MOVEBG) "#7eeeee"
  95. set dan(FG) "#000000"
  96. set dan(BG) "#cecece"
  97. set dan(fgred) "red"
  98. set dan(fgbold) "magenta"
  99. set dan(fgtodo) "orange"
  100. set dan(fgbranch) "blue"
  101. set dan(CHARFAMILY) "Sans"
  102. set dan(CHARSIZE) 10
  103. set dan(MAXFILES) 250
  104. set dan(MAXFILESIZE) 65534
  105. set dan(MAXFINDLENGTH) 50
  106. set dan(TAB_IN_SPACE) " "
  107. # icons
  108. set dan(ICON) "icons/radxide.png"
  109. set dan(ICONI) [image create photo imgobj1 -file $dan(ICON)]
  110. set icons(PROJECT-ICON) "icons/archive.png"
  111. set icons(PROJECT-ICONI) [image create photo imgobj2 -file $icons(PROJECT-ICON)]
  112. set icons(PUBLICF-ICON) "icons/public-folder.png"
  113. set icons(PUBLICF-ICONI) [image create photo imgobj3 -file $icons(PUBLICF-ICON)]
  114. set icons(PRIVATEF-ICON) "icons/private-folder.png"
  115. set icons(PRIVATEF-ICONI) [image create photo imgobj4 -file $icons(PRIVATEF-ICON)]
  116. set icons(HTML-ICON) "icons/file-html.png"
  117. set icons(HTML-ICONI) [image create photo imgobj5 -file $icons(HTML-ICON)]
  118. set icons(JS-ICON) "icons/file-js.png"
  119. set icons(JS-ICONI) [image create photo imgobj6 -file $icons(JS-ICON)]
  120. set icons(IMG-ICON) "icons/image.png"
  121. set icons(IMG-ICONI) [image create photo imgobj7 -file $icons(IMG-ICON)]
  122. set icons(CSS-ICON) "icons/file-css.png"
  123. set icons(CSS-ICONI) [image create photo imgobj8 -file $icons(CSS-ICON)]
  124. set icons(PHP-ICON) "icons/file-php.png"
  125. set icons(PHP-ICONI) [image create photo imgobj9 -file $icons(PHP-ICON)]
  126. set icons(TXT-ICON) "icons/file-txt.png"
  127. set icons(TXT-ICONI) [image create photo imgobj10 -file $icons(TXT-ICON)]
  128. set icons(GENERIC-FILE-ICON) "icons/file-generic.png"
  129. set icons(GENERIC-FILE-ICONI) [image create photo imgobj11 -file $icons(GENERIC-FILE-ICON)]
  130. set icons(FOLDER-ICON) "icons/folder.png"
  131. set icons(FOLDER-ICONI) [image create photo imgobj12 -file $icons(FOLDER-ICON)]
  132. # Menu variables
  133. set menu(ROOT) "";
  134. set menu(ADD_FILE_ENTRY_IDX) 2;
  135. set menu(SAVE_AS_ENTRY_IDX) 4;
  136. set menu(SAVE_ENTRY_IDX) 5;
  137. set menu(CLOSE_ENTRY_IDX) 7;
  138. set menu(CLOSE_PROJECT_ENTRY_IDX) 8;
  139. set menu(COPY_ENTRY_IDX) 0;
  140. set menu(PASTE_ENTRY_IDX) 1;
  141. set menu(CUT_ENTRY_IDX) 2;
  142. set menu(FIND_ENTRY_IDX) 4;
  143. set menu(GOTO_ENTRY_IDX) 5;
  144. # a couplle of extension definitions..
  145. set dan(PhpExts) {.php .php2 .php3 .php4 .php5 .funny .inc} ;# extensions of php files
  146. set dan(HtmlExts) {.html .htm} ;# extensions of html files
  147. set dan(CssExts) {.css} ;# extensions of css files
  148. set dan(JsExts) {.js} ;# extensions of js files
  149. set dan(TxtExts) {.txt .rtf} ;# extensions of txt files
  150. set dan(ImgExts) {.gif .png .jpg .jpeg} ;# extensions of images
  151. set dan(BinExts) {.so .o .exe} ;# extensions of binary
  152. # __________________ iswindows ___________________ #
  153. proc iswindows {} {
  154. # Checks for "platform is MS Windows".
  155. expr {$::tcl_platform(platform) eq {windows}}
  156. }
  157. # __________________ quit ___________________ #
  158. proc quit {{w ""} {res 0} {ask yes}} {
  159. # Closes alited application.
  160. # w - not used
  161. # res - result of running of main window
  162. # ask - if "yes", requests the confirmation of the exit
  163. exit 0;
  164. }
  165. # __________________ raise_window ___________________ #
  166. proc raise_window {} {
  167. # Raises the app's window.
  168. variable dan
  169. catch {
  170. wm withdraw $dan(WIN)
  171. wm deiconify $dan(WIN)
  172. }
  173. }
  174. # __________________ Tclexe ___________________ #
  175. proc Tclexe {} {
  176. # Gets Tcl's executable file.
  177. variable dan
  178. set tclexe [info nameofexecutable]
  179. return $tclexe
  180. }
  181. source [file join $SRCDIR main.tcl]
  182. source [file join $SRCDIR filelib.tcl]
  183. source [file join $SRCDIR win.tcl]
  184. source [file join $SRCDIR menu.tcl]
  185. source [file join $SRCDIR tree.tcl]
  186. source [file join $SRCDIR eglib.tcl]
  187. ## _ EONS: radxide _ ##
  188. }
  189. # ________________________ ::argv, ::argc _________________________ #
  190. set ::radxide::ARGV $::argv
  191. set ::radxide::dan(IsWindows) [expr {$::tcl_platform(platform) eq {windows}}]
  192. # _________________________ Run the app _________________________ #
  193. namespace upvar ::radxide dan dan
  194. radxide::main::_create ;# create the main form
  195. unset -nocomplain _
  196. if {[catch {set res [radxide::main::_run]} err]} {
  197. set res 0
  198. set msg "\nERROR in radxide:"
  199. puts \n$msg\n\n$::errorInfo\n
  200. set msg "$msg\n\n$err\n\nPlease, inform authors.\nDetails are in stdout."
  201. tk_messageBox -title $dan(TITLE) -icon error -message $msg
  202. exit 2
  203. }
  204. exit 0
  205. # _________________________________ EOF _________________________________ #