25 Commits

Author SHA1 Message Date
svk
0f9d6e9214 Новая сборка бета4 2026-02-13 11:27:41 +03:00
svk
40ceb04bf8 Исправлено регшулярное выражение для поиска переменных в коде на С. 2026-02-13 11:22:36 +03:00
svk
b12381dbce Сборка beta4 2026-02-12 12:05:33 +03:00
svk
3d0ae84dc2 Добавил экранирование '*' в имени функции для поиска. 2026-02-12 11:53:37 +03:00
svk
afa368c519 Подкрректировал регулярки для работы с С. 2026-02-12 11:53:06 +03:00
svk
118638e42e Исиправил закрытие вкладки при отпускании кнопки мыши при нажатии на крестик. 2026-02-12 10:58:42 +03:00
svk
723426b1d6 Добавил иконки для 'c' и 'h'. Добавил сочитание Alt-R в русской раскладке 2026-02-06 18:42:47 +03:00
svk
c8547ec45b Добавил поддержку С (подсветка, навигация) 2026-02-06 18:03:04 +03:00
svk
e83507eb9b Добавил копирование готовых пакетов
All checks were successful
Build and Release / build (push) Successful in 24s
2026-02-06 15:22:39 +03:00
svk
382e62df95 Откорректировал сборку рпм
All checks were successful
Build and Release / build (push) Successful in 31s
2026-02-06 15:12:38 +03:00
svk
7d0b40d651 Добавил сборку rpm. Исправил changelog-и
Some checks failed
Build and Release / build (push) Failing after 1m8s
2026-02-06 14:07:53 +03:00
svk
2877ebc8a2 changelog-gen: исправил дату еще раз 2026-02-06 13:57:07 +03:00
svk
04ba6663ee changelog-gen: исправил формат даты для сохранения 2026-02-06 13:31:38 +03:00
svk
676a0e6185 changelog-gen: доделал генерацию списка изменений для rmp.spec 2026-02-06 12:40:46 +03:00
svk
5dc1da5dbf Правка changelog 2026-02-06 12:12:36 +03:00
svk
7511a5445e Исправил смену регистра в заголовках вкладок, тепеь имена файлов во вкладках как и должны быть.
Исправил обработку Return при использовании функции поиска и перехода по процеедурам/функциям/разделам внутри файла по нажатию Control-j
2026-02-05 18:49:28 +03:00
svk
3860db2c26 Новая сборка
All checks were successful
Build and Release / build (push) Successful in 20s
2026-01-30 14:10:22 +03:00
svk
bded0b22b1 Правка 2026-01-30 14:08:05 +03:00
svk
478f1d156f Добавил проверки в диалог FileOper::SaveFile 2026-01-30 14:07:14 +03:00
svk
e86b600cd9 Добавил диалог 'Сохранить как'
All checks were successful
Build and Release / build (push) Successful in 24s
2026-01-30 13:47:05 +03:00
svk
c4923c5871 Merge pull request 'beta3' (#9) from beta3 into master
All checks were successful
Build and Release / build (push) Successful in 23s
Reviewed-on: #9
2026-01-29 16:07:40 +03:00
svk
c2d128dd42 Новая сборка 2026-01-29 16:00:03 +03:00
svk
166cd5f4d8 Добавил проверку на наличие символа переменной. 2026-01-29 15:57:16 +03:00
svk
782ed0298a Выпуск 3-й беты 2026-01-29 14:58:09 +03:00
svk
3de27dac4f Исправил работу со списком переменных из всплывающего окна. Теперь там можно выбрать из списка стрелками и вставить по Enter. 2026-01-29 14:22:55 +03:00
18 changed files with 608 additions and 92 deletions

View File

@@ -67,7 +67,10 @@ jobs:
echo "=== Сборка OpenBSD пакета ===" echo "=== Сборка OpenBSD пакета ==="
cd ../openbsd && ./build-package-bsd.sh cd ../openbsd && ./build-package-bsd.sh
echo "=== Сборка RPM пакета ==="
cd ../redhat && ./build-rpm.sh
echo "=== Собранные файлы ===" echo "=== Собранные файлы ==="
find . -maxdepth 1 -name "projman*" -type f | xargs ls -la 2>/dev/null || echo "Файлы не найдены" find . -maxdepth 1 -name "projman*" -type f | xargs ls -la 2>/dev/null || echo "Файлы не найдены"
@@ -187,7 +190,7 @@ jobs:
echo "ID релиза для загрузки: $REL_ID" echo "ID релиза для загрузки: $REL_ID"
# Находим все файлы projman # Находим все файлы projman
FILES=$(find ../ -maxdepth 1 \( -name "*projman*deb" -o -name "*projman*tgz" \) -type f) FILES=$(find ../ -maxdepth 1 \( -name "*projman*deb" -o -name "*projman*tgz" -o -name "*projman*rpm" \) -type f)
if [ -z "$FILES" ]; then if [ -z "$FILES" ]; then
echo "Нет файлов projman для загрузки" echo "Нет файлов projman для загрузки"
exit 0 exit 0
@@ -227,9 +230,9 @@ jobs:
echo "Ответ API: $API_RESPONSE" echo "Ответ API: $API_RESPONSE"
if [ "$HTTP_STATUS" = "201" ] || [ "$HTTP_STATUS" = "200" ]; then if [ "$HTTP_STATUS" = "201" ] || [ "$HTTP_STATUS" = "200" ]; then
echo "Файл загружен: $FILENAME" echo "Файл загружен: $FILENAME"
else else
echo "ОШИБКА загрузки: $FILENAME" echo "ОШИБКА загрузки: $FILENAME"
echo "Детали: $API_RESPONSE" echo "Детали: $API_RESPONSE"
fi fi
@@ -266,4 +269,4 @@ jobs:
fi fi
echo "Собранные файлы:" echo "Собранные файлы:"
find ../ -maxdepth 1 \( -name "*projman*deb" -o -name "*projman*tgz" \) -type f | xargs ls -la 2>/dev/null || echo "Файлы не найдены" find ../ -maxdepth 1 \( -name "*projman*deb" -o -name "*projman*tgz" -o -name "*projman*rpm"\) -type f | xargs ls -la 2>/dev/null || echo "Файлы не найдены"

View File

@@ -1,3 +1,4 @@
projman (2.0.0-beta1) stable; urgency=medium projman (2.0.0-beta1) stable; urgency=medium
* Сделан вывод отладочной информации по запросу. * Сделан вывод отладочной информации по запросу.

View File

@@ -17,6 +17,7 @@ Highlightning and source code navigation:
* Markdown * Markdown
* YAML (Ansible support) * YAML (Ansible support)
* Lua * Lua
* C
Highlightning: Highlightning:

View File

@@ -106,14 +106,14 @@ proc ReadGitLog {} {
} }
} }
proc StoreProjectInfo {timeStamp} { proc StoreProjectInfo {timeStamp changelogFormat} {
global dir args global dir args
set cfgFile [open [file join $dir(cfg) $args(--project-name).conf] "w+"] set cfgFile [open [file join $dir(cfg) $args(--project-name).$changelogFormat.conf] "w+"]
puts $cfgFile "# set args(--project-version) \"$args(--project-version)\"" puts $cfgFile "# set args(--project-version) \"$args(--project-version)\""
puts $cfgFile "# set args(--project-release) \"$args(--project-release)\"" puts $cfgFile "# set args(--project-release) \"$args(--project-release)\""
puts $cfgFile "set lastCommitTimeStamp \"$timeStamp\"" puts $cfgFile "set lastCommitTimeStamp \"$timeStamp\""
puts $cfgFile "set lastCommitTimeStampSec [clock scan $timeStamp]" puts $cfgFile "set lastCommitTimeStampSec [clock scan $timeStamp]"
close $cfgFile close $cfgFile
} }
@@ -141,37 +141,77 @@ proc GenerateChangelogDEB {} {
set timeStamp [clock format [clock scan $timeStamp] -format {%a, %e %b %Y %H:%M:%S %z}] set timeStamp [clock format [clock scan $timeStamp] -format {%a, %e %b %Y %H:%M:%S %z}]
# puts "> $commiter" # puts "> $commiter"
if {$index == 0} { if {$index == 0} {
puts "$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n" # puts "$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n"
append outText "$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n\n" append outText "$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n\n"
set commiter [lindex $record 2] set commiter [lindex $record 2]
StoreProjectInfo $timeStamp StoreProjectInfo $timeStamp "deb"
# puts "\n \[ [string trim $commiter] \]" # puts "\n \[ [string trim $commiter] \]"
} }
# puts ">> $commiter" # puts ">> $commiter"
if {$commiter ne [lindex $record 2]} { if {$commiter ne [lindex $record 2]} {
puts "\n -- [string trim $commiter] <$email> $timeStamp" # puts "\n -- [string trim $commiter] <$email> $timeStamp"
append outText "\n -- [string trim $commiter] <$email> $timeStamp\n" append outText "\n -- [string trim $commiter] <$email> $timeStamp\n"
puts "\n$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n" # puts "\n$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n"
append outText "\n$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n\n" append outText "\n$args(--project-name) ($args(--project-version)-$args(--project-release)) stable; urgency=medium\n\n"
set commiter [lindex $record 2] set commiter [lindex $record 2]
# puts "\n \[ [string trim $commiter] \]" # puts "\n \[ [string trim $commiter] \]"
} }
set commitTex [lindex $record 4] set commitTex [lindex $record 4]
puts " * $commitTex" # puts " * $commitTex"
append outText " * $commitTex\n" append outText " * $commitTex\n"
} }
puts "\n -- [string trim $commiter] <$email> $timeStamp" # puts "\n -- [string trim $commiter] <$email> $timeStamp"
append outText "\n -- [string trim $commiter] <$email> $timeStamp\n" append outText "\n -- [string trim $commiter] <$email> $timeStamp\n"
return $outText return $outText
} }
proc GenerateChangelogRPM {} { proc GenerateChangelogRPM {} {
puts "GenerateChangelogRPM" global args
# puts "GenerateChangelogRPM"
set lastCommitTimeStamp ""
set commiter ""
set commitText ""
# ReadGitLog
set lst [lsort -integer -index 0 [ReadGitLog]]
# puts $lst
# exit
set outText ""
foreach l $lst {
set index [lindex $l 0]
set line [lindex $l 1]
# puts "$index - $line"
set record [split $line ","]
set timeStamp [string trim [lindex $record 1]]
set email [string trim [lindex $record 3]]
if {$lastCommitTimeStamp eq ""} {
set lastCommitTimeStamp [string trim [lindex $record 1]]
}
set timeStampForStore [clock format [clock scan $timeStamp] -format {%a, %e %b %Y %H:%M:%S %z}]
set timeStamp [clock format [clock scan $timeStamp] -format {%a %b %e %Y}]
if {$index == 0} {
set commiter [lindex $record 2]
append outText "* $timeStamp [string trim $commiter] <$email> $args(--project-version)-$args(--project-release)\n"
StoreProjectInfo $timeStampForStore "rpm"
}
if {$commiter ne [lindex $record 2]} {
append outText "\n"
append outText "* $timeStamp [string trim $commiter] <$email> $args(--project-version)-$args(--project-release)\n"
set commiter [lindex $record 2]
}
set commitTex [lindex $record 4]
# puts " * $commitTex"
append outText " - $commitTex\n"
}
# puts "\n -- [string trim $commiter] <$email> $timeStamp"
# append outText "\n -- [string trim $commiter] <$email> $timeStamp\n"
return $outText
} }
proc GenerateChangelogTXT {} { proc GenerateChangelogTXT {} {
global args global args
set lastCommitTimeStamp "" set lastCommitTimeStamp ""
@@ -189,14 +229,15 @@ proc GenerateChangelogTXT {} {
if {$lastCommitTimeStamp eq ""} { if {$lastCommitTimeStamp eq ""} {
set lastCommitTimeStamp [string trim [lindex $record 1]] set lastCommitTimeStamp [string trim [lindex $record 1]]
} }
set timeStamp [clock format [clock scan $timeStamp] -format {%a, %e %b %Y %H:%M:%S %z}] # * Mon Nov 28 2022 Sergey Kalinin <svk@nuk-svk.ru> 2.0.0
set timeStamp [clock format [clock scan $timeStamp] -format {%a %b %e %Y %H:%M:%S %z}]
# puts "> $commiter" # puts "> $commiter"
if {$index == 0} { if {$index == 0} {
append outText "$args(--project-name) ($args(--project-version)-$args(--project-release))\n" append outText "$args(--project-name) ($args(--project-version)-$args(--project-release))\n"
set commiter [lindex $record 2] set commiter [lindex $record 2]
puts "\n[string trim $commiter] <$email> $timeStamp" puts "\n[string trim $commiter] <$email> $timeStamp"
append outText "\n[string trim $commiter] <$email> $timeStamp\n" append outText "\n[string trim $commiter] <$email> $timeStamp\n"
StoreProjectInfo $timeStamp StoreProjectInfo $timeStamp "txt"
} }
if {$commiter ne [lindex $record 2]} { if {$commiter ne [lindex $record 2]} {
puts "\n[string trim $commiter] <$email> $timeStamp" puts "\n[string trim $commiter] <$email> $timeStamp"
@@ -254,6 +295,68 @@ proc StoreChangeLog {outText} {
} else { } else {
set outFile [open $args(--out-file) "w+"] set outFile [open $args(--out-file) "w+"]
puts $outFile $outText puts $outFile $outText
puts $outText
close $outFile
}
}
proc StoreChangeLogRPM {outText} {
global args
if [file exists $args(--out-file)] {
file copy -force $args(--out-file) "$args(--out-file).tmp"
set fh [open $args(--out-file) r]
set lines [split [read $fh] "\n"]
close $fh
set result [list]
set inserted false
foreach line $lines {
lappend result $line
if {!$inserted && $line eq "%changelog"} {
lappend result $outText
set inserted true
}
}
set fh [open $args(--out-file) w]
puts $fh [join $result "\n"]
close $fh
}
}
proc StoreChangeLogRPM_ {outText} {
global args
puts "Changelog generator write a file $args(--out-file)"
if [file exists $args(--out-file)] {
file copy -force $args(--out-file) "$args(--out-file).tmp"
set origOutFile [open "$args(--out-file).tmp" "r"]
set origText [read $origOutFile]
close $origOutFile
set outFile [open $args(--out-file) "w"]
puts $outFile $outText
puts $outFile $origText
close $outFile
if [info exists args(--last)] {
set outFile [open $args(--out-file) "r+"]
puts $outFile $outText
close $outFile
} else {
set outFile [open $args(--out-file) "w+"]
puts $outFile $outText
close $outFile
}
} else {
set outFile [open $args(--out-file) "w+"]
puts $outFile $outText
puts $outText
close $outFile close $outFile
} }
} }
@@ -311,26 +414,43 @@ if ![info exists args(--project-release)] {
exit exit
} }
if [file exists [file join $dir(cfg) $args(--project-name).conf]] { puts "Running chngelog generator with folowing options:\n"
source [file join $dir(cfg) $args(--project-name).conf]
}
foreach arg [array names args] { foreach arg [array names args] {
puts "$arg $args($arg)" puts "\t$arg $args($arg)"
} }
if [info exists args(--deb)] { if [info exists args(--deb)] {
if [file exists [file join $dir(cfg) $args(--project-name).deb.conf]] {
source [file join $dir(cfg) $args(--project-name).deb.conf]
}
set outText [GenerateChangelogDEB] set outText [GenerateChangelogDEB]
if [info exists args(--out-file)] { if [info exists args(--out-file)] {
StoreChangeLog $outText StoreChangeLog $outText
} else {
puts $outText
} }
} }
if [info exists args(--rpm)] { if [info exists args(--rpm)] {
GenerateChangelogRPM if [file exists [file join $dir(cfg) $args(--project-name).rpm.conf]] {
source [file join $dir(cfg) $args(--project-name).rpm.conf]
}
set outText [GenerateChangelogRPM]
# puts $outText
if [info exists args(--out-file)] {
StoreChangeLogRPM $outText
} else {
puts $outText
}
} }
if [info exists args(--txt)] { if [info exists args(--txt)] {
if [file exists [file join $dir(cfg) $args(--project-name).txt.conf]] {
source [file join $dir(cfg) $args(--project-name).txt.conf]
}
set outText [GenerateChangelogTXT] set outText [GenerateChangelogTXT]
if [info exists args(--out-file)] { if [info exists args(--out-file)] {
StoreChangeLog $outText StoreChangeLog $outText
} else {
puts $outText
} }
} }

26
debian/changelog vendored
View File

@@ -1,3 +1,28 @@
projman (2.0.0-beta4) stable; urgency=medium
* Исправлено регулярное выражение для поиска переменных в коде на С.
* Добавил экранирование '*' в имени функции для поиска.
* Подкрректировал регулярки для работы с С.
* Исиправил закрытие вкладки при отпускании кнопки мыши при нажатии на крестик.
* Добавил иконки для 'c' и 'h'. Добавил сочитание Alt-R в русской раскладке
* Добавил поддержку С подсветка
* Добавил копирование готовых пакетов
* Откорректировал сборку рпм
* Добавил сборку rpm. Исправил changelog-и
-- svk <svk@nuk-svk.ru> Fri, 6 Feb 2026 14:07:53 +0300
projman (2.0.0-beta3) stable; urgency=medium
* changelog-gen: сделал вывод изменения в формате rpm.spec
* Исправил смену регистра в заголовках вкладок
* Добавил диалог вменю "Сохранить как"
* Добавил проверки в диалог FileOper::SaveFile
* Вынес код связанный с обработкой подсказок при вводе переменных и процедур в отдельный модуль.
* Исправил работу со списком переменных из всплывающего окна. Теперь там можно выбрать из списка стрелками и вставить по Enter. Исправил обработку клавиш Вверх Вниз Ввод Отмена в окне со списком вариантов.
-- svk <svk@nuk-svk.ru> Thu, 29 Jan 2026 14:22:55 +0300
projman (2.0.0-beta2) stable; urgency=medium projman (2.0.0-beta2) stable; urgency=medium
* Добавлено подключение (bind) сочетания клавиш указанных в настройках инструментов. * Добавлено подключение (bind) сочетания клавиш указанных в настройках инструментов.
@@ -486,3 +511,4 @@ projman (2.0.0-alfa0) stable; urgency=medium

View File

@@ -16,7 +16,7 @@ namespace eval Editor {
$node.frmText.t configure -$optionName $value $node.frmText.t configure -$optionName $value
} }
} }
# Comment one string or selected string # Comment one string or selected string
proc Comment {txt fileType} { proc Comment {txt fileType} {
global lexers cfgVariables global lexers cfgVariables
@@ -404,7 +404,14 @@ namespace eval Editor {
} }
proc ReleaseKey {k txt fileType} { proc ReleaseKey {k txt fileType} {
global cfgVariables lexers global cfgVariables lexers returnProcessed
# Если Return уже обработан в SelectFromList, пропускаем
# puts "$returnProcessed $k"
if {$k eq "Return" && [info exists returnProcessed]} {
unset returnProcessed
return
}
#
set pos [$txt index insert] set pos [$txt index insert]
set lineNum [lindex [split $pos "."] 0] set lineNum [lindex [split $pos "."] 0]
set posNum [lindex [split $pos "."] 1] set posNum [lindex [split $pos "."] 1]
@@ -508,10 +515,68 @@ namespace eval Editor {
if {$cfgVariables(variableHelper) eq "true"} { if {$cfgVariables(variableHelper) eq "true"} {
if {[dict exists $lexers $fileType variableSymbol] != 0} { if {[dict exists $lexers $fileType variableSymbol] != 0} {
set varSymbol [dict get $lexers $fileType variableSymbol] set varSymbol [dict get $lexers $fileType variableSymbol]
set lastSymbol [string last $varSymbol [$txt get $lineNum.0 $pos]] set lineText [$txt get $lineNum.0 $pos]
# # Ищем переменную с помощью регулярного выражения
# # Паттерн ищет $ за которым идет имя переменной И курсор сразу после имени
# if {[regexp "(\\$)(\[a-zA-Z_:\]\[a-zA-Z0-9_:\]*)\$" $lineText -> symbol varName]} {
# # Проверяем, что найденный $ - это действительно начало переменной
# # (а не часть строки или другого символа)
# DebugPuts "Found variable: $symbol$varName"
#
# # Дополнительная проверка: перед $ не должно быть обратного слэша (экранирование)
# set posOfVarSymbol [string last $varSymbol $lineText]
# if {$posOfVarSymbol > 0} {
# set charBefore [string index $lineText [expr {$posOfVarSymbol - 1}]]
# if {$charBefore eq "\\"} {
# DebugPuts "Dollar sign is escaped, skipping"
# return
# }
# }
# Helper::VarHelper $box_x $box_y $txt $varName vars
# }
DebugPuts "Line text: '$lineText'"
# Проверяем, есть ли $ в строке
set lastSymbol [string last $varSymbol $lineText]
if {$lastSymbol ne "-1"} { if {$lastSymbol ne "-1"} {
set word [string trim [$txt get $lineNum.[expr $lastSymbol + 1] $pos]] # Проверяем экранирование
Helper::VarHelper $box_x $box_y $txt $word vars if {$lastSymbol > 0} {
set charBefore [string index $lineText [expr {$lastSymbol - 1}]]
if {$charBefore eq "\\"} {
DebugPuts "Dollar sign is escaped, skipping"
return
}
}
# Берем текст после $
set afterDollar [string range $lineText [expr {$lastSymbol + 1}] end]
DebugPuts "Text after $varSymbol: '$afterDollar'"
# Если после $ ничего нет (только что ввели $) - показываем все переменные
if {$afterDollar eq ""} {
DebugPuts "Just typed $varSymbol, showing all variables"
Helper::VarHelper $box_x $box_y $txt "" vars
return
}
# Проверяем, что введено после $
if {[regexp {^([a-zA-Z_:][a-zA-Z0-9_:]*)?$} $afterDollar -> varName]} {
# Вариант 1: regexp с концом строки - курсор сразу после (возможного) имени
DebugPuts "Cursor after variable name (or $varSymbol only): '$varName'"
Helper::VarHelper $box_x $box_y $txt $varName vars
} elseif {[regexp {^([a-zA-Z_:][a-zA-Z0-9_:]*)} $afterDollar -> varName]} {
# Вариант 2: есть имя переменной, но курсор не обязательно сразу после
DebugPuts "Found variable name: '$varName'"
# Проверяем позицию курсора
set varEndPos [expr {[string length $varName] + 1}] ; # +1 для $
if {$varEndPos == [string length $lineText]} {
# Курсор сразу после имени
Helper::VarHelper $box_x $box_y $txt $varName vars
} else {
DebugPuts "Cursor not immediately after variable name, skipping"
}
} else {
# После $ что-то недопустимое (например, цифра, скобка и т.д.)
DebugPuts "Invalid characters after $varSymbol"
}
} }
} else { } else {
set ind [$txt search -backwards -regexp {\W} $pos {insert linestart}] set ind [$txt search -backwards -regexp {\W} $pos {insert linestart}]
@@ -523,6 +588,7 @@ namespace eval Editor {
# set ind [$txt search -backwards -regexp {^} $pos {insert linestart}] # set ind [$txt search -backwards -regexp {^} $pos {insert linestart}]
set word [$txt get {insert linestart} $pos] set word [$txt get {insert linestart} $pos]
} }
DebugPuts "> Extracted word: '$word'"
if {$word ne ""} { if {$word ne ""} {
Helper::VarHelper $box_x $box_y $txt $word {} Helper::VarHelper $box_x $box_y $txt $word {}
} }
@@ -615,7 +681,7 @@ namespace eval Editor {
bind $txt <Control-Cyrillic_em> "Editor::SelectionPaste $txt" bind $txt <Control-Cyrillic_em> "Editor::SelectionPaste $txt"
bind $txt <Control-l> "SearchVariable $txt; break" bind $txt <Control-l> "SearchVariable $txt; break"
bind $txt <Control-Cyrillic_de> "SearchVariable $txt; break" bind $txt <Control-Cyrillic_de> "SearchVariable $txt; break"
bind $txt <Control-i> "ImageBase64Encode $txt" bind $txt <Control-i> "ImageBase64Encode"
bind $txt <Control-Cyrillic_sha> "ImageBase64Encode $txt" bind $txt <Control-Cyrillic_sha> "ImageBase64Encode $txt"
bind $txt <Control-bracketleft> "Editor::InsertTabular $txt" bind $txt <Control-bracketleft> "Editor::InsertTabular $txt"
bind $txt <Control-bracketright> "Editor::DeleteTabular $txt" bind $txt <Control-bracketright> "Editor::DeleteTabular $txt"
@@ -628,7 +694,7 @@ namespace eval Editor {
bind $txt <<Modified>> "SetModifiedFlag $w $nb auto" bind $txt <<Modified>> "SetModifiedFlag $w $nb auto"
bind $txt <Control-u> "Editor::SearchBrackets %W" bind $txt <Control-u> "Editor::SearchBrackets %W"
bind $txt <Control-Cyrillic_ghe> "Editor::SearchBrackets %W" bind $txt <Control-Cyrillic_ghe> "Editor::SearchBrackets %W"
bind $txt <Control-J> "catch {Editor::GoToFunction $txt}" bind $txt <Control-J> "catch {Editor::GoToFunction $txt}; break"
bind $txt <Control-j> "catch {Editor::GoToFunction $txt}; break" bind $txt <Control-j> "catch {Editor::GoToFunction $txt}; break"
bind $txt <Control-y> {Redo; break} bind $txt <Control-y> {Redo; break}
bind $txt <Control-Cyrillic_o> "catch {Editor::GoToFunction $txt}; break" bind $txt <Control-Cyrillic_o> "catch {Editor::GoToFunction $txt}; break"
@@ -636,6 +702,7 @@ namespace eval Editor {
bind $txt <Alt-odiaeresis> "$txt delete {insert wordstart} {insert wordend}" bind $txt <Alt-odiaeresis> "$txt delete {insert wordstart} {insert wordend}"
bind $txt <Alt-Cyrillic_tse> "$txt delete {insert wordstart} {insert wordend}" bind $txt <Alt-Cyrillic_tse> "$txt delete {insert wordstart} {insert wordend}"
bind $txt <Alt-r> "$txt delete {insert linestart} {insert lineend + 1char}" bind $txt <Alt-r> "$txt delete {insert linestart} {insert lineend + 1char}"
bind $txt <Alt-Cyrillic_ka> "$txt delete {insert linestart} {insert lineend + 1char}"
bind $txt <Alt-ecircumflex> "$txt delete {insert linestart} {insert lineend + 1char}" bind $txt <Alt-ecircumflex> "$txt delete {insert linestart} {insert lineend + 1char}"
bind $txt <Alt-Cyrillic_er> "$txt delete {insert linestart} {insert lineend + 1char}" bind $txt <Alt-Cyrillic_er> "$txt delete {insert linestart} {insert lineend + 1char}"
bind $txt <Alt-b> "$txt delete {insert linestart} insert" bind $txt <Alt-b> "$txt delete {insert linestart} insert"
@@ -679,6 +746,8 @@ namespace eval Editor {
} }
bind $txt <Control-r> "Editor::SplitEditorForExecute $w $fileType $nb " bind $txt <Control-r> "Editor::SplitEditorForExecute $w $fileType $nb "
bind $txt <Control-Cyrillic_ka> "Editor::SplitEditorForExecute $w $fileType $nb " bind $txt <Control-Cyrillic_ka> "Editor::SplitEditorForExecute $w $fileType $nb "
# bind $txt <Shift-Control-s> FileOper::Close
# bind $txt <Shift-Control-Cyrillic_es> "FileOper::Close saveas"
# bind $txt.t <KeyRelease> "Editor::ReleaseKey %K $txt.t $fileType" # bind $txt.t <KeyRelease> "Editor::ReleaseKey %K $txt.t $fileType"
# bind $txt.t <KeyPress> "Editor::PressKey %K $txt.t" # bind $txt.t <KeyPress> "Editor::PressKey %K $txt.t"
@@ -808,9 +877,15 @@ namespace eval Editor {
for {set lineNumber 0} {$lineNumber <= [$txt count -lines 0.0 end]} {incr lineNumber} { for {set lineNumber 0} {$lineNumber <= [$txt count -lines 0.0 end]} {incr lineNumber} {
set line [$txt get $lineNumber.0 $lineNumber.end] set line [$txt get $lineNumber.0 $lineNumber.end]
# Выбираем процедуры (функции, классы и т.д.) # Выбираем процедуры (функции, классы и т.д.)
# DebugPuts "Editor::RedaStructure: file type $fileType"
if {[dict exists $lexers $fileType procRegexpCommand] != 0 } { if {[dict exists $lexers $fileType procRegexpCommand] != 0 } {
# regexp -nocase -all -line -- {^\s*(?:(\w+)\s+)+(\w+)\s*\((.*?)\)\s*(?:;|\{)} $line match returns procName params
# regexp -nocase -all -line -lineanchor -linestop -- {^\s*(?:(\w+)\s+)+(\w+)\s*\((.*?)(,|\))} $line match v1 v2 v3 v4
if {[eval [dict get $lexers $fileType procRegexpCommand]]} { if {[eval [dict get $lexers $fileType procRegexpCommand]]} {
DebugPuts "Editor::RedaStructure: regexp = [dict get $lexers $fileType procRegexpCommand]"
set procName_ [string trim $procName] set procName_ [string trim $procName]
DebugPuts "Editor::RedaStructure: find the proc $procName_"
if {$treeItemName ne ""} { if {$treeItemName ne ""} {
Tree::InsertItem $tree $treeItemName $procName_ "procedure" "$procName_ ($params)" Tree::InsertItem $tree $treeItemName $procName_ "procedure" "$procName_ ($params)"
} }

View File

@@ -364,7 +364,7 @@ namespace eval FileOper {
set nbEditorWindow "[lindex $str 0].[lindex $str 1].[lindex $str 2]" set nbEditorWindow "[lindex $str 0].[lindex $str 1].[lindex $str 2]"
# puts "FileOper::Save: current window $nbEditorWindow" # puts "FileOper::Save: current window $nbEditorWindow"
} }
# puts "FileOper::Save: $nbEditorWindow"
set nbEditorItem [$nbEditorWindow select] set nbEditorItem [$nbEditorWindow select]
DebugPuts "Saved editor text: $nbEditorItem" DebugPuts "Saved editor text: $nbEditorItem"
if [string match "*untitled*" $nbEditorItem] { if [string match "*untitled*" $nbEditorItem] {
@@ -382,7 +382,14 @@ namespace eval FileOper {
set treeItem "file::[string range $nbEditorItem [expr [string last "." $nbEditorItem] +1] end ]" set treeItem "file::[string range $nbEditorItem [expr [string last "." $nbEditorItem] +1] end ]"
set filePath [Tree::GetItemID $tree $treeItem] set filePath [Tree::GetItemID $tree $treeItem]
} }
if {![winfo exists $nbEditorItem.frmText.t]} {
DebugPuts "winfo exists $nbEditorWindow.frmText.t equal [winfo exists $nbEditorWindow.frmText.t]"
return
}
set editedText [$nbEditorItem.frmText.t get 0.0 end] set editedText [$nbEditorItem.frmText.t get 0.0 end]
if {$type eq "saveas"} {set filePath [FileOper::SaveDialog]}
if {$filePath eq "cancel"} {return}
DebugPuts "FileOper::Save $filePath"
set f [open $filePath "w+"] set f [open $filePath "w+"]
puts -nonewline $f $editedText puts -nonewline $f $editedText
# puts "$f was saved" # puts "$f was saved"
@@ -397,7 +404,7 @@ namespace eval FileOper {
Tools::GetMenu .popup.tools Tools::GetMenu .popup.tools
Tools::GetMenu .frmMenu.mnuTools.m Tools::GetMenu .frmMenu.mnuTools.m
} }
if [string match "*untitled*" $nbEditorItem] { if {[string match "*untitled*" $nbEditorItem] || $type eq "saveas"} {
FileOper::Close FileOper::Close
if {$type ne "close"} { if {$type ne "close"} {
FileOper::Edit $filePath FileOper::Edit $filePath
@@ -627,5 +634,29 @@ namespace eval FileOper {
# set selEnd [lindex [$txt tag ranges sel] 1] # set selEnd [lindex [$txt tag ranges sel] 1]
# puts [$txt get [$txt tag ranges sel]] # puts [$txt get [$txt tag ranges sel]]
# } # }
proc SaveDialog {} {
global env project activeProject
if [info exists activeProject] {
set dir $activeProject
} else {
set dir $env(HOME)
}
set fileName [tk_getSaveFile -initialdir $dir -filetypes $::types -parent .]
if {$fileName eq ""} {return "cancel"}
set fullPath [file join $dir $fileName]
set file [string range $fullPath [expr [string last "/" $fullPath]+1] end]
DebugPuts "FileOper::SaveDialog $fileName $fullPath"
regsub -all "." $file "_" node
set dir [file dirname $fullPath]
set file [file tail $fullPath]
set name [file rootname $file]
set ext [string range [file extension $file] 1 end]
if {$fullPath != ""} {
# puts $fullPath
return $fullPath
} else {
return
}
}
} }

View File

@@ -237,7 +237,7 @@ ttk::style layout TNotebook.Tab {
} }
bind TNotebook <Button-1> "catch {NB::PressTab %W %x %y}\;[bind TNotebook <Button-1>];break" bind TNotebook <Button-1> "catch {NB::PressTab %W %x %y}\;[bind TNotebook <Button-1>];break"
# bind <<NotebookTabChanged>> "NB::PressTab %W %x %y" # bind <<NotebookTabChanged>> "NB::PressTab %W %x %y"
bind TNotebook <ButtonRelease-1> "NB::PressTab %W %x %y" # bind TNotebook <ButtonRelease-1> "NB::PressTab %W %x %y"
# bind TNotebook <Control-w> FileOper::Close # bind TNotebook <Control-w> FileOper::Close
# bind . <Control-Tab> "NB::NextTab $nbEditor" # bind . <Control-Tab> "NB::NextTab $nbEditor"
bind . <Control-Next> "NB::NextTab $nbEditor 1" bind . <Control-Next> "NB::NextTab $nbEditor 1"

View File

@@ -4,7 +4,7 @@ namespace eval Helper {
variable ::listActive 0 variable ::listActive 0
# Переменная для отслеживания предыдущего ввода (чтобы не обновлять список без необходимости) # Переменная для отслеживания предыдущего ввода (чтобы не обновлять список без необходимости)
variable ::previousInput "" variable ::previousInput ""
proc VarHelperKey { widget K A } { proc VarHelperKey { widget K A } {
set win .varhelper set win .varhelper
DebugPuts "Helper::VarHelperKey: K=$K, A='$A'" DebugPuts "Helper::VarHelperKey: K=$K, A='$A'"
@@ -16,7 +16,7 @@ namespace eval Helper {
set ::listActive 0 set ::listActive 0
return return
} }
switch -- $K { switch -- $K {
<Up> { <Up> {
DebugPuts "Processing Up arrow" DebugPuts "Processing Up arrow"
@@ -275,7 +275,7 @@ namespace eval Helper {
} }
return return
} }
# Восстанавливаем оригинальные привязки # Восстанавливаем оригинальные привязки
foreach binding $::originalBindings { foreach binding $::originalBindings {
set event [lindex $binding 0] set event [lindex $binding 0]
@@ -288,49 +288,52 @@ namespace eval Helper {
bind $txt $event $command bind $txt $event $command
} }
} }
# Очищаем сохраненные привязки # Очищаем сохраненные привязки
set ::originalBindings {} set ::originalBindings {}
} }
proc SelectFromList {txt} { proc SelectFromList {txt} {
global returnProcessed editors lexers
set win .varhelper set win .varhelper
# puts "[dict get $editors $txt fileType]"
DebugPuts "SelectFromList called" # puts "[dict get $lexers [dict get $editors $txt fileType] variableSymbol]"
if {![winfo exists $win]} { if {![winfo exists $win]} {
DebugPuts "Window doesn't exist"
return return
} }
# Получаем выбранный элемент
set selected [$win.lBox curselection] set selected [$win.lBox curselection]
DebugPuts "Selected index: $selected"
if {$selected ne ""} { if {$selected ne ""} {
set text [$win.lBox get $selected] set text [string trim [$win.lBox get $selected]]
DebugPuts "Selected text: $text" # DebugPuts "[dict exists $lexers [dict get $editors $txt fileType] variableSymbol]"
if [dict exists $lexers [dict get $editors $txt fileType] variableSymbol] {
# Вставляем выбранный текст в текстовое поле set varSymbol [dict get $lexers [dict get $editors $txt fileType] variableSymbol]
$txt delete "insert - 1 chars wordstart" "insert wordend - 1 chars" } else {
$txt insert "insert" $text set varSymbol ""
}
# Закрываем окно списка # Опеределяем что символ перед позицией вставки равен символу переменной из настроек lexers
# если равен то вставляем выбранное из списка сразу за ним
# если нет то удаляем введенный текст до этого символа и вставляем выбранное из списка
if {[$txt get "insert - 1 char" "insert"] eq $varSymbol} {
$txt insert "insert" $text
} else {
$txt delete "insert - 1 chars wordstart" "insert wordend - 1 chars"
$txt insert "insert" $text
}
# Закрываем окно
destroy $win destroy $win
set ::listActive 0 set ::listActive 0
Helper::VarHelperBindingsRestore $txt Helper::VarHelperBindingsRestore $txt
set ::previousInput "" set ::previousInput ""
# Устанавливаем флаг, что Return уже обработан
set returnProcessed 1
# after 10 {catch {unset returnProcessed}}
# Возвращаем фокус
focus $txt.t focus $txt.t
} }
} }
proc DebugPuts {msg} { proc DebugPuts {msg} {
puts "DEBUG: $msg" puts "DEBUG: $msg"
} }
} }

View File

@@ -210,5 +210,24 @@ namespace eval Highlight {} {
ctext::addHighlightClass $txt compile_errors #ff5050 {error Error ERROR invalid undefined cannot} ctext::addHighlightClass $txt compile_errors #ff5050 {error Error ERROR invalid undefined cannot}
ctext::addHighlightClassForRegexp $txt url lightblue {\w+://\w.+\w+} ctext::addHighlightClassForRegexp $txt url lightblue {\w+://\w.+\w+}
} }
proc C {txt} {
global lexers
ctext::addHighlightClassForRegexp $txt flags orange {-+[a-zA-Z\-_]+}
ctext::addHighlightClassForRegexp $txt arrows orange {(->)|(-<)}
ctext::addHighlightClass $txt stackControl #19a2a6 [dict get $lexers C commands]
ctext::addHighlightClass $txt types #7187d5 {string int int16 int32 int64 float bool byte size_t void char uint32_t uint32}
ctext::addHighlightClassWithOnlyCharStart $txt vars #4471ca "\&"
ctext::addHighlightClassWithOnlyCharStart $txt vars #4471ca "\*"
# ctext::addHighlightClassForRegexp $txt vars_extended #4471ca {\$\{[a-zA-Z0-9\_\-:\./\$\{\}]+\}}
ctext::addHighlightClass $txt variable_funcs gold {var type struct}
ctext::addHighlightClassForSpecialChars $txt brackets green {[]{}()}
ctext::addHighlightClassForRegexp $txt paths lightblue {\.[a-zA-Z0-9\_\-]+}
ctext::addHighlightClassForRegexp $txt comments #666666 {(//|/\*)[^\n\r]*}
ctext::addHighlightClassForSpecialChars $txt qoute #b84a0c {"'`}
ctext::addHighlightClass $txt bool #3e803b {nil false true NULL TRUE FALSE}
ctext::addHighlightClassForRegexp $txt qoute #b84a0c {("|'|`).*?("|'|`)}
ctext::addHighlightClassForRegexp $txt macros #f88ffb {#\w+}
ctext::addHighlightClassForRegexp $txt include #68ceff {<[\w./_-]+?>}
}
proc H {txt} {Highlight::C $txt}
} }

View File

@@ -1947,3 +1947,24 @@ image create photo settings_24x24 -data {
3W5MPksIPgdckHTF1XAMeCrpRXAexPT6yYSddEj6eKSJJmk3IcFGqWby51AbSvpeqr+KPjcKC7GT 3W5MPksIPgdckHTF1XAMeCrpRXAexPT6yYSddEj6eKSJJmk3IcFGqWby51AbSvpeqr+KPjcKC7GT
hfgXbteIc85F7RUAAAAASUVORK5CYII= hfgXbteIc85F7RUAAAAASUVORK5CYII=
} }
image create photo c_16x12 -data {
iVBORw0KGgoAAAANSUhEUgAAAAsAAAANCAYAAAB/9ZQ7AAAAAXNSR0IB2cksfwAAAARnQU1BAACx
jwv8YQUAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dE
APgAjwD7QQHXygAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB+oCBg8YOxzsqLgAAABWSURB
VCjPY2AgATDCGFeLi/+jS2r39jJiKIYp1O7tZUDSjKGBCYdtyCbCbWTB5T6oiShOYyHWT7icgRPg
VHy1uPg/eggRY/J/YsMZRR0jLlNweZI2AAAzbhnP2WkKCAAAAABJRU5ErkJggg==
}
image create photo h_16x12 -data {
iVBORw0KGgoAAAANSUhEUgAAAAsAAAANCAYAAAB/9ZQ7AAAAAXNSR0IB2cksfwAAAARnQU1BAACx
jwv8YQUAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAAZiS0dE
AAAAAAAA+UO7fwAAAAlwSFlzAAALEwAACxMBAJqcGAAAAAd0SU1FB+oCBg8iNd79W8YAAABJSURB
VCjPY2AgB1wtLv5/tbj4Pz41TKQYSJJiRmRnYFOg3dvLSLTJyIawYDEJWSGM+Z+BgYGRCY/zGOkX
GkwMFID/UExIjDAAAEu2FECKwea9AAAAAElFTkSuQmCC
}
image create photo cpp_16x12 -data {
iVBORw0KGgoAAAANSUhEUgAAAAsAAAANCAMAAABIK2QJAAAAAXNSR0IB2cksfwAAAARnQU1BAACx
jwv8YQUAAAAgY0hSTQAAeiYAAICEAAD6AAAAgOgAAHUwAADqYAAAOpgAABdwnLpRPAAAAA9QTFRF
AAAAzAAAAAAA////////6rs+vwAAAAF0Uk5TAEDm2GYAAAABYktHRACIBR1IAAAACXBIWXMAAAsT
AAALEwEAmpwYAAAAB3RJTUUH6gIGDxU21/OqSAAAADVJREFUCNd9jUEOACAIw7D7/58VmNF4sAco
CbCIm5FsBTwsd+kmgVQu87p3OLfg/9AJJPFhAjDkAJmwKBolAAAAAElFTkSuQmCC
}

View File

@@ -104,5 +104,29 @@ dict set lexers LUA procFindString {function\s*?PROCNAME}
dict set lexers LUA procRegexpCommand {regexp -nocase -all -- {^(local|)\s*?(function)\s([a-zA-Z0-9\-_:]+?)\s+\((.+?)\)} $line match v1 keyWord procName params} dict set lexers LUA procRegexpCommand {regexp -nocase -all -- {^(local|)\s*?(function)\s([a-zA-Z0-9\-_:]+?)\s+\((.+?)\)} $line match v1 keyWord procName params}
dict set lexers LUA varRegexpCommand {regexp -nocase -all -- {^(\s*?)([a-zA-Z0-9\-_\.]+)\s+=\s+(.+?)(\s*$|--)} $line match indent varName varValue lineEnd} dict set lexers LUA varRegexpCommand {regexp -nocase -all -- {^(\s*?)([a-zA-Z0-9\-_\.]+)\s+=\s+(.+?)(\s*$|--)} $line match indent varName varValue lineEnd}
#--------------------------------------------------
# C
dict set lexers C commentSymbol {//}
dict set lexers C commentMultilineSymbolBegin {/*}
dict set lexers C commentMultilineSymbolEnd {*/}
dict set lexers C procFindString {(\w+)\s+(PROCNAME)\s*\((.*?)(,|\))(\W|$)}
dict set lexers C procRegexpCommand {regexp -nocase -all -line -- {^(?:(\w+)\s+)+(\*\w+|\w+)\s*\((.*?)(,|\))} $line match returns procName params v4}
# dict set lexers C procRegexpCommand {regexp -nocase -all -- {\s*?func\s*?(\(\w+\s*?\**?\w+\)|)\s*?(\w+)\((.*?)\)\s+?([a-zA-Z0-9\{\}\[\]\(\)-_.]*?|)\s*?\{} $line match linkName procName params returns}
# dict set lexers C varRegexpCommand {regexp -nocase -all -line -- {^\s*?var\s+([a-zA-Z0-9\-_$]+)\s+(.+?)(\s*$)} $line match varName varType lineEnd}
dict set lexers C varRegexpCommand {regexp -nocase -all -line -- {^\s*(\w+\s+)+(?:[*\s]+)?(\w+)\s*[=;,\[]} $line match varType varName}
dict set lexers C commands {auto break case const continue default do else enum extern for goto if inline int long register restrict return signed sizeof static struct switch typedef typeof typeof_unqual union unsigned void volatile while}
#--------------------------------------------------
# H
dict set lexers H commentSymbol {//}
dict set lexers H commentMultilineSymbolBegin {/*}
dict set lexers H commentMultilineSymbolEnd {*/}
# dict set lexers C procFindString {^\s*(?:(\w+)\s+)+(PROCNAME)\s*\((.*?)(,|\))}
dict set lexers H procFindString {^\s*(?:(\w+)\s+)+(PROCNAME)\s*\((.*?)(,|\))}
dict set lexers H procRegexpCommand {regexp -nocase -all -line -- {^(?:(\w+)\s+)+(\*\w+|\w+)\s*\((.*?)(,|\))} $line match returns procName params v4}
# dict set lexers C procRegexpCommand {regexp -nocase -all -- {\s*?func\s*?(\(\w+\s*?\**?\w+\)|)\s*?(\w+)\((.*?)\)\s+?([a-zA-Z0-9\{\}\[\]\(\)-_.]*?|)\s*?\{} $line match linkName procName params returns}
dict set lexers C varRegexpCommand {regexp -nocase -all -line -- {^\s*(\w+\s+)+(?:[*\s]+)?(\w+)\s*[=;,\[]} $line match varType varName}
dict set lexers H commands {auto break case const continue default do else enum extern for goto if inline int long register restrict return signed sizeof static struct switch typedef typeof typeof_unqual union unsigned void volatile while}
# ------------------------------------------------- # -------------------------------------------------
dict set lexers ALL varDirectory {variables vars group_vars host_vars defaults} dict set lexers ALL varDirectory {variables vars group_vars host_vars defaults}

View File

@@ -20,6 +20,7 @@ proc GetFileMenu {m} {
} }
$m add command -label [::msgcat::mc "Save file"] -command {FileOper::Save}\ $m add command -label [::msgcat::mc "Save file"] -command {FileOper::Save}\
-accelerator "Ctrl+S" -accelerator "Ctrl+S"
$m add command -label [::msgcat::mc "Save as"] -command {FileOper::Save saveas}
$m add command -label [::msgcat::mc "Close file"] -command {FileOper::Close}\ $m add command -label [::msgcat::mc "Close file"] -command {FileOper::Close}\
-accelerator "Ctrl+w" -accelerator "Ctrl+w"
$m add command -label [::msgcat::mc "Close all"] -command {FileOper::CloseAll} $m add command -label [::msgcat::mc "Close all"] -command {FileOper::CloseAll}

View File

@@ -13,6 +13,7 @@ namespace eval NB {
proc InsertItem {nb item type} { proc InsertItem {nb item type} {
switch $type { switch $type {
file { file {
set titleFileName [file tail $item]
set item [string tolower $item] set item [string tolower $item]
regsub -all {\.|/|\\|\s|:} $item "_" itemName regsub -all {\.|/|\\|\s|:} $item "_" itemName
# puts "$item -> $itemName" # puts "$item -> $itemName"
@@ -21,7 +22,7 @@ namespace eval NB {
} else { } else {
set fm [ttk::frame $nb.$itemName] set fm [ttk::frame $nb.$itemName]
pack $fm -side top -expand true -fill both pack $fm -side top -expand true -fill both
$nb add $fm -text [file tail $item];# -image close_12x12 -compound right $nb add $fm -text $titleFileName;# -image close_12x12 -compound right
$nb select $fm $nb select $fm
} }
} }
@@ -32,7 +33,7 @@ namespace eval NB {
set fm [ttk::frame $nb.$item] set fm [ttk::frame $nb.$item]
pack $fm -side top -expand true -fill both pack $fm -side top -expand true -fill both
$nb add $fm -text Git;# -image close_12x12 -compound right $nb add $fm -text Git;# -image close_12x12 -compound right
$nb select $fm $nb select $fm
} }
} }
# puts "NB item - $fm" # puts "NB item - $fm"

View File

@@ -132,8 +132,10 @@ namespace eval Tree {
$nbEditor select $nbItem $nbEditor select $nbItem
set txt $nbItem.frmText.t set txt $nbItem.frmText.t
set findString [dict get $lexers [dict get $editors $txt fileType] procFindString] set findString [dict get $lexers [dict get $editors $txt fileType] procFindString]
DebugPuts "Tree::PressItem: $findString\n values: $values"
regsub -all {\*} $values {\\*} values
regsub -all {PROCNAME} $findString $values str regsub -all {PROCNAME} $findString $values str
DebugPuts "Tree::PressItem: $str"
Editor::FindFunction $txt "$str" Editor::FindFunction $txt "$str"
} }
} }

View File

@@ -9,8 +9,8 @@ exec wish8.6 "$0" -- "$@"
# Home page: https://nuk-svk.ru # Home page: https://nuk-svk.ru
###################################################### ######################################################
# Version: 2.0.0 # Version: 2.0.0
# Release: beta2 # Release: beta4
# Build: 28012026124210 # Build: 13022026112625
###################################################### ######################################################
# определим текущую версию, релиз и т.д. # определим текущую версию, релиз и т.д.

View File

@@ -18,6 +18,8 @@ cp projman.tcl projman
sed -i "s+^set\ dir(lib)+set\ dir(lib)\ /usr/share/projman/lib ;#+g" projman sed -i "s+^set\ dir(lib)+set\ dir(lib)\ /usr/share/projman/lib ;#+g" projman
sed -i "s+\[pwd\]+/usr/share/projman+g" projman sed -i "s+\[pwd\]+/usr/share/projman+g" projman
./changelog-gen.tcl --project-name projman --project-version ${VERSION} --project-release ${RELEASE} --out-file redhat/projman.spec --rpm --last
CUR_DIR=$(pwd) CUR_DIR=$(pwd)
cd ../ cd ../
@@ -31,12 +33,12 @@ cp redhat/projman.spec ${RPM_BUILD_DIR}/SPECS/projman.spec
sed -i "s/.*Version:.*/Version:\t${VERSION}/" ${RPM_BUILD_DIR}/SPECS/projman.spec sed -i "s/.*Version:.*/Version:\t${VERSION}/" ${RPM_BUILD_DIR}/SPECS/projman.spec
sed -i "s/.*Release:.*/Release:\t${RELEASE}/" ${RPM_BUILD_DIR}/SPECS/projman.spec sed -i "s/.*Release:.*/Release:\t${RELEASE}/" ${RPM_BUILD_DIR}/SPECS/projman.spec
rpmbuild -ba "${RPM_BUILD_DIR}/SPECS/projman.spec" fakeroot rpmbuild -ba "${RPM_BUILD_DIR}/SPECS/projman.spec"
# cp ${RPM_BUILD_DIR}/RPMS/noarch/projman-${VERSION}-${RELEASE}.noarch.rpm /files/ cp ${RPM_BUILD_DIR}/RPMS/noarch/projman-${VERSION}-${RELEASE}.noarch.rpm ../
# cp ${RPM_BUILD_DIR}/SRPMS/projman-${VERSION}-${RELEASE}.src.rpm /files/ cp ${RPM_BUILD_DIR}/SRPMS/projman-${VERSION}-${RELEASE}.src.rpm ../
rm -v projman rm -v projman
rm -r -v ${RPM_BUILD_DIR}/SPECS/projman.spec rm -r -v ${RPM_BUILD_DIR}/SPECS/projman.spec
rm -r -v ${RPM_BUILD_DIR}/SOURCES/projman-${VERSION}-${RELEASE}.tar.gz rm -r -v ${RPM_BUILD_DIR}/SOURCES/projman-${VERSION}-${RELEASE}.tar.gz
rm -r -v ${RPM_BUILD_DIR}/BUILD/projman #rm -r -v ${RPM_BUILD_DIR}/BUILD/projman

View File

@@ -6,7 +6,7 @@ License: GPL
Group: Development/Tcl Group: Development/Tcl
Url: https://nuk-svk.ru Url: https://nuk-svk.ru
BuildArch: noarch BuildArch: noarch
Source: %name-%version-%release.tar.gz Source: %{name}-%{version}-%{release}.tar.gz
Requires: tcl, tk, tklib, tcllib Requires: tcl, tk, tklib, tcllib
%description %description
@@ -16,40 +16,226 @@ This a editor for programming in TCL/Tk (and other language). It includes a file
Интегрированная среда для программирования на Tcl/Tk. Включает в себя - менеджер проектов, полнофункциональный редактор, систему навигации по файлам и структуре файлов и многое другое. Интегрированная среда для программирования на Tcl/Tk. Включает в себя - менеджер проектов, полнофункциональный редактор, систему навигации по файлам и структуре файлов и многое другое.
%prep %prep
%setup -n %name %setup -n %{name}
%build %build
# Пустая секция, если сборка не требуется
%install %install
mkdir -p $RPM_BUILD_ROOT%_bindir # Создаем директории
mkdir -p $RPM_BUILD_ROOT%_datadir/%name/lib/msgs mkdir -p %{buildroot}%{_bindir}
mkdir -p $RPM_BUILD_ROOT%_datadir/%name/theme mkdir -p %{buildroot}%{_datadir}/%{name}/lib/msgs
mkdir -p $RPM_BUILD_ROOT%{_datarootdir}/applications mkdir -p %{buildroot}%{_datadir}/%{name}/theme
mkdir -p %{buildroot}%{_datadir}/applications
mkdir -p %{buildroot}%{_iconsdir}/hicolor/48x48/apps
install -p -m755 projman $RPM_BUILD_ROOT%_bindir/%name # Копируем исполняемые файлы
install -p -m755 tkregexp.tcl $RPM_BUILD_ROOT%_bindir/tkregexp install -p -m755 projman %{buildroot}%{_bindir}/%{name}
install -p -m755 tkregexp.tcl %{buildroot}%{_bindir}/tkregexp
install -p -m755 changelog-gen.tcl %{buildroot}%{_bindir}/changeloggen
# install -p -m644 *.tcl $RPM_BUILD_ROOT%_datadir/%name/ # Копируем библиотеки и ресурсы
install -p -m644 lib/*.tcl $RPM_BUILD_ROOT%_datadir/%name/lib/ install -p -m644 lib/*.tcl %{buildroot}%{_datadir}/%{name}/lib/
install -p -m644 lib/msgs/*.* $RPM_BUILD_ROOT%_datadir/%name/lib/msgs/ install -p -m644 lib/msgs/*.* %{buildroot}%{_datadir}/%{name}/lib/msgs/
install -p -m644 theme/*.tcl $RPM_BUILD_ROOT%_datadir/%name/theme install -p -m644 theme/*.tcl %{buildroot}%{_datadir}/%{name}/theme
install -p -m644 projman.desktop $RPM_BUILD_ROOT%{_datarootdir}/applications
# Копируем .desktop файл
install -p -m644 projman.desktop %{buildroot}%{_datadir}/applications/
# Копируем иконку в правильное место
install -p -m644 projman.png %{buildroot}%{_iconsdir}/hicolor/48x48/apps/projman.png
# Обновляем кэш иконок (опционально для Debian)
%post %post
%update_menus if [ $1 -eq 1 ] ; then
if [ -x /usr/bin/gtk-update-icon-cache ]; then
/usr/bin/gtk-update-icon-cache -q %{_iconsdir}/hicolor || :
fi
fi
%postun %postun
%clean_menus if [ $1 -eq 0 ] ; then
if [ -x /usr/bin/gtk-update-icon-cache ]; then
/usr/bin/gtk-update-icon-cache -q %{_iconsdir}/hicolor || :
fi
fi
%files %files
%doc INSTALL CHANGELOG TODO LICENSE README.md %doc CHANGELOG TODO LICENSE README.md
%_bindir/%name %{_bindir}/%{name}
%_bindir/tkregexp %{_bindir}/tkregexp
%_datarootdir/applications/%name.desktop %{_bindir}/changeloggen
%_datadir/%name %{_datadir}/applications/projman.desktop
%{_datadir}/%{name}
%{_iconsdir}/hicolor/48x48/apps/projman.png
%changelog %changelog
* Mon Nov 28 2022 Sergey Kalinin <svk@nuk-svk.ru> 2.0.0 * Fri Feb 13 2026 svk <svk@nuk-svk.ru> 2.0.0-beta4
- Initial release - Исправлено регулярное выражение для поиска переменных в коде на С.
- Добавил экранирование '*' в имени функции для поиска.
- Подкрректировал регулярки для работы с С.
- Исправил закрытие вкладки при отпускании кнопки мыши при нажатии на крестик.
- Добавил иконки для 'c' и 'h'. Добавил сочитание Alt-R в русской раскладке
- Добавил поддержку С (подсветка)
- Добавил копирование готовых пакетов
* Fri Feb 6 2026 svk <svk@nuk-svk.ru> 2.0.0-beta3
- Откорректировал сборку рпм
* Fri Feb 6 2026 svk <svk@nuk-svk.ru> 2.0.0-beta3
- Добавил сборку rpm. Исправил changelog-и
* Fri Feb 6 2026 svk <svk@nuk-svk.ru> 2.0.0-beta3
- changelog-gen: сделал вывод изменения в формате rpm.spec
- Исправил смену регистра в заголовках вкладок
- Добавил проверки в диалог FileOper::SaveFile
- Добавил диалог 'Сохранить как'
- Добавил проверку на наличие символа переменной.
- Исправил работу со списком переменных из всплывающего окна. Теперь там можно выбрать из списка стрелками и вставить по Enter.
- Вынес код связанный с обработкой подсказок при вводе переменных и процедур в отдельный модуль. Исправил недоработку при выборе варианта из списка и вставке его в текст. Исправил обработку клавиш Ввер Вниз Ввод Отмена в окне со списком вариантов.
* Tue Jan 27 2026 svk <svk@nuk-svk.ru> 2.0.0-beta2
- Добавлено подключение (bind) сочетания клавишь указанных в настройках инструментов.
- Добавлена динамическая генерация меню 'Инструменты'. Теперь новые внешние инструменты доступны сразу после сохранения файла настроек tools.ini в редакторе.
- 2-я бета
- Исправлена ошибка с некорректным определением виджета в процедуре получения выделенного текста.
- Добавлено редактирование настроек внешних инструментов. И пункт в меню 'Инструменты'->'Настройки'
- Исправление ошибки с запуском внешних программ.
- Добавлено определение путей до внешних программ при подключении к редактору.
- Сделана обработка шаблонов командной строки и запуск внешних инструментов.
- Добавлен tkregexp для установки в /usr/bin
- Добавлена сборка пакетов для openbsd
* Wed Jan 21 2026 svk <svk@nuk-svk.ru> 2.0.0-beta1
- Сделан вывод отладочной информации по запросу. Переделка кода.
- Добавлены процедуры проверки наличия параметров конфигурации
- Добавил фокус ввода на 'терминал' если он открыт во вкладке (при переключении вкладок).
- Исправил вставку кавычек при выделении текста
- Исправил ошибку при отправке сигналов несуществующему процессу.
- Уменьшил всплывающее меню: вынес менюшки Файл и Вид в подменю.
- Изменил команду загрузки пакета в репу
- Исправлено поведение при сочетании клавиш Control-y (повторение последнего действия)
- Исправлен флаг модификации при открытии файла
- Исправил закрытие вкладок редактора и сохранение файла при разделении экрана.
- Добавлены настройки путей к программам для выполнения редактируемых файлов для каждого поддержимаего типа. И использование этих настроек при выполнении файла.
- Добавил вывод информации о версиях tcl и tk
- Добавил вывод номера версии tcl/tl в О Программе
- Исправил сохранение и закрытие нового файла. Теперь при сохранении файл будет переоткрыт под новым именем.
- Добавил проверку пакета Img. И поправил проверку типов изображений
- Переделал сигналы и сочетния
- Добавлен перевод фокуса ввода на прежнее окно после закрытия диалога выполнения.
- Добавлена передача сигналов для закрытия запущенного процесса
- Добавлен диалог настроек
- Добавил псевдо-терминал
- Добавлен диалог при открытии файлов отличных от текстовых
- Поправил тему оформления
- Исправлена работа в windows
- Уменьшил колдичество выводимой отладочной информации
- Добавлено определение пути до git в зависимости от платформы.
- Исправлено создание файла конфигурации
- Исправлено создание файла конфигурации. Добавлены номера версий в вызов tclsh8.6 и wish8.6. Убрана зависимостить на Threads.
- Исправлено чтение структуры проекта при открытии из меню 'Открыть недавнее'
- Bugfix release
- Bug fix with varhelper
- Added the "Open Recent" menu. The "recentlyEditedFolders" option in the configuration file contains a list of recently opened directories. The procedures for working with this list have also been added.
- Косметические изменения.
- Исправлены ошибки при вставке кавычек
- changelog-gen.tcl: Добавлена генерация текстового журнала изменений
- build-deb-projman.sh: добавлена генерация changelog из git log
- changelog-gen.tcl: Вывод в файл вынесен в отдельную процедуру
- changelog-gen.tcl: Добавлено создание резервной копии выходного файла. Исправлен вывод в файл.
- changelog-gen.tcl: Добавлены опции командной строки
- Добавлен запуск changelog-gen при сборке пакета
- Добавлено чстение журнала начиная с определенной даты
- Генерация списка изменений для debian приведена к корректному виду
- Исправлен фокус при создании нового файла. #3
- Исправлена неправильная замена выражение при поиске
- Реализовал базовые функции генератора журнала изменений
- Добавлена иконка для jinja template
- Исправил остатки слияния веток
- Исправлено некорректное определение типа файла при открытии.
- Исправил открытие файлов с разными путями (~/ ./ ../)
- Добавил изображений программы
- Исправлена ошибка при создании нового файла.
- Добавил пиктограммы файлов
- Исправил процедуру Files::CloseAll ('Закрыть всё')
- Добавлена поддержка Lua
- Исправлена процедура (рас)комментирования
- Исправил ошибку при выходе в процедуре (Congig::Write)
- Добавил раскраски в ruby
- Добавлена возможность многострочных комментариев
- В Ruby lexer добавлен поиск переменных коде.
- Немного почистил. Добавлен поиск переменных по питоньим исходникам (lexer)
- Изменения в подсветке для INI
- Добавил подсветку для Desktop и Spec файлов
- Добавил вывод отладочной инфы в процедуру
- Исправил подсветку комментариев в TCL
- Оптимизация процедур
- Добавлена подсветка и навигация по HTML. Исправлена подсветка XML
- Добавил иконку для изображений
- Добавил иконки для perl
- Исправлена подсветка и навигация по коду для Ruby
- Исправлено сохранение сессии в редакторе (открытие папки и файлов при следующем запуске)
- Добавлена новая секция UserSession
- Исправление ошибки при открытии файла
- Добавлена поддержка INI-файлов (подсветка
- Добавлена поддержка perl
- Добавил икогнку для файлов git
- Добавлены иконки для ключей и сертификатов. Изменен поиск иконки (вощзвращает теерь с размером)
- Реализован двухпанельный режим работы (вертиикальное разделение)
- Исправлена ошибка при открытии ansible.cfg
- Добавил деактивацию кнопки 'Создать репу' если не выбран активный проект (не открыто ни одного каталога/папки)
- Добавлены команды git init и git config (зачаток). Изменен диалог клонирования репозитория (добавлена кнопка Создать репозиторий)
- Исправил ошибку git при открытии файла или каталога если репозиторий не инициализирован (нет .git каталога внутри проекта)
- Добавил скриты сборки rpm
- Добавлено обрамление выделенного текста прии нажатии '_' в markdown
- Исправление подсветки
- Добавлена поддержка markdown (подсветка
- Исправлена ошибка с закрытием файлов в редакторе при закрытии папки
- Переделана процедура определения активного проекта. Исправлено определение ветки git. Теперь можно нормально работать в двух и более открытых проектах (каталогах/папках)
- Доделан вид диалога поиска по файлам
- Исправлен поиск имени функции
- Добавлен диалог клонирования репозитория
- Добавил разделитель
- Исправлено переключение вкладок при закрытии
- Исправлено закрытиие вкладки Git по нажатию соотв. кнопки в панели инструментов
- Добавлен пункт 'Закрыть всё'
- Исправлено соответствие открытого файла в редакторе и выделение этого файла в дереве
- Исправлено переключение отображения панели (лево/право) в без перезапуска программы.
- Украшательства интерфейса - Реакция на нажатие кнопки в панели инструментов теперь зависит от контекста
- Добавлено включение отключение отображения Меню
- Добавлено копирование текущей строки в буфер по Atl+Y
- Исправлена ошибка с отображением файловой панели
- Добавлены и исправлены функции отображения меню
- Добавлен параметр statusBarShow - показ строки статуса
- Добавлены переводы
- Добавлена проверка параметров вызова файл или просто строка
- Добавлен вывод сообщений об ошибке в диалоге
- Добавлено обновления списка файлов в дереве
- Добавлена процедура вывода информационного сообщения
- Добавлена команда Git::Reset (git reset _file_) на кнопке в диалоге. Для отмены 'git add'
- Добавлена кнопка Обновление в диалог работы с Git
- Исправление процедуры поиска наименования функции
- Фиксы диалога работы с Git (работа с выделенными файлами в списках)
- Фиксы и тесты работы с git
- Исправление выборанескольких файлов в диалоге Git
- Исправление рег. выражения чтения файлов командой git status
- Исправлено рег. выпражение определения mime типа файла
- Добавил очистку текстовых полей при добавлении файлов в коммит
- Исправрелдение Git::Commit (индексация всех файлов в проекте)
- Исправления глюков
- Украшательства строки статуса
- Добавлен просмотрщик изображений
- Добавил рамку кону ввода номера
- Добавлен диалог перехода по номеру строки Ctrl-G
- Добавлено определение типа файла
- Добавил удаление артефактов сборки пакета
- Новая сборка
- Добавлена подсветка имен файлов в выводе git show
- Небольшие правки в подсказках по переменным
- Исправлена подсветка SHELL переменных а YAML файлах (ansible