Compare commits
21 Commits
c2d128dd42
...
c_support
| Author | SHA1 | Date | |
|---|---|---|---|
| 0f9d6e9214 | |||
| 40ceb04bf8 | |||
| b12381dbce | |||
| 3d0ae84dc2 | |||
| afa368c519 | |||
| 118638e42e | |||
| 723426b1d6 | |||
| c8547ec45b | |||
| e83507eb9b | |||
| 382e62df95 | |||
| 7d0b40d651 | |||
| 2877ebc8a2 | |||
| 04ba6663ee | |||
| 676a0e6185 | |||
| 5dc1da5dbf | |||
| 7511a5445e | |||
| 3860db2c26 | |||
| bded0b22b1 | |||
| 478f1d156f | |||
| e86b600cd9 | |||
| c4923c5871 |
@@ -68,6 +68,9 @@ 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 "Файлы не найдены"
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
projman (2.0.0-beta1) stable; urgency=medium
|
projman (2.0.0-beta1) stable; urgency=medium
|
||||||
|
|
||||||
* Сделан вывод отладочной информации по запросу.
|
* Сделан вывод отладочной информации по запросу.
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ Highlightning and source code navigation:
|
|||||||
* Markdown
|
* Markdown
|
||||||
* YAML (Ansible support)
|
* YAML (Ansible support)
|
||||||
* Lua
|
* Lua
|
||||||
|
* C
|
||||||
|
|
||||||
Highlightning:
|
Highlightning:
|
||||||
|
|
||||||
|
|||||||
@@ -106,9 +106,9 @@ 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\""
|
||||||
@@ -141,36 +141,76 @@ 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
|
||||||
@@ -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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
18
debian/changelog
vendored
18
debian/changelog
vendored
@@ -1,5 +1,23 @@
|
|||||||
|
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
|
projman (2.0.0-beta3) stable; urgency=medium
|
||||||
|
|
||||||
|
* changelog-gen: сделал вывод изменения в формате rpm.spec
|
||||||
|
* Исправил смену регистра в заголовках вкладок
|
||||||
|
* Добавил диалог вменю "Сохранить как"
|
||||||
|
* Добавил проверки в диалог FileOper::SaveFile
|
||||||
* Вынес код связанный с обработкой подсказок при вводе переменных и процедур в отдельный модуль.
|
* Вынес код связанный с обработкой подсказок при вводе переменных и процедур в отдельный модуль.
|
||||||
* Исправил работу со списком переменных из всплывающего окна. Теперь там можно выбрать из списка стрелками и вставить по Enter. Исправил обработку клавиш Вверх Вниз Ввод Отмена в окне со списком вариантов.
|
* Исправил работу со списком переменных из всплывающего окна. Теперь там можно выбрать из списка стрелками и вставить по Enter. Исправил обработку клавиш Вверх Вниз Ввод Отмена в окне со списком вариантов.
|
||||||
|
|
||||||
|
|||||||
@@ -681,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"
|
||||||
@@ -694,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"
|
||||||
@@ -702,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"
|
||||||
@@ -745,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"
|
||||||
@@ -874,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)"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
@@ -628,4 +635,28 @@ namespace eval FileOper {
|
|||||||
# 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
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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"
|
||||||
|
|||||||
@@ -337,4 +337,3 @@ namespace eval Helper {
|
|||||||
puts "DEBUG: $msg"
|
puts "DEBUG: $msg"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
}
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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: beta3
|
# Release: beta4
|
||||||
# Build: 29012026155729
|
# Build: 13022026112625
|
||||||
######################################################
|
######################################################
|
||||||
|
|
||||||
# определим текущую версию, релиз и т.д.
|
# определим текущую версию, релиз и т.д.
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user