diff --git a/.cvsignore b/.cvsignore index 7c1a1c8..67d54e0 100644 --- a/.cvsignore +++ b/.cvsignore @@ -1,3 +1,4 @@ -emacs-20.7.tar.gz -emacs20-xim-20000713.tar.gz -leim-20.7.tar.gz +emacs-20.7.tar.bz2 +emacs-asian.tar.bz2 +gnus-5.8.8.tar.bz2 +leim-20.7.tar.bz2 diff --git a/emacs.desktop b/emacs.desktop index df39ea1..8737a16 100644 --- a/emacs.desktop +++ b/emacs.desktop @@ -1,65 +1,31 @@ [Desktop Entry] Name=Emacs -Name[bg]=Emacs -Name[ca]=Emacs -Name[cs]=Emacs -Name[da]=Emacs -Name[de]=Emacs -Name[el]=Emacs -Name[es]=Emacs -Name[et]=Emacs -Name[eu]=Emacs -Name[fi]=Emacs -Name[fr]=Emacs -Name[ga]=Emacs -Name[gl]=Emacs -Name[it]=Emacs -Name[ja]=Emacs -Name[ko]≠ƽ -Name[nl]=Emacs -Name[no]=Emacs -Name[pl]=Emacs -Name[pt]=Emacs -Name[pt_BR]=Emacs -Name[ru]=Emacs -Name[sv]=Emacs -Name[tr]=Emacs -Name[uk]=Emacs -Name[wa]=Emacs -Name[zh_CN.GB2312]=Emacs -Name[zh_TW.Big5]=Emacs -Comment=Emacs text editor -Comment[bg]=Emacs -Comment[ca]=L'editor de text Emacs -Comment[cs]=Textov editor Emacs -Comment[da]=Emacs tekstbehandleren -Comment[de]=Der Texteditor Emacs -Comment[el]= Emacs -Comment[es]=Editor de textos Emacs -Comment[et]=tekstiredaktor Emacs -Comment[eu]=Emacs testu editorea -Comment[fi]=Emacs-editori -Comment[fr]=Editeur de texte Emacs -Comment[ga]=Eagarthir Teacs Emacs -Comment[gl]=Editor de texto Emacs -Comment[hu]=Emacs szvegszerkeszt -Comment[it]=Editor di testo Emacs -Comment[ja]=Emacsƥȥǥ -Comment[ko]≠ƽ -Comment[nl]=Emacs tekst editor -Comment[no]=Teksteditoren Emacs -Comment[pl]=Edytor tekstu Emacs -Comment[pt]=Editor de texto Emacs -Comment[pt_BR]=Editor de texto Emacs -Comment[ru]= Emacs -Comment[sv]=Emacs texteditor -Comment[tr]=Emacs metin editr -Comment[uk]= -Comment[wa]=L' aspougneu di tekse Emacs -Comment[zh_CN.GB2312]=Emacs ֱ༩ -Comment[zh_TW.Big5]=Emacs rsr -TryExec=emacs -Exec=emacs +Name[eo]=Emakso +Name[et]=Emacs tekstiredaktor +Comment=Emacs +Comment[ca]=Editor Emacs +Comment[cs]=Editor Emacs +Comment[eo]=La redaktilo Emakso +Comment[et]=Võimas tekstiredaktor Emacs +Comment[fi]=Emacs editori +Comment[fr]=Éditeur Emacs +Comment[hu]=Emacs szövegszerkesztő +Comment[is]=Emacs-ritill +Comment[mk]=Софистицираниот Emacs уредувач +Comment[no]=Emacs-tekstredigerer +Comment[pt]=Editor Emacs +Comment[ro]=Editorul Emacs +Comment[ru]=Редактор Emacs +Comment[sk]=Editor Emacs +Comment[sl]=Urejevalnik Emacs +Comment[uk]=Редактор Emacs +BinaryPattern= +Protocols= +MimeType=text/english;text/plain;text/x-makefile;text/x-c++hdr;text/x-c++src;text/x-chdr;text/x-csrc;text/x-java;text/x-moc;text/x-pascal;text/x-tcl;text/x-tex;application/x-shellscript;text/x-c;text/x-c++; +Exec=emacs %f Icon=emacs.png -Terminal=0 +TerminalOptions= +Path= Type=Application +Terminal=0 +MapNotify=false diff --git a/emacs.spec b/emacs.spec index c653d53..001f1e2 100644 --- a/emacs.spec +++ b/emacs.spec @@ -1,11 +1,11 @@ Summary: The libraries needed to run the GNU Emacs text editor. Name: emacs Version: 20.7 -Release: 17tc1 +Release: 34 Copyright: GPL Group: Applications/Editors -Source0: ftp://ftp.gnu.org/gnu/emacs/emacs-%{version}.tar.gz -Source1: ftp://ftp.gnu.org/gnu/emacs/leim-%{version}.tar.gz +Source0: ftp://ftp.gnu.org/gnu/emacs/emacs-%{version}.tar.bz2 +Source1: ftp://ftp.gnu.org/gnu/emacs/leim-%{version}.tar.bz2 Source3: emacs.desktop Source4: emacs.png Source5: dotemacs @@ -13,13 +13,11 @@ Source6: site-start.el Source7: http://www.python.org/emacs/python-mode/python-mode.el # From /usr/X11R6/lib/X11/locale/locale.alias Source8: emacs.locale.alias -Source9: startup.el -Source10: startup.elc -#Source10: lisp-startup-localealias.patch -# By CLE { -Source20: emacs20-xim-20000713.tar.gz -Source21: emacs.sh-cle -# } +Source11: rpm-spec-mode.el +Source12: mwheel.el +Source13: lisp-startup-localealias.patch +Source14: ftp://ftp.gnus.org/pub/gnus/gnus-5.8.8.tar.bz2 +Source15: emacs-asian.tar.bz2 Patch0: emacs-20.7-xaw3d.patch Patch2: emacs-20.3-tmprace.patch Patch3: emacs-20.3-linkscr.patch @@ -31,10 +29,15 @@ Patch8: emacs-20.6-ia64-2.patch Patch9: emacs-20.6-ia64-3.patch Patch10: emacs-20.7-manboption.patch Patch11: emacs-20.7-proto.patch +Patch12: emacs-cpp-Makefile.patch +Patch13: emacs-20.4-ppc-config.patch + +Patch50: emacs-20.7-s390.patch + Buildroot: %{_tmppath}/%{name}-%{version}-root Prereq: /sbin/install-info -Packager: Red Hat, Inc. -Vendor: Red Hat, Inc. +# temporary hack. roll tamago into base emacs package +Requires: tamago %description Emacs is a powerful, customizable, self-documenting, modeless text @@ -77,6 +80,7 @@ character sets are included in this package. Summary: The Emacs text editor without support for the X Window System. Group: Applications/Editors Requires: emacs +Prereq: fileutils %description nox Emacs-nox is the Emacs text editor program without support for @@ -119,17 +123,15 @@ also need to install the emacs package in order to run Emacs. %patch9 -p1 %patch10 -p1 %patch11 -p1 +%patch12 -p1 -cp -f %{SOURCE9} lisp/startup.el -cp -f %{SOURCE10} lisp/startup.elc +%ifarch ppc +%patch13 -p1 -b .ppc +%endif -# By CLE { -tar zxvf %SOURCE20 -patch -s -p1 < emacs20-xim-20000713/emacs20-xim-20000713.diff - -# clean out remnants of patching -find . -name "*.orig" -or -name "*~" -exec rm -f {} \; -# } +%ifarch s390 +%patch50 -p1 -b .s390 +%endif %build @@ -174,13 +176,16 @@ BuildEmacs nox "--with-x=no" # recompile patched .el files %{recompile} lisp/mail/mh-utils.el -# bytecompile python-mode -cp %SOURCE7 . -%{recompile} python-mode.el +# bytecompile python-mode, mwheel and rpm-spec-mode +cp %SOURCE7 %SOURCE11 %SOURCE12 . +%{recompile} python-mode.el mwheel.el rpm-spec-mode.el + + %install rm -rf $RPM_BUILD_ROOT mkdir -p $RPM_BUILD_ROOT/usr +mkdir -p $RPM_BUILD_ROOT/usr/share/emacs/site-lisp/site-start.d mkdir -p $RPM_BUILD_ROOT/%{_infodir} make install -C build-withx \ @@ -193,9 +198,37 @@ make install -C build-withx \ # install the locale file install -m 644 %SOURCE8 $RPM_BUILD_ROOT/usr/share/emacs/locale.alias +#install lisp files for Japanese and other Asian languages +pushd $RPM_BUILD_ROOT +tar --use-compress-program=bzip2 -xf %{SOURCE15} +popd + +# We want a newer gnus +tar --use-compress-program=bzip2 -xf %{SOURCE14} +pushd gnus-5.8.8 +PATH=$RPM_BUILD_ROOT/usr/bin:$PATH ./configure +make + +rm -f $RPM_BUILD_ROOT//usr/share/emacs/%{version}/lisp/gnus/* +install -m 644 lisp/* $RPM_BUILD_ROOT//usr/share/emacs/%{version}/lisp/gnus/ +rm -f $RPM_BUILD_ROOT/%{_infodir}/gnus* +install -m 644 texi/{gnus,gnus-?,gnus-??} $RPM_BUILD_ROOT/%{_infodir} +popd + rm -f $RPM_BUILD_ROOT/%{_infodir}/dir gzip -9nf $RPM_BUILD_ROOT/%{_infodir}/* + +#change the locale.alias for this one and regenerate +# Do it this way, using the macro here seems to confuse RPM +patch lisp/startup.el %SOURCE13 + +rm -fv lisp/startup.elc +%{recompile} lisp/startup.el +rm -f build-nox/src/emacs-%{version}* +make -C build-nox +install -c -m755 build-nox/src/emacs $RPM_BUILD_ROOT/usr/bin/emacs-nox + install -c -m755 build-nox/src/emacs $RPM_BUILD_ROOT/usr/bin/emacs-nox install -m 644 %SOURCE6 $RPM_BUILD_ROOT/usr/share/emacs/site-lisp/site-start.el @@ -213,29 +246,23 @@ install -c -m 0644 %SOURCE4 $RPM_BUILD_ROOT/usr/share/pixmaps/ install -c -m644 build-nox/etc/DOC-* $RPM_BUILD_ROOT/usr/share/emacs/%{version}/etc -# Python mode +# Python mode, mwheel and rpm-spec mode -install -c -m0644 python-mode.el $RPM_BUILD_ROOT/usr/share/emacs/site-lisp/ -install -c -m0644 python-mode.elc $RPM_BUILD_ROOT/usr/share/emacs/site-lisp/ +install -c -m0644 python-mode.el python-mode.elc mwheel.el mwheel.elc rpm-spec-mode.el rpm-spec-mode.elc $RPM_BUILD_ROOT/usr/share/emacs/site-lisp/ # default initialization file mkdir -p $RPM_BUILD_ROOT/etc/skel install -c -m0644 %SOURCE5 $RPM_BUILD_ROOT/etc/skel/.emacs -# By CLE { -rm -f $RPM_BUILD_ROOT/usr/bin/emacs -cp -f %SOURCE21 $RPM_BUILD_ROOT/usr/bin/emacs -# } - # # create file lists # -# Remove etags, ctags +# Remove ctags -rm -f $RPM_BUILD_ROOT/usr/bin/{ctags,etags} -rm -f $RPM_BUILD_ROOT/%{_mandir}/man1/*tags* -rm -f $RPM_BUILD_ROOT/usr/share/emacs/%{version}/{etags,ctags}* +rm -f $RPM_BUILD_ROOT/usr/bin/ctags +rm -f $RPM_BUILD_ROOT/%{_mandir}/man1/*ctags* +rm -f $RPM_BUILD_ROOT/usr/share/emacs/%{version}/etc/ctags* find $RPM_BUILD_ROOT/usr/share/emacs/%{version}/lisp \ @@ -286,14 +313,14 @@ rm -rf build-withx %define info_files ccmode cl dired-x ediff emacs forms gnus info message mh-e reftex sc vip viper widget %post for f in %{info_files}; do - /sbin/install-info %{_infodir}/$f.gz %{_infodir}/dir --section="GNU Emacs" + /sbin/install-info %{_infodir}/$f.gz %{_infodir}/dir --section="GNU Emacs" 2> /dev/null || : done %preun if [ "$1" = 0 ]; then for f in %{info_files}; do /sbin/install-info --delete %{_infodir}/$f.gz %{_infodir}/dir \ - --section="GNU Emacs" + --section="GNU Emacs" 2> /dev/null || : done fi @@ -319,19 +346,24 @@ if [ -L /usr/bin/emacs ]; then rm /usr/bin/emacs fi - %files -f core-filelist %defattr(-,root,root) %config(noreplace) /etc/skel/.emacs %doc etc/NEWS BUGS README etc/FAQ /usr/bin/b2m /usr/bin/emacsclient +/usr/bin/etags /usr/bin/rcs-checkin %{_mandir}/*/* %{_infodir}/* -/usr/share/emacs/site-lisp/python-mode.elc -/usr/share/emacs/site-lisp/subdirs.el /usr/share/emacs/locale.alias +/usr/share/emacs/site-lisp/python-mode.elc +/usr/share/emacs/site-lisp/mwheel.elc +/usr/share/emacs/site-lisp/rpm-spec-mode.elc +/usr/share/emacs/site-lisp/subdirs.el + +/usr/share/emacs/site-lisp/site-start.d/lang.emacs.el +/usr/share/emacs/site-lisp/lang %dir /usr/lib/emacs %dir /usr/lib/emacs/site-lisp @@ -340,8 +372,8 @@ fi %attr(0755,root,root) /usr/lib/emacs/%{version}/*/movemail %dir /usr/share/emacs/site-lisp -%attr(0644,root,root) %config(noreplace) /usr/share/emacs/site-lisp/site-start.el - +%attr(0644,root,root) %config /usr/share/emacs/site-lisp/site-start.el +%dir /usr/share/emacs/site-lisp/site-start.d %dir /usr/share/emacs/%{version} %dir /usr/share/emacs/%{version}/site-lisp %dir /usr/share/emacs/%{version}/leim @@ -350,6 +382,8 @@ fi %files -f el-filelist el %defattr(-,root,root) /usr/share/emacs/site-lisp/python-mode.el +/usr/share/emacs/site-lisp/mwheel.el +/usr/share/emacs/site-lisp/rpm-spec-mode.el %files -f leim-filelist leim %defattr(-,root,root) @@ -363,10 +397,76 @@ fi %defattr(-,root,root) %attr(755,root,root) /usr/bin/emacs %attr(755,root,root) /usr/bin/emacs-%{version} -%config(missingok) /etc/X11/applnk/Applications/emacs.desktop +%config /etc/X11/applnk/Applications/emacs.desktop /usr/share/pixmaps/emacs.png %changelog +* Fri Mar 16 2001 Trond Eivind Glomsrd +- New locale.alias file for emacs-nox + +* Tue Mar 6 2001 Trond Eivind Glomsrd +- update rpm-spec-mode.el to 0.11e - this should fix #30702 + +* Fri Feb 16 2001 Preston Brown +- require tamago, or japanese cannot be input (#27932). + +* Sat Jan 27 2001 Jakub Jelinek +- Preprocess Makefiles as if they were assembly, not C source. + +* Thu Jan 24 2001 Yukihiro Nakai +- Fix the fontset problem when creating a new frame. + +* Thu Jan 18 2001 Trond Eivind Glomsrd +- add Japanese support from Yukihiro Nakai + +* Thu Jan 04 2001 Preston Brown +- do not remove etags, only ctags, per Tom Tromey's suggestion. + +* Wed Dec 27 2000 Tim Powers +- bzipped sources to conserve space + +* Mon Dec 18 2000 Trond Eivind Glomsrd +- add /usr/share/emacs/locale.alias , which had gone AWOL +- update rpm-spec-mode to 0.11a, fresh from the author + (Stig Bjorlykke ). The changes we made + are integrated. + +* Fri Dec 15 2000 Trond Eivind Glomsrd +- prereq fileutils for emacs-nox + +* Mon Dec 11 2000 Trond Eivind Glomsrd +- do locale.alias fix for emacs-nox only, as it somehow + broke the subject line in gnus. Weird. +- update to gnus 5.8.7 + +* Fri Dec 08 2000 Than Ngo +- add support s390 machine + +* Thu Dec 07 2000 Trond Eivind Glomsrd +- add rpm-spec-mode after modifying (use Red Hat groups, + from /usr/share/doc/rpm-version/GROUPS) and fixing + colours(don't specify "yellow" on "bright") Also, + use gpg, not pgp. +- use it (site-start.el) +- add mwheel +- use it, in /etc/skel/.emacs + +* Thu Nov 30 2000 Trond Eivind Glomsrd +- add /usr/share/emacs/site-lisp/site-start.d +- change site-start.el so files in the above directory + are automatically run on startup +- don't set the ispell name in site-start.el, use the + above directory instead + +* Thu Oct 19 2000 Trond Eivind Glomsrd +- fix icon name in the .desktop file +- don't have site-start.el "noreplace" +- load psgml-init (if present) in the default site-start.el + to avoid psgml modifying the file + +* Tue Oct 17 2000 Trond Eivind Glomsrd +- new and better emacs.desktop file + * Tue Oct 10 2000 Trond Eivind Glomsrd - remove ctags.1 and etags.1 from the emacs etc directory (#18011) diff --git a/rpm-spec-mode.el b/rpm-spec-mode.el new file mode 100644 index 0000000..5f0c4fd --- /dev/null +++ b/rpm-spec-mode.el @@ -0,0 +1,1090 @@ +;;; rpm-spec-mode.el --- RPM spec file editing commands for Emacs/XEmacs + +;; Copyright (C) 1997,1998,1999,2000,2001 Stig Bjrlykke, + +;; Author: Stig Bjrlykke, +;; Keywords: unix, languages +;; Version: 0.11e + +;; This file is not yet part of FSF Emacs or XEmacs. + +;; Emacs/XEmacs is free software; you can redistribute it and/or modify +;; it under the terms of the GNU General Public License as published by +;; the Free Software Foundation; either version 2, or (at your option) +;; any later version. + +;; Emacs/XEmacs is distributed in the hope that it will be useful, +;; but WITHOUT ANY WARRANTY; without even the implied warranty of +;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +;; General Public License for more details. + +;; You should have received a copy of the GNU General Public License +;; along with Emacs/XEmacs; see the file COPYING. If not, write to the +;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, +;; MA 02111-1307, USA. + +;;; Synched up with: both in FSF Emacs and XEmacs. + +;;; Thanx to: + +;; Tore Olsen for some general fixes. +;; Steve Sanbeg for navigation functions and +;; some Emacs fixes. + +;;; ToDo: + +;; - rewrite function names and shortcuts. +;; - autofill changelog entries. +;; - customize rpm-tags-list and rpm-group-tags-list. +;; - get values from `rpm --showrc'. +;; - ssh/rsh for compile. +;; - finish integrating the new navigation functions in with existing stuff. +;; - use a single prefix conistently (internal) + +;;; Commentary: + +;; This mode is used for editing spec files used for building RPM packages. +;; +;; Most recent version is available from: +;; +;; +;; Put this in your .emacs file to enable autoloading of rpm-spec-mode, +;; and auto-recognition of ".spec" files: +;; +;; (autoload 'rpm-spec-mode "rpm-spec-mode.el" "RPM spec mode." t) +;; (setq auto-mode-alist (append '(("\\.spec" . rpm-spec-mode)) +;; auto-mode-alist)) +;;------------------------------------------------------------ +;; +;; Adapted for Red Hat and some fixes made by Tim Powers +;; and Trond Eivind Glomsrd . +;; +;; Adapted by Chmouel Boudjnah for Mandrake + +;;; Code: + +(defgroup rpm-spec nil + "RPM Spec mode with Emacs/XEmacs enhancements." + :prefix "rpm-spec" + :group 'languages) + +(defcustom rpm-spec-add-attr nil + "Add %attr entry for filelistings or not." + :type 'boolean + :group 'rpm-spec) + +(defcustom rpm-spec-short-circuit nil + "Skip straight to specified stage. +(ie, skip all stages leading up to the specified stage). Only valid +in \"%build\" and \"%install\" stage." + :type 'boolean + :group 'rpm-spec) + +(defcustom rpm-spec-timecheck "0" + "Set the \"timecheck\" age (0 to disable). +The timecheck value expresses, in seconds, the maximum age of a file +being packaged. Warnings will be printed for all files beyond the +timecheck age." + :type 'integer + :group 'rpm-spec) + +(defcustom rpm-spec-buildroot "" + "Override the BuildRoot tag with directory ." + :type 'string + :group 'rpm-spec) + +(defcustom rpm-spec-target "" + "Interpret given string as `arch-vendor-os'. +Set the macros _target, _target_arch and _target_os accordingly" + :type 'string + :group 'rpm-spec) + +(defcustom rpm-spec-clean nil + "Remove the build tree after the packages are made." + :type 'boolean + :group 'rpm-spec) + +(defcustom rpm-spec-rmsource nil + "Remove the source and spec file after the packages are made." + :type 'boolean + :group 'rpm-spec) + +(defcustom rpm-spec-test nil + "Do not execute any build stages. Useful for testing out spec files." + :type 'boolean + :group 'rpm-spec) + +(defcustom rpm-spec-sign-gpg nil + "Embed a GPG signature in the package. +This signature can be used to verify the integrity and the origin of +the package." + :type 'boolean + :group 'rpm-spec) + +(defcustom rpm-initialize-sections t + "Automatically add empty section headings to new spec files." + :type 'boolean + :group 'rpm-spec) + +(defcustom rpm-insert-version t + "Automatically add version in a new changelog entry." + :type 'boolean + :group 'rpm-spec) + +(defgroup rpm-spec-faces nil + "Font lock faces for RPM Spec mode." + :group 'rpm-spec + :group 'faces) + +;;------------------------------------------------------------ +;; variables used by navigation functions. + +(defconst rpm-sections + '("preamble" "description" "prep" "setup" "build" "install" "clean" + "changelog" "files") + "Partial list of section names.") +(defvar rpm-section-list + '(("preamble") ("description") ("prep") ("setup") ("build") ("install") + ("clean") ("changelog") ("files")) + "Partial list of section names.") +(defconst rpm-scripts + '("pre" "post" "preun" "postun" "trigger" "triggerun" "triggerpostun") + "List of rpm scripts") +(defconst rpm-section-seperate "^%\\(\\w+\\)\\s-") +(defconst rpm-section-regexp + "^%\\(\\(description\\)\\|\\(prep\\)\\|\\(changelog\\)\\|\\(build\\)\\|\\(install\\)\\|\\(files\\)\\|\\(clean\\)\\|\\(package\\)\\|\\(pre\\|post\\(un\\)?\\)\\|\\(trigger\\(post\\)?\\([iu]n\\)?\\)\\)\\b" + "Regular expression to match beginning of a section.") + +;;------------------------------------------------------------ + +(defface rpm-spec-tag-face + '(( ((class color) (background light)) (:foreground "blue") ) + ( ((class color) (background dark)) (:foreground "blue") )) + "*The face used for tags." + :group 'rpm-spec-faces) + +(defface rpm-spec-macro-face + '(( ((class color) (background light)) (:foreground "purple") ) + ( ((class color) (background dark)) (:foreground "yellow") )) + "*The face used for macros." + :group 'rpm-spec-faces) + +(defface rpm-spec-doc-face + '(( ((class color) (background light)) (:foreground "magenta") ) + ( ((class color) (background dark)) (:foreground "magenta") )) + "*The face used for document files." + :group 'rpm-spec-faces) + +(defface rpm-spec-dir-face + '(( ((class color) (background light)) (:foreground "green") ) + ( ((class color) (background dark)) (:foreground "green") )) + "*The face used for directories." + :group 'rpm-spec-faces) + +(defface rpm-spec-package-face + '(( ((class color) (background light)) (:foreground "red") ) + ( ((class color) (background dark)) (:foreground "red") )) + "*The face used for files." + :group 'rpm-spec-faces) + +(defface rpm-spec-ghost-face + '(( ((class color) (background light)) (:foreground "red") ) + ( ((class color) (background dark)) (:foreground "red") )) + "*The face used for ghost tags." + :group 'rpm-spec-faces) + +;;; GNU emacs font-lock needs these... +(defvar rpm-spec-macro-face 'rpm-spec-macro-face "*Face for macros") +(defvar rpm-spec-tag-face 'rpm-spec-tag-face "*Face for tags") +(defvar rpm-spec-package-face 'rpm-spec-package-face "*Face for package tag") +(defvar rpm-spec-dir-face 'rpm-spec-dir-face "*Face for directory entries") +(defvar rpm-spec-doc-face 'rpm-spec-doc-face "*Face for documentation entries") +(defvar rpm-spec-ghost-face 'rpm-spec-ghost-face "*Face for %ghost files") + +(defvar rpm-default-umask "-" + "*Default umask for files, specified with %attr") +(defvar rpm-default-owner "root" + "*Default owner for files, specified with %attr") +(defvar rpm-default-group "root" + "*Default group for files, specified with %attr") + +;;------------------------------------------------------------ + +(defvar rpm-no-gpg nil "Tell rpm not to sign package.") + +(defvar rpm-tags-list + '(("Autoreqprov") + ("Buildroot") + ("Conflicts") + ("Copyright") + ("%description") + ("Distribution") + ("Excludearch") + ("Excludeos") + ("Exclusivearch") + ("Exclusiveos") + ("%files") + ("Group") + ("Icon") + ("%ifarch") + ("Name") + ("Nopatch") + ("Nosource") + ("%package") + ("Packager") + ("Patch") + ("Prefix") + ("Provides") + ("Release") + ("Requires") + ("Serial") + ("Source") + ("Summary") + ("Url") + ("Vendor") + ("Version")) + "List which elements are valid tags.") + +(defvar rpm-group-tags-list + '(("Amusements/Games") + ("Amusements/Graphics") + ("Applications/Archiving") + ("Applications/Communications") + ("Applications/Databases") + ("Applications/Editors") + ("Applications/Emulators") + ("Applications/Engineering") + ("Applications/File") + ("Applications/Internet") + ("Applications/Multimedia") + ("Applications/Productivity") + ("Applications/Publishing") + ("Applications/System") + ("Applications/Text") + ("Development/Debuggers") + ("Development/Languages") + ("Development/Libraries") + ("Development/System") + ("Development/Tools") + ("Documentation") + ("System Environment/Base") + ("System Environment/Daemons") + ("System Environment/Kernel") + ("System Environment/Libraries") + ("System Environment/Shells") + ("User Interface/Desktops") + ("User Interface/X") + ("User Interface/X Hardware Support") + ) + "List which elements is valid group tags.") + +(defvar rpm-spec-mode-syntax-table nil + "Syntax table in use in RPM-Spec-mode buffers.") +(unless rpm-spec-mode-syntax-table + (setq rpm-spec-mode-syntax-table (make-syntax-table)) + (modify-syntax-entry ?\\ "\\" rpm-spec-mode-syntax-table) + (modify-syntax-entry ?\n "> " rpm-spec-mode-syntax-table) + (modify-syntax-entry ?\f "> " rpm-spec-mode-syntax-table) + (modify-syntax-entry ?\# "< " rpm-spec-mode-syntax-table) + (modify-syntax-entry ?/ "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?* "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?+ "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?- "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?= "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?% "_" rpm-spec-mode-syntax-table) + (modify-syntax-entry ?< "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?> "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?& "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?| "." rpm-spec-mode-syntax-table) + (modify-syntax-entry ?\' "." rpm-spec-mode-syntax-table)) + +(defvar rpm-spec-mode-map nil + "Keymap used in RPM Spec mode.") +(unless rpm-spec-mode-map + (setq rpm-spec-mode-map (make-sparse-keymap)) + (and (functionp 'set-keymap-name) + (set-keymap-name rpm-spec-mode-map 'rpm-spec-mode-map)) + (define-key rpm-spec-mode-map "\C-ca" 'rpm-build-ba) + (define-key rpm-spec-mode-map "\C-cb" 'rpm-build-bb) + (define-key rpm-spec-mode-map "\C-cc" 'rpm-build-bc) + (define-key rpm-spec-mode-map "\C-ce" 'rpm-add-change-log-entry) + (define-key rpm-spec-mode-map "\C-cg" 'rpm-goto-section) + (define-key rpm-spec-mode-map "\C-ci" 'rpm-build-bi) + (define-key rpm-spec-mode-map "\C-cl" 'rpm-build-bl) + (define-key rpm-spec-mode-map "\C-cp" 'rpm-build-bp) + (define-key rpm-spec-mode-map "\C-cr" 'rpm-increase-release-tag) + (define-key rpm-spec-mode-map "\C-cs" 'rpm-build-bs) + (define-key rpm-spec-mode-map "\C-cxa" 'rpm-toggle-add-attr) + (define-key rpm-spec-mode-map "\C-cxb" 'rpm-change-buildroot-option) + (define-key rpm-spec-mode-map "\C-cxc" 'rpm-toggle-clean) + (define-key rpm-spec-mode-map "\C-cxg" 'rpm-toggle-sign-gpg) + (define-key rpm-spec-mode-map "\C-cxi" 'rpm-change-timecheck-option) + (define-key rpm-spec-mode-map "\C-cxp" 'rpm-change-target-option) + (define-key rpm-spec-mode-map "\C-cxr" 'rpm-toggle-rmsource) + (define-key rpm-spec-mode-map "\C-cxs" 'rpm-toggle-short-circuit) + (define-key rpm-spec-mode-map "\C-cxt" 'rpm-toggle-test) + ;;May be better to have movement commands on \C-ck, and build on \C-c\C-k + (define-key rpm-spec-mode-map "\C-c\C-i" 'rpm-insert-tag) + (define-key rpm-spec-mode-map "\C-u\C-c\C-i" 'rpm-change-tag) + (define-key rpm-spec-mode-map "\C-c\C-n" 'rpm-forward-section) + (define-key rpm-spec-mode-map "\C-c\C-p" 'rpm-backward-section) + (define-key rpm-spec-mode-map "\C-c\C-t" 'rpm-insert-true-prefix) + (define-key rpm-spec-mode-map "\C-c\C-cg" 'rpm-files-group) + (define-key rpm-spec-mode-map "\C-c\C-co" 'rpm-files-owner) + (define-key rpm-spec-mode-map "\C-c\C-cu" 'rpm-files-umask) + (define-key rpm-spec-mode-map "\C-c\C-dd" 'rpm-insert-dir) + (define-key rpm-spec-mode-map "\C-c\C-do" 'rpm-insert-docdir) + (define-key rpm-spec-mode-map "\C-c\C-fc" 'rpm-insert-config) + (define-key rpm-spec-mode-map "\C-c\C-fd" 'rpm-insert-doc) + (define-key rpm-spec-mode-map "\C-c\C-ff" 'rpm-insert-file) + (define-key rpm-spec-mode-map "\C-c\C-fg" 'rpm-insert-ghost) + ;(define-key rpm-spec-mode-map "\C-q" 'indent-spec-exp) + ;(define-key rpm-spec-mode-map "\t" 'sh-indent-line) + ) + +(defconst rpm-spec-mode-menu + (purecopy '("RPM-Spec" + ["Insert Tag" rpm-insert-tag t] + ["Change Tag" rpm-change-tag t] + "---" + ["Go to section..." rpm-mouse-goto-section :keys "C-c g"] + ["Forward section" rpm-forward-section t] + ["Backward sectoin" rpm-backward-section t] + "---" + ["Add changelog entry..." rpm-add-change-log-entry t] + ["Increase release-tag" rpm-increase-release-tag t] + "---" + ("Add file entry" + ["Regular file..." rpm-insert-file t] + ["Config file..." rpm-insert-config t] + ["Document file..." rpm-insert-doc t] + ["Ghost file..." rpm-insert-ghost t] + "---" + ["Directory..." rpm-insert-dir t] + ["Document directory..." rpm-insert-docdir t] + "---" + ["Insert %{prefix}" rpm-insert-true-prefix t] + "---" + ["Default add \"%attr\" entry" rpm-toggle-add-attr + :style toggle :selected rpm-spec-add-attr] + ["Change default umask for files..." rpm-files-umask t] + ["Change default owner for files..." rpm-files-owner t] + ["Change default group for files..." rpm-files-group t]) + ("Build Options" + ["Short Circuit" rpm-toggle-short-circuit + :style toggle :selected rpm-spec-short-circuit] + ["Remove source" rpm-toggle-rmsource + :style toggle :selected rpm-spec-rmsource] + ["Clean" rpm-toggle-clean + :style toggle :selected rpm-spec-clean] + ["Testing only" rpm-toggle-test + :style toggle :selected rpm-spec-test] + ["GPG Sign" rpm-toggle-sign-gpg + :style toggle :selected rpm-spec-sign-gpg] + "---" + ["Change timecheck value..." rpm-change-timecheck-option t] + ["Change buildroot value..." rpm-change-buildroot-option t] + ["Change target value..." rpm-change-target-option t]) + ("RPM Build" + ["Execute \"%prep\" stage" rpm-build-bp t] + ["Do a \"list check\"" rpm-build-bl t] + ["Do the \"%build\" stage" rpm-build-bc t] + ["Do the \"%install\" stage" rpm-build-bi t] + "---" + ["Build binary package" rpm-build-bb t] + ["Build source package" rpm-build-bs t] + ["Build binary and source" rpm-build-ba t]) + "---" + ["About rpm-spec-mode" rpm-about-rpm-spec-mode t] + ))) + +(defvar rpm-spec-font-lock-keywords + '( + ("%[a-zA-Z0-9_]+" 0 rpm-spec-macro-face) + ("^\\([a-zA-Z0-9]+\\)\\(\([a-zA-Z0-9]+\)\\):" + (1 rpm-spec-tag-face) + (2 rpm-spec-ghost-face)) + ("^\\([a-zA-Z0-9]+\\):" 1 rpm-spec-tag-face) + ("%\\(define\\|files\\|package\\|description\\)[ \t]+\\([^ \t\n-]+\\)" + (2 rpm-spec-package-face)) + ("%configure " 0 rpm-spec-macro-face) + ("%dir[ \t]+\\([^ \t\n]+\\)[ \t]*" 1 rpm-spec-dir-face) + ("%doc\\(\\|dir\\)[ \t]+\\(.*\\)\n" 2 rpm-spec-doc-face) + ("%\\(ghost\\|config\\)[ \t]+\\(.*\\)\n" 2 rpm-spec-ghost-face) + ("^%.+-[a-zA-Z][ \t]+\\([a-zA-Z0-9\.-]+\\)" 1 rpm-spec-doc-face) + ("^\\(.+\\)(\\([a-zA-Z]\\{2,2\\}\\)):" + (1 rpm-spec-tag-face) + (2 rpm-spec-doc-face)) + ("^\\*\\(.*[0-9] \\)\\(.*\\)\\(<.*>\\)\\(.*\\)\n" + (1 rpm-spec-dir-face) + (2 rpm-spec-package-face) + (3 rpm-spec-tag-face) + (4 font-lock-warning-face)) + ("%{[^{}]*}" 0 rpm-spec-macro-face) + ) + "Additional expressions to highlight in RPM Spec mode.") + +;;Initialize font lock for xemacs +(put 'rpm-spec-mode 'font-lock-defaults '(rpm-spec-font-lock-keywords)) + +(defvar rpm-spec-mode-abbrev-table nil + "Abbrev table in use in RPM-Spec-mode buffers.") +(define-abbrev-table 'rpm-spec-mode-abbrev-table ()) + +;;------------------------------------------------------------ + +;;;###autoload +(defun rpm-spec-mode () + "Major mode for editing spec files. +This is much like C mode except for the syntax of comments. It uses +the same keymap as C mode and has the same variables for customizing +indentation. It has its own abbrev table and its own syntax table. + +Turning on RPM Spec mode calls the value of the variable `rpm-spec-mode-hook' +with no args, if that value is non-nil." + (interactive) + (kill-all-local-variables) + (condition-case nil + (require 'shindent) + (error + (require 'sh-script))) + (require 'cc-mode) + (use-local-map rpm-spec-mode-map) + (setq major-mode 'rpm-spec-mode) + (setq mode-name "RPM-SPEC") + (setq local-abbrev-table rpm-spec-mode-abbrev-table) + (set-syntax-table rpm-spec-mode-syntax-table) + + (require 'easymenu) + (easy-menu-define rpm-spec-call-menu rpm-spec-mode-map + "Post menu for rpm-spec-mode" rpm-spec-mode-menu) + (easy-menu-add rpm-spec-mode-menu) + + (if (= (buffer-size) 0) + (rpm-spec-initialize)) + + (make-local-variable 'paragraph-start) + (setq paragraph-start (concat "$\\|" page-delimiter)) + (make-local-variable 'paragraph-separate) + (setq paragraph-separate paragraph-start) + (make-local-variable 'paragraph-ignore-fill-prefix) + (setq paragraph-ignore-fill-prefix t) +; (make-local-variable 'indent-line-function) +; (setq indent-line-function 'c-indent-line) + (make-local-variable 'require-final-newline) + (setq require-final-newline t) + (make-local-variable 'comment-start) + (setq comment-start "# ") + (make-local-variable 'comment-end) + (setq comment-end "") + (make-local-variable 'comment-column) + (setq comment-column 32) + (make-local-variable 'comment-start-skip) + (setq comment-start-skip "#+ *") +; (make-local-variable 'comment-indent-function) +; (setq comment-indent-function 'c-comment-indent) + ;;Initialize font lock for GNU emacs. + (make-local-variable 'font-lock-defaults) + (setq font-lock-defaults '(rpm-spec-font-lock-keywords nil t)) + (run-hooks 'rpm-spec-mode-hook)) + +(defun rpm-command-filter (process string) + "Filter to process normal output." + (save-excursion + (set-buffer (process-buffer process)) + (save-excursion + (goto-char (process-mark process)) + (insert-before-markers string) + (set-marker (process-mark process) (point))))) + +;;------------------------------------------------------------ + +(defun rpm-add-change-log-entry (&optional change-log-entry) + "Find change log and add an entry for today." + (interactive "sChangelog entry: ") + (save-excursion + (rpm-goto-section "changelog") + (let ((string (concat "* " (substring (current-time-string) 0 11) + (substring (current-time-string) -4) " " + (user-full-name) " <" user-mail-address ">"))) + (if (not (search-forward string nil t)) + (insert "\n" string "\n") + (forward-line 2)) + (insert "- " change-log-entry "\n")))) + +;;------------------------------------------------------------ + +(defun rpm-insert-f (&optional filetype filename) + "Insert new %files entry." + (save-excursion + (and (rpm-goto-section "files") (rpm-end-of-section)) + (if (or (eq filename 1) (not filename)) + (insert (read-file-name + (concat filetype "filename: ") "" "" nil) "\n") + (insert filename "\n")) + (forward-line -1) + (if rpm-spec-add-attr + (let ((rpm-default-mode rpm-default-umask)) + (insert "%attr(" rpm-default-mode ", " rpm-default-owner ", " + rpm-default-group ") "))) + (insert filetype))) + +(defun rpm-insert-file (&optional filename) + "Insert regular file." + (interactive "p") + (rpm-insert-f "" filename)) + +(defun rpm-insert-config (&optional filename) + "Insert config file." + (interactive "p") + (rpm-insert-f "%config " filename)) + +(defun rpm-insert-doc (&optional filename) + "Insert doc file." + (interactive "p") + (rpm-insert-f "%doc " filename)) + +(defun rpm-insert-ghost (&optional filename) + "Insert ghost file." + (interactive "p") + (rpm-insert-f "%ghost " filename)) + +(defun rpm-insert-dir (&optional dirname) + "Insert directory." + (interactive "p") + (rpm-insert-f "%dir " dirname)) + +(defun rpm-insert-docdir (&optional dirname) + "Insert doc directory." + (interactive "p") + (rpm-insert-f "%docdir " dirname)) + +;;------------------------------------------------------------ + +(defun rpm-insert (&optional what file-completion) + "Insert given tag. Use file-completion if argument is t." + (beginning-of-line) + (if (not what) + (setq what (completing-read "Tag: " rpm-tags-list))) + (if (string-match "^%" what) + (setq read-text (concat "Packagename for " what ": ") + insert-text (concat what " ")) + (setq read-text (concat what ": ") + insert-text (concat what ": "))) + (cond + ((string-equal what "Group") + (rpm-insert-group)) + ((string-equal what "Source") + (rpm-insert-n "Source")) + ((string-equal what "Patch") + (rpm-insert-n "Patch")) + (t + (if file-completion + (insert insert-text (read-file-name (concat read-text) "" "" nil) "\n") + (insert insert-text (read-from-minibuffer (concat read-text)) "\n"))))) + +(defun rpm-topdir () + (or + (getenv "RPM") + (getenv "rpm") + (if (file-directory-p "~/rpm") "~/rpm/") + (if (file-directory-p "~/RPM") "~/RPM/") + (if (file-directory-p "/usr/src/redhat/")"/usr/src/redhat/") + "/usr/src/RPM")) + +(defun rpm-insert-n (what &optional arg) + "Insert given tag with possible number." + (save-excursion + (goto-char (point-max)) + (if (search-backward-regexp (concat "^" what "\\([0-9]*\\):") nil t) + (let ((release (1+ (string-to-int (match-string 1))))) + (forward-line 1) + (let ((default-directory (concat (rpm-topdir) "/SOURCES/"))) + (insert what (int-to-string release) ": " + (read-file-name (concat what "file: ") "" "" nil) "\n"))) + (goto-char (point-min)) + (rpm-end-of-section) + (insert what ": " (read-from-minibuffer (concat what "file: ")) "\n")))) + +(defun rpm-change (&optional what arg) + "Update given tag." + (save-excursion + (if (not what) + (setq what (completing-read "Tag: " rpm-tags-list))) + (cond + ((string-equal what "Group") + (rpm-change-group)) + ((string-equal what "Source") + (rpm-change-n "Source")) + ((string-equal what "Patch") + (rpm-change-n "Patch")) + (t + (goto-char (point-min)) + (if (search-forward-regexp (concat "^" what ":\\s-*\\(.*\\)$") nil t) + (replace-match + (concat what ": " (read-from-minibuffer + (concat "New " what ": ") (match-string 1)))) + (message (concat what " tag not found..."))))))) + +(defun rpm-change-n (what &optional arg) + "Change given tag with possible number." + (save-excursion + (goto-char (point-min)) + (let ((number (read-from-minibuffer (concat what " number: ")))) + (if (search-forward-regexp + (concat "^" what number ":\\s-*\\(.*\\)") nil t) + (let ((default-directory (concat (rpm-topdir) "/SOURCES/"))) + (replace-match + (concat what number ": " + (read-file-name (concat "New " what number " file: ") + "" "" nil (match-string 1))))) + (message (concat what " number \"" number "\" not found...")))))) + +(defun rpm-insert-group (group) + "Insert Group tag." + (interactive (list (completing-read "Group: " rpm-group-tags-list))) + (beginning-of-line) + (insert "Group: " group "\n")) + +(defun rpm-change-group (&optional arg) + "Update Group tag." + (interactive "p") + (save-excursion + (goto-char (point-min)) + (if (search-forward-regexp "^Group: \\(.*\\)$" nil t) + (replace-match + (concat "Group: " + (insert (completing-read "Group: " rpm-group-tags-list + nil nil (match-string 1))))) + (message "Group tag not found...")))) + +(defun rpm-insert-tag (&optional arg) + "Insert a tag." + (interactive "p") + (rpm-insert)) + +(defun rpm-change-tag (&optional arg) + "Change a tag." + (interactive "p") + (rpm-change)) + +(defun rpm-insert-packager (&optional arg) + "Insert Packager tag." + (interactive "p") + (beginning-of-line) + (insert "Packager: " (user-full-name) " <" user-mail-address ">\n")) + +(defun rpm-change-packager (&optional arg) + "Update Packager tag." + (interactive "p") + (rpm-change "Packager")) + +;;------------------------------------------------------------ + +(defun rpm-current-section nil + (interactive) + (save-excursion + (rpm-forward-section) + (rpm-backward-section) + (if (bobp) "preamble" + (buffer-substring (match-beginning 1) (match-end 1))))) + +(defun rpm-backward-section nil + "Move backward to the beginning of the previous section. +Go to beginning of previous section." + (interactive) + (or (re-search-backward rpm-section-regexp nil t) + (goto-char (point-min)))) + +(defun rpm-beginning-of-section nil + "Move backward to the beginning of the current section. +Go to beginning of current section." + (interactive) + (or (and (looking-at rpm-section-regexp) (point)) + (re-search-backward rpm-section-regexp nil t) + (goto-char (point-min)))) + +(defun rpm-forward-section nil + "Move forward to the beginning of the next section." + (interactive) + (forward-char) + (if (re-search-forward rpm-section-regexp nil t) + (progn (forward-line 0) (point)) + (goto-char (point-max)))) + +(defun rpm-end-of-section nil + "Move forward to the end of this section." + (interactive) + (forward-char) + (if (re-search-forward rpm-section-regexp nil t) + (forward-line -1) + (goto-char (point-max))) +;; (while (or (looking-at paragraph-separate) (looking-at "^\\s-*#")) + (while (looking-at "^\\s-*\\($\\|#\\)") + (forward-line -1)) + (forward-line 1) + (point)) + +(defun rpm-goto-section (section) + "Move point to the beginning of the specified section; +leave point at previous location." + (interactive (list (completing-read "Section: " rpm-section-list))) + (push-mark) + (goto-char (point-min)) + (or + (equal section "preamble") + (re-search-forward (concat "^%" section "\\b") nil t) + (let ((s (cdr rpm-sections))) + (while (not (equal section (car s))) + (re-search-forward (concat "^%" (car s) "\\b") nil t) + (setq s (cdr s))) + (if (re-search-forward rpm-section-regexp nil t) + (forward-line -1) (goto-char (point-max))) + (insert "\n%" section "\n")))) + +(defun rpm-mouse-goto-section (&optional section) + (interactive + (x-popup-menu nil + (list "sections" + (cons "Sections" (mapcar (lambda (e) (list e e)) rpm-sections)) + (cons "Scripts" (mapcar (lambda (e) (list e e)) rpm-scripts)) + ))) + (and section ;if user doesn't pick a section, exit quietly. + (if (member section rpm-sections) + (rpm-goto-section section) + (goto-char (point-min)) + (or (re-search-forward (concat "^%" section "\\b") nil t) + (and (re-search-forward "^%files\\b" nil t) (forward-line -1)) + (goto-char (point-max)))))) + +(defun rpm-insert-true-prefix () + (interactive) + (insert "%{prefix}")) + + +;;------------------------------------------------------------ + +(defun rpm-build (buildoptions) + "Build this rpm-package." + (setq rpm-buffer-name + (concat "*rpm " buildoptions " " + (file-name-nondirectory buffer-file-name) "*")) + (rpm-process-check rpm-buffer-name) + (if (get-buffer rpm-buffer-name) + (kill-buffer rpm-buffer-name)) + (create-file-buffer rpm-buffer-name) + (display-buffer rpm-buffer-name) + (setq buildoptions (list buildoptions buffer-file-name)) + (if (or rpm-spec-short-circuit rpm-spec-test) + (setq rpm-no-gpg t)) + (if rpm-spec-rmsource + (setq buildoptions (cons "--rmsource" buildoptions))) + (if rpm-spec-clean + (setq buildoptions (cons "--clean" buildoptions))) + (if rpm-spec-short-circuit + (setq buildoptions (cons "--short-circuit" buildoptions))) + (if (and (not (equal rpm-spec-timecheck "0")) + (not (equal rpm-spec-timecheck ""))) + (setq buildoptions (cons "--timecheck" (cons rpm-spec-timecheck + buildoptions)))) + (if (not (equal rpm-spec-buildroot "")) + (setq buildoptions (cons "--buildroot" (cons rpm-spec-buildroot + buildoptions)))) + (if (not (equal rpm-spec-target "")) + (setq buildoptions (cons "--target" (cons rpm-spec-target + buildoptions)))) + (if rpm-spec-test + (setq buildoptions (cons "--test" buildoptions))) + (if (and rpm-spec-sign-gpg (not rpm-no-gpg)) + (setq buildoptions (cons "--sign" buildoptions))) + (save-excursion + (set-buffer (get-buffer rpm-buffer-name)) + (goto-char (point-max))) + (let ((process + (apply 'start-process "rpm" rpm-buffer-name "rpm" buildoptions))) + (if (and rpm-spec-sign-gpg (not rpm-no-gpg)) + (let ((rpm-passwd-cache (read-passwd "GPG passphrase: "))) + (process-send-string process (concat rpm-passwd-cache "\n")))) + (set-process-filter process 'rpm-command-filter))) + +(defun rpm-build-bp (&optional arg) + "Run a `rpm -bp'." + (interactive "p") + (if rpm-spec-short-circuit + (message "Cannot run `rpm -bp' with --short-circuit") + (setq rpm-no-gpg t) + (rpm-build "-bp"))) + +(defun rpm-build-bl (&optional arg) + "Run a `rpm -bl'." + (interactive "p") + (if rpm-spec-short-circuit + (message "Cannot run `rpm -bl' with --short-circuit") + (setq rpm-no-gpg t) + (rpm-build "-bl"))) + +(defun rpm-build-bc (&optional arg) + "Run a `rpm -bc'." + (interactive "p") + (setq rpm-no-gpg t) + (rpm-build "-bc")) + +(defun rpm-build-bi (&optional arg) + "Run a `rpm -bi'." + (interactive "p") + (setq rpm-no-gpg t) + (rpm-build "-bi")) + +(defun rpm-build-bb (&optional arg) + "Run a `rpm -bb'." + (interactive "p") + (if rpm-spec-short-circuit + (message "Cannot run `rpm -bb' with --short-circuit") + (setq rpm-no-gpg nil) + (rpm-build "-bb"))) + +(defun rpm-build-bs (&optional arg) + "Run a `rpm -bs'." + (interactive "p") + (if rpm-spec-short-circuit + (message "Cannot run `rpm -bs' with --short-circuit") + (setq rpm-no-gpg nil) + (rpm-build "-bs"))) + +(defun rpm-build-ba (&optional arg) + "Run a `rpm -ba'." + (interactive "p") + (if rpm-spec-short-circuit + (message "Cannot run `rpm -ba' with --short-circuit") + (setq rpm-no-gpg nil) + (rpm-build "-ba"))) + +(defun rpm-process-check (buffer) + "Check if BUFFER has a running process. +If so, give the user the choice of aborting the process or the current +command." + (let ((process (get-buffer-process (get-buffer buffer)))) + (if (and process (eq (process-status process) 'run)) + (if (yes-or-no-p (concat "Process `" (process-name process) + "' running. Kill it? ")) + (delete-process process) + (error "Cannot run two simultaneous processes ..."))))) + +;;------------------------------------------------------------ + +(defun rpm-toggle-short-circuit (&optional arg) + "Toggle rpm-spec-short-circuit." + (interactive "p") + (setq rpm-spec-short-circuit (not rpm-spec-short-circuit)) + (rpm-update-mode-name) + (message (concat "Turned `--short-circuit' " + (if rpm-spec-short-circuit "on" "off") "."))) + +(defun rpm-toggle-rmsource (&optional arg) + "Toggle rpm-spec-rmsource." + (interactive "p") + (setq rpm-spec-rmsource (not rpm-spec-rmsource)) + (rpm-update-mode-name) + (message (concat "Turned `--rmsource' " + (if rpm-spec-rmsource "on" "off") "."))) + +(defun rpm-toggle-clean (&optional arg) + "Toggle rpm-spec-clean." + (interactive "p") + (setq rpm-spec-clean (not rpm-spec-clean)) + (rpm-update-mode-name) + (message (concat "Turned `--clean' " + (if rpm-spec-clean "on" "off") "."))) + +(defun rpm-toggle-test (&optional arg) + "Toggle rpm-spec-test." + (interactive "p") + (setq rpm-spec-test (not rpm-spec-test)) + (rpm-update-mode-name) + (message (concat "Turned `--test' " + (if rpm-spec-test "on" "off") "."))) + +(defun rpm-toggle-sign-gpg (&optional arg) + "Toggle rpm-spec-sign-gpg." + (interactive "p") + (setq rpm-spec-sign-gpg (not rpm-spec-sign-gpg)) + (rpm-update-mode-name) + (message (concat "Turned `--sign' " + (if rpm-spec-sign-gpg "on" "off") "."))) + +(defun rpm-toggle-add-attr (&optional arg) + "Toggle rpm-spec-add-attr." + (interactive "p") + (setq rpm-spec-add-attr (not rpm-spec-add-attr)) + (rpm-update-mode-name) + (message (concat "Default add \"attr\" entry turned " + (if rpm-spec-add-attr "on" "off") "."))) + +(defun rpm-update-mode-name () + "Update mode-name according to values set." + (setq mode-name "RPM-SPEC") + (setq modes (concat (if rpm-spec-add-attr "A") + (if rpm-spec-clean "C") + (if rpm-spec-sign-gpg "G") + (if rpm-spec-rmsource "R") + (if rpm-spec-short-circuit "S") + (if rpm-spec-test "T") + )) + (if (not (equal modes "")) + (setq mode-name (concat mode-name ":" modes)))) + +;;------------------------------------------------------------ + +(defun rpm-change-timecheck-option (&optional arg) + "Change the value for timecheck." + (interactive "p") + (setq rpm-spec-timecheck + (read-from-minibuffer "New timecheck: " rpm-spec-timecheck))) + +(defun rpm-change-buildroot-option (&optional arg) + "Change the value for buildroot." + (interactive "p") + (setq rpm-spec-buildroot + (read-from-minibuffer "New buildroot: " rpm-spec-buildroot))) + +(defun rpm-change-target-option (&optional arg) + "Change the value for target." + (interactive "p") + (setq rpm-spec-target + (read-from-minibuffer "New target: " rpm-spec-target))) + +(defun rpm-files-umask (&optional arg) + "Change the default umask for files." + (interactive "p") + (setq rpm-default-umask + (read-from-minibuffer "Default file umask: " rpm-default-umask))) + +(defun rpm-files-owner (&optional arg) + "Change the default owner for files." + (interactive "p") + (setq rpm-default-owner + (read-from-minibuffer "Default file owner: " rpm-default-owner))) + +(defun rpm-files-group (&optional arg) + "Change the source directory." + (interactive "p") + (setq rpm-default-group + (read-from-minibuffer "Default file group: " rpm-default-group))) + +(defun rpm-increase-release-tag (&optional arg) + "Increase the release tag by 1." + (interactive "p") + (save-excursion + (goto-char (point-min)) + (if (search-forward-regexp "^Release:[ \t]*\\([0-9]+\\)\\(.*\\)" nil t) + (let ((release (1+ (string-to-int (match-string 1))))) + (setq release (concat (int-to-string release) (match-string 2))) + (replace-match (concat "Release: " release)) + (message (concat "Release tag changed to " release ".")))) + (if (search-forward-regexp "^Release:[ \t]*%{?\\([^}]*\\)}?$" nil t) + (rpm-increase-release-with-macros) + (message "No Release tag found...")))) + +;;------------------------------------------------------------ + +(defun rpm-spec-field-value (field max) + (save-excursion + (let ((str + (progn + (goto-char (point-min)) + (search-forward-regexp (concat field ":[ \t]*\\(.+\\).*$") max) + (match-string 1)))) + (if (string-match "%{?\\([^}]*\\)}?$" str) + (progn + (goto-char (point-min)) + (search-forward-regexp + (concat "%define[ \t]+" (substring str (match-beginning 1) + (match-end 1)) + "[ \t]+\\(.*\\)")) + (match-string 1)) + str)))) + +(defun rpm-find-spec-version () + (save-excursion + (goto-char (point-min)) + (let* ((max (search-forward-regexp rpm-section-regexp)) + (version (rpm-spec-field-value "Version" max)) + (release (rpm-spec-field-value "Release" max)) ) + (concat version "-" release)))) + +(defun rpm-increase-release-with-macros () + (save-excursion + (let ((str + (progn + (goto-char (point-min)) + (search-forward-regexp (concat "Release:[ \t]*\\(.+\\).*$") nil) + (match-string 1)))) + (let ((inrel + (if (string-match "%{?\\([^}]*\\)}?$" str) + (progn + (goto-char (point-min)) + (setq macros (substring str (match-beginning 1) + (match-end 1))) + (search-forward-regexp + (concat "%define[ \t]+" macros + "[ \t]+\\(\\([0-9]\\|\\.\\)+\\)\\(.*\\)")) + (concat macros " " (int-to-string (1+ (string-to-int + (match-string 1)))) + (match-string 3))) + str))) + (setq dinrel inrel) + (replace-match (concat "%define " dinrel)) + (message (concat "Release tag changed to " dinrel ".")))))) + +;;------------------------------------------------------------ + +(defun rpm-spec-initialize () + "Create a default spec file if one does not exist or is empty." + (let (file name version (release "1")) + (setq file (if (buffer-file-name) + (file-name-nondirectory (buffer-file-name)) + (buffer-name))) + (cond + ((eq (string-match "\\(.*\\)-\\([^-]*\\)-\\([^-]*\\).spec" file) 0) + (setq name (match-string 1 file)) + (setq version (match-string 2 file)) + (setq release (match-string 3 file))) + ((eq (string-match "\\(.*\\)-\\([^-]*\\).spec" file) 0) + (setq name (match-string 1 file)) + (setq version (match-string 2 file))) + ((eq (string-match "\\(.*\\).spec" file) 0) + (setq name (match-string 1 file)))) + + (insert + "Summary: " + "\nName: " (or name "") + "\nVersion: " (or version "") + "\nRelease: " (or release "") + "\nURL: " + "\nSource0: %{name}-%{version}.tar.gz" + "\nLicense: \nGroup: " + "\nBuildRoot: %{_tmppath}/%{name}-root" + "\n\n%description\n" + "\n%prep" + "\n%setup -q" + "\n\n%build" + "\n\n%install" + "\nrm -rf $RPM_BUILD_ROOT" + "\n\n%clean" + "\nrm -rf $RPM_BUILD_ROOT" + "\n\n%files" + "\n%defattr(-,root,root)\n" + "\n\n%changelog\n") + + (rpm-add-change-log-entry "Initial build.\n"))) + +;;------------------------------------------------------------ + +(defun rpm-about-rpm-spec-mode (&optional arg) + "About rpm-spec-mode." + (interactive "p") + (message "Made by Stig Bjrlykke, ")) + +(provide 'rpm-spec-mode) + +;;; rpm-spec-mode.el ends here diff --git a/site-start.el b/site-start.el index 675449a..31f9502 100644 --- a/site-start.el +++ b/site-start.el @@ -8,3 +8,18 @@ (setq interpreter-mode-alist (cons '("python" . python-mode) interpreter-mode-alist)) + +;; run functions from the /usr/share/emacs/site-lisp/site-start.d directory +;; Files in this directory ending with ".el" are run on startup + +(let (list) + (setq list (directory-files "/usr/share/emacs/site-lisp/site-start.d" t "\\.el$")) + (while list + (load-file (car list)) + (setq list (cdr list))) + ) + +;; Use the rpm-spec-mode for spec files +(require 'rpm-spec-mode) +(setq auto-mode-alist + (cons '("\\.spec$" . rpm-spec-mode) auto-mode-alist)) diff --git a/sources b/sources index cb853d7..533061c 100644 --- a/sources +++ b/sources @@ -1,3 +1,4 @@ -c732cf5e668d4ac67d9418ecb103ecf5 emacs-20.7.tar.gz -3fec03adb19038afe25345b12962ec0f emacs20-xim-20000713.tar.gz -74766f5336675ca8e951037339077c09 leim-20.7.tar.gz +2a369e104d7557991811c06f982c2ade emacs-20.7.tar.bz2 +606b7415499a88b839a7cf414e3caaa8 emacs-asian.tar.bz2 +88cf8dd2d19b973d0a77b4430a66008f gnus-5.8.8.tar.bz2 +112c8f7493ef295fc9022feb4653eab0 leim-20.7.tar.bz2