Compare commits
59 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
2f6338330a | ||
|
24d65d087d | ||
|
29b8e9dec8 | ||
|
8f058b1c85 | ||
|
615534bee5 | ||
|
e79d2e526a | ||
|
d092d213ec | ||
|
0263a47ced | ||
|
65f0c06e4b | ||
|
36be3d61d5 | ||
|
c4a21caf59 | ||
|
e4c235604e | ||
|
2c49d5d892 | ||
|
cee12ef43a | ||
|
bf1d5e8e1b | ||
|
fe829acf27 | ||
|
a3d22a1ee0 | ||
|
e6597871cb | ||
|
f8859c95d0 | ||
|
8fbb0fc07e | ||
|
49615aad35 | ||
|
6cb8c47e98 | ||
|
b9da2a30d8 | ||
|
9e413dee60 | ||
|
181aafcdb7 | ||
|
14924f48f8 | ||
|
746bf11c12 | ||
|
87fd254a44 | ||
|
1cedb94027 | ||
|
fc196308db | ||
|
ac07724a18 | ||
|
c669fb8f4d | ||
|
3485b794fc | ||
|
662bd4a9f9 | ||
|
6f367bc62e | ||
|
2a95cfd148 | ||
|
0a3be2953e | ||
|
94c9e43efe | ||
|
9f11e11b96 | ||
|
f6258eb59a | ||
|
3db109a18a | ||
|
4e7b9f195e | ||
|
b0e50ecf8b | ||
|
8e555a7028 | ||
|
ae52ac8149 | ||
|
b30910b353 | ||
|
c54edbb096 | ||
|
4331f4bc1a | ||
|
0a11a46a01 | ||
|
2d38b7a376 | ||
|
43b6a67131 | ||
|
0588f11f70 | ||
|
f71d70bf31 | ||
|
037321c00b | ||
|
3ff82ca0e7 | ||
|
fcfcb1d79c | ||
|
9e6823b900 | ||
|
fe17289e8a | ||
|
41da3cc65c |
10
.gitignore
vendored
10
.gitignore
vendored
@ -21,3 +21,13 @@
|
|||||||
/emacs-25.2-rc2.tar.xz
|
/emacs-25.2-rc2.tar.xz
|
||||||
/emacs-25.2.tar.xz
|
/emacs-25.2.tar.xz
|
||||||
/emacs-25.3.tar.xz
|
/emacs-25.3.tar.xz
|
||||||
|
/emacs-26.1.tar.xz
|
||||||
|
/emacs-26.2.tar.xz
|
||||||
|
/emacs-26.3.tar.xz
|
||||||
|
/emacs-26.3.tar.xz.sig
|
||||||
|
/emacs-27.1.tar.xz
|
||||||
|
/emacs-27.1.tar.xz.sig
|
||||||
|
/emacs-27.2.tar.xz
|
||||||
|
/emacs-27.2.tar.xz.sig
|
||||||
|
/emacs-28.1.tar.xz
|
||||||
|
/emacs-28.1.tar.xz.sig
|
707
cdefs.h
Normal file
707
cdefs.h
Normal file
@ -0,0 +1,707 @@
|
|||||||
|
/* Copyright (C) 1992-2022 Free Software Foundation, Inc.
|
||||||
|
Copyright The GNU Toolchain Authors.
|
||||||
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
The GNU C Library 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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public
|
||||||
|
License along with the GNU C Library; if not, see
|
||||||
|
<https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#ifndef _SYS_CDEFS_H
|
||||||
|
#define _SYS_CDEFS_H 1
|
||||||
|
|
||||||
|
/* We are almost always included from features.h. */
|
||||||
|
#ifndef _FEATURES_H
|
||||||
|
# include <features.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The GNU libc does not support any K&R compilers or the traditional mode
|
||||||
|
of ISO C compilers anymore. Check for some of the combinations not
|
||||||
|
supported anymore. */
|
||||||
|
#if defined __GNUC__ && !defined __STDC__
|
||||||
|
# error "You need a ISO C conforming compiler to use the glibc headers"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Some user header file might have defined this before. */
|
||||||
|
#undef __P
|
||||||
|
#undef __PMT
|
||||||
|
|
||||||
|
/* Compilers that lack __has_attribute may object to
|
||||||
|
#if defined __has_attribute && __has_attribute (...)
|
||||||
|
even though they do not need to evaluate the right-hand side of the &&.
|
||||||
|
Similarly for __has_builtin, etc. */
|
||||||
|
#if (defined __has_attribute \
|
||||||
|
&& (!defined __clang_minor__ \
|
||||||
|
|| (defined __apple_build_version__ \
|
||||||
|
? 6000000 <= __apple_build_version__ \
|
||||||
|
: 3 < __clang_major__ + (5 <= __clang_minor__))))
|
||||||
|
# define __glibc_has_attribute(attr) __has_attribute (attr)
|
||||||
|
#else
|
||||||
|
# define __glibc_has_attribute(attr) 0
|
||||||
|
#endif
|
||||||
|
#ifdef __has_builtin
|
||||||
|
# define __glibc_has_builtin(name) __has_builtin (name)
|
||||||
|
#else
|
||||||
|
# define __glibc_has_builtin(name) 0
|
||||||
|
#endif
|
||||||
|
#ifdef __has_extension
|
||||||
|
# define __glibc_has_extension(ext) __has_extension (ext)
|
||||||
|
#else
|
||||||
|
# define __glibc_has_extension(ext) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined __GNUC__ || defined __clang__
|
||||||
|
|
||||||
|
/* All functions, except those with callbacks or those that
|
||||||
|
synchronize memory, are leaf functions. */
|
||||||
|
# if __GNUC_PREREQ (4, 6) && !defined _LIBC
|
||||||
|
# define __LEAF , __leaf__
|
||||||
|
# define __LEAF_ATTR __attribute__ ((__leaf__))
|
||||||
|
# else
|
||||||
|
# define __LEAF
|
||||||
|
# define __LEAF_ATTR
|
||||||
|
# endif
|
||||||
|
|
||||||
|
/* GCC can always grok prototypes. For C++ programs we add throw()
|
||||||
|
to help it optimize the function calls. But this only works with
|
||||||
|
gcc 2.8.x and egcs. For gcc 3.4 and up we even mark C functions
|
||||||
|
as non-throwing using a function attribute since programs can use
|
||||||
|
the -fexceptions options for C code as well. */
|
||||||
|
# if !defined __cplusplus \
|
||||||
|
&& (__GNUC_PREREQ (3, 4) || __glibc_has_attribute (__nothrow__))
|
||||||
|
# define __THROW __attribute__ ((__nothrow__ __LEAF))
|
||||||
|
# define __THROWNL __attribute__ ((__nothrow__))
|
||||||
|
# define __NTH(fct) __attribute__ ((__nothrow__ __LEAF)) fct
|
||||||
|
# define __NTHNL(fct) __attribute__ ((__nothrow__)) fct
|
||||||
|
# else
|
||||||
|
# if defined __cplusplus && (__GNUC_PREREQ (2,8) || __clang_major >= 4)
|
||||||
|
# if __cplusplus >= 201103L
|
||||||
|
# define __THROW noexcept (true)
|
||||||
|
# else
|
||||||
|
# define __THROW throw ()
|
||||||
|
# endif
|
||||||
|
# define __THROWNL __THROW
|
||||||
|
# define __NTH(fct) __LEAF_ATTR fct __THROW
|
||||||
|
# define __NTHNL(fct) fct __THROW
|
||||||
|
# else
|
||||||
|
# define __THROW
|
||||||
|
# define __THROWNL
|
||||||
|
# define __NTH(fct) fct
|
||||||
|
# define __NTHNL(fct) fct
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
|
||||||
|
#else /* Not GCC or clang. */
|
||||||
|
|
||||||
|
# if (defined __cplusplus \
|
||||||
|
|| (defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L))
|
||||||
|
# define __inline inline
|
||||||
|
# else
|
||||||
|
# define __inline /* No inline functions. */
|
||||||
|
# endif
|
||||||
|
|
||||||
|
# define __THROW
|
||||||
|
# define __THROWNL
|
||||||
|
# define __NTH(fct) fct
|
||||||
|
|
||||||
|
#endif /* GCC || clang. */
|
||||||
|
|
||||||
|
/* These two macros are not used in glibc anymore. They are kept here
|
||||||
|
only because some other projects expect the macros to be defined. */
|
||||||
|
#define __P(args) args
|
||||||
|
#define __PMT(args) args
|
||||||
|
|
||||||
|
/* For these things, GCC behaves the ANSI way normally,
|
||||||
|
and the non-ANSI way under -traditional. */
|
||||||
|
|
||||||
|
#define __CONCAT(x,y) x ## y
|
||||||
|
#define __STRING(x) #x
|
||||||
|
|
||||||
|
/* This is not a typedef so `const __ptr_t' does the right thing. */
|
||||||
|
#define __ptr_t void *
|
||||||
|
|
||||||
|
|
||||||
|
/* C++ needs to know that types and declarations are C, not C++. */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
# define __BEGIN_DECLS extern "C" {
|
||||||
|
# define __END_DECLS }
|
||||||
|
#else
|
||||||
|
# define __BEGIN_DECLS
|
||||||
|
# define __END_DECLS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Fortify support. */
|
||||||
|
#define __bos(ptr) __builtin_object_size (ptr, __USE_FORTIFY_LEVEL > 1)
|
||||||
|
#define __bos0(ptr) __builtin_object_size (ptr, 0)
|
||||||
|
|
||||||
|
/* Use __builtin_dynamic_object_size at _FORTIFY_SOURCE=3 when available. */
|
||||||
|
#if __USE_FORTIFY_LEVEL == 3 && (__glibc_clang_prereq (9, 0) \
|
||||||
|
|| __GNUC_PREREQ (12, 0))
|
||||||
|
# define __glibc_objsize0(__o) __builtin_dynamic_object_size (__o, 0)
|
||||||
|
# define __glibc_objsize(__o) __builtin_dynamic_object_size (__o, 1)
|
||||||
|
#else
|
||||||
|
# define __glibc_objsize0(__o) __bos0 (__o)
|
||||||
|
# define __glibc_objsize(__o) __bos (__o)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Compile time conditions to choose between the regular, _chk and _chk_warn
|
||||||
|
variants. These conditions should get evaluated to constant and optimized
|
||||||
|
away. */
|
||||||
|
|
||||||
|
#define __glibc_safe_len_cond(__l, __s, __osz) ((__l) <= (__osz) / (__s))
|
||||||
|
#define __glibc_unsigned_or_positive(__l) \
|
||||||
|
((__typeof (__l)) 0 < (__typeof (__l)) -1 \
|
||||||
|
|| (__builtin_constant_p (__l) && (__l) > 0))
|
||||||
|
|
||||||
|
/* Length is known to be safe at compile time if the __L * __S <= __OBJSZ
|
||||||
|
condition can be folded to a constant and if it is true. The -1 check is
|
||||||
|
redundant because since it implies that __glibc_safe_len_cond is true. */
|
||||||
|
#define __glibc_safe_or_unknown_len(__l, __s, __osz) \
|
||||||
|
(__glibc_unsigned_or_positive (__l) \
|
||||||
|
&& __builtin_constant_p (__glibc_safe_len_cond ((__SIZE_TYPE__) (__l), \
|
||||||
|
__s, __osz)) \
|
||||||
|
&& __glibc_safe_len_cond ((__SIZE_TYPE__) (__l), __s, __osz))
|
||||||
|
|
||||||
|
/* Conversely, we know at compile time that the length is unsafe if the
|
||||||
|
__L * __S <= __OBJSZ condition can be folded to a constant and if it is
|
||||||
|
false. */
|
||||||
|
#define __glibc_unsafe_len(__l, __s, __osz) \
|
||||||
|
(__glibc_unsigned_or_positive (__l) \
|
||||||
|
&& __builtin_constant_p (__glibc_safe_len_cond ((__SIZE_TYPE__) (__l), \
|
||||||
|
__s, __osz)) \
|
||||||
|
&& !__glibc_safe_len_cond ((__SIZE_TYPE__) (__l), __s, __osz))
|
||||||
|
|
||||||
|
/* Fortify function f. __f_alias, __f_chk and __f_chk_warn must be
|
||||||
|
declared. */
|
||||||
|
|
||||||
|
#define __glibc_fortify(f, __l, __s, __osz, ...) \
|
||||||
|
(__glibc_safe_or_unknown_len (__l, __s, __osz) \
|
||||||
|
? __ ## f ## _alias (__VA_ARGS__) \
|
||||||
|
: (__glibc_unsafe_len (__l, __s, __osz) \
|
||||||
|
? __ ## f ## _chk_warn (__VA_ARGS__, __osz) \
|
||||||
|
: __ ## f ## _chk (__VA_ARGS__, __osz))) \
|
||||||
|
|
||||||
|
/* Fortify function f, where object size argument passed to f is the number of
|
||||||
|
elements and not total size. */
|
||||||
|
|
||||||
|
#define __glibc_fortify_n(f, __l, __s, __osz, ...) \
|
||||||
|
(__glibc_safe_or_unknown_len (__l, __s, __osz) \
|
||||||
|
? __ ## f ## _alias (__VA_ARGS__) \
|
||||||
|
: (__glibc_unsafe_len (__l, __s, __osz) \
|
||||||
|
? __ ## f ## _chk_warn (__VA_ARGS__, (__osz) / (__s)) \
|
||||||
|
: __ ## f ## _chk (__VA_ARGS__, (__osz) / (__s)))) \
|
||||||
|
|
||||||
|
#if __GNUC_PREREQ (4,3)
|
||||||
|
# define __warnattr(msg) __attribute__((__warning__ (msg)))
|
||||||
|
# define __errordecl(name, msg) \
|
||||||
|
extern void name (void) __attribute__((__error__ (msg)))
|
||||||
|
#else
|
||||||
|
# define __warnattr(msg)
|
||||||
|
# define __errordecl(name, msg) extern void name (void)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Support for flexible arrays.
|
||||||
|
Headers that should use flexible arrays only if they're "real"
|
||||||
|
(e.g. only if they won't affect sizeof()) should test
|
||||||
|
#if __glibc_c99_flexarr_available. */
|
||||||
|
#if defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L && !defined __HP_cc
|
||||||
|
# define __flexarr []
|
||||||
|
# define __glibc_c99_flexarr_available 1
|
||||||
|
#elif __GNUC_PREREQ (2,97) || defined __clang__
|
||||||
|
/* GCC 2.97 and clang support C99 flexible array members as an extension,
|
||||||
|
even when in C89 mode or compiling C++ (any version). */
|
||||||
|
# define __flexarr []
|
||||||
|
# define __glibc_c99_flexarr_available 1
|
||||||
|
#elif defined __GNUC__
|
||||||
|
/* Pre-2.97 GCC did not support C99 flexible arrays but did have
|
||||||
|
an equivalent extension with slightly different notation. */
|
||||||
|
# define __flexarr [0]
|
||||||
|
# define __glibc_c99_flexarr_available 1
|
||||||
|
#else
|
||||||
|
/* Some other non-C99 compiler. Approximate with [1]. */
|
||||||
|
# define __flexarr [1]
|
||||||
|
# define __glibc_c99_flexarr_available 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* __asm__ ("xyz") is used throughout the headers to rename functions
|
||||||
|
at the assembly language level. This is wrapped by the __REDIRECT
|
||||||
|
macro, in order to support compilers that can do this some other
|
||||||
|
way. When compilers don't support asm-names at all, we have to do
|
||||||
|
preprocessor tricks instead (which don't have exactly the right
|
||||||
|
semantics, but it's the best we can do).
|
||||||
|
|
||||||
|
Example:
|
||||||
|
int __REDIRECT(setpgrp, (__pid_t pid, __pid_t pgrp), setpgid); */
|
||||||
|
|
||||||
|
#if (defined __GNUC__ && __GNUC__ >= 2) || (__clang_major__ >= 4)
|
||||||
|
|
||||||
|
# define __REDIRECT(name, proto, alias) name proto __asm__ (__ASMNAME (#alias))
|
||||||
|
# ifdef __cplusplus
|
||||||
|
# define __REDIRECT_NTH(name, proto, alias) \
|
||||||
|
name proto __THROW __asm__ (__ASMNAME (#alias))
|
||||||
|
# define __REDIRECT_NTHNL(name, proto, alias) \
|
||||||
|
name proto __THROWNL __asm__ (__ASMNAME (#alias))
|
||||||
|
# else
|
||||||
|
# define __REDIRECT_NTH(name, proto, alias) \
|
||||||
|
name proto __asm__ (__ASMNAME (#alias)) __THROW
|
||||||
|
# define __REDIRECT_NTHNL(name, proto, alias) \
|
||||||
|
name proto __asm__ (__ASMNAME (#alias)) __THROWNL
|
||||||
|
# endif
|
||||||
|
# define __ASMNAME(cname) __ASMNAME2 (__USER_LABEL_PREFIX__, cname)
|
||||||
|
# define __ASMNAME2(prefix, cname) __STRING (prefix) cname
|
||||||
|
|
||||||
|
/*
|
||||||
|
#elif __SOME_OTHER_COMPILER__
|
||||||
|
|
||||||
|
# define __REDIRECT(name, proto, alias) name proto; \
|
||||||
|
_Pragma("let " #name " = " #alias)
|
||||||
|
*/
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GCC and clang have various useful declarations that can be made with
|
||||||
|
the '__attribute__' syntax. All of the ways we use this do fine if
|
||||||
|
they are omitted for compilers that don't understand it. */
|
||||||
|
#if !(defined __GNUC__ || defined __clang__)
|
||||||
|
# define __attribute__(xyz) /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* At some point during the gcc 2.96 development the `malloc' attribute
|
||||||
|
for functions was introduced. We don't want to use it unconditionally
|
||||||
|
(although this would be possible) since it generates warnings. */
|
||||||
|
#if __GNUC_PREREQ (2,96) || __glibc_has_attribute (__malloc__)
|
||||||
|
# define __attribute_malloc__ __attribute__ ((__malloc__))
|
||||||
|
#else
|
||||||
|
# define __attribute_malloc__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Tell the compiler which arguments to an allocation function
|
||||||
|
indicate the size of the allocation. */
|
||||||
|
#if __GNUC_PREREQ (4, 3)
|
||||||
|
# define __attribute_alloc_size__(params) \
|
||||||
|
__attribute__ ((__alloc_size__ params))
|
||||||
|
#else
|
||||||
|
# define __attribute_alloc_size__(params) /* Ignore. */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Tell the compiler which argument to an allocation function
|
||||||
|
indicates the alignment of the allocation. */
|
||||||
|
#if __GNUC_PREREQ (4, 9) || __glibc_has_attribute (__alloc_align__)
|
||||||
|
# define __attribute_alloc_align__(param) \
|
||||||
|
__attribute__ ((__alloc_align__ param))
|
||||||
|
#else
|
||||||
|
# define __attribute_alloc_align__(param) /* Ignore. */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* At some point during the gcc 2.96 development the `pure' attribute
|
||||||
|
for functions was introduced. We don't want to use it unconditionally
|
||||||
|
(although this would be possible) since it generates warnings. */
|
||||||
|
#if __GNUC_PREREQ (2,96) || __glibc_has_attribute (__pure__)
|
||||||
|
# define __attribute_pure__ __attribute__ ((__pure__))
|
||||||
|
#else
|
||||||
|
# define __attribute_pure__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This declaration tells the compiler that the value is constant. */
|
||||||
|
#if __GNUC_PREREQ (2,5) || __glibc_has_attribute (__const__)
|
||||||
|
# define __attribute_const__ __attribute__ ((__const__))
|
||||||
|
#else
|
||||||
|
# define __attribute_const__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __GNUC_PREREQ (2,7) || __glibc_has_attribute (__unused__)
|
||||||
|
# define __attribute_maybe_unused__ __attribute__ ((__unused__))
|
||||||
|
#else
|
||||||
|
# define __attribute_maybe_unused__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* At some point during the gcc 3.1 development the `used' attribute
|
||||||
|
for functions was introduced. We don't want to use it unconditionally
|
||||||
|
(although this would be possible) since it generates warnings. */
|
||||||
|
#if __GNUC_PREREQ (3,1) || __glibc_has_attribute (__used__)
|
||||||
|
# define __attribute_used__ __attribute__ ((__used__))
|
||||||
|
# define __attribute_noinline__ __attribute__ ((__noinline__))
|
||||||
|
#else
|
||||||
|
# define __attribute_used__ __attribute__ ((__unused__))
|
||||||
|
# define __attribute_noinline__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Since version 3.2, gcc allows marking deprecated functions. */
|
||||||
|
#if __GNUC_PREREQ (3,2) || __glibc_has_attribute (__deprecated__)
|
||||||
|
# define __attribute_deprecated__ __attribute__ ((__deprecated__))
|
||||||
|
#else
|
||||||
|
# define __attribute_deprecated__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Since version 4.5, gcc also allows one to specify the message printed
|
||||||
|
when a deprecated function is used. clang claims to be gcc 4.2, but
|
||||||
|
may also support this feature. */
|
||||||
|
#if __GNUC_PREREQ (4,5) \
|
||||||
|
|| __glibc_has_extension (__attribute_deprecated_with_message__)
|
||||||
|
# define __attribute_deprecated_msg__(msg) \
|
||||||
|
__attribute__ ((__deprecated__ (msg)))
|
||||||
|
#else
|
||||||
|
# define __attribute_deprecated_msg__(msg) __attribute_deprecated__
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* At some point during the gcc 2.8 development the `format_arg' attribute
|
||||||
|
for functions was introduced. We don't want to use it unconditionally
|
||||||
|
(although this would be possible) since it generates warnings.
|
||||||
|
If several `format_arg' attributes are given for the same function, in
|
||||||
|
gcc-3.0 and older, all but the last one are ignored. In newer gccs,
|
||||||
|
all designated arguments are considered. */
|
||||||
|
#if __GNUC_PREREQ (2,8) || __glibc_has_attribute (__format_arg__)
|
||||||
|
# define __attribute_format_arg__(x) __attribute__ ((__format_arg__ (x)))
|
||||||
|
#else
|
||||||
|
# define __attribute_format_arg__(x) /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* At some point during the gcc 2.97 development the `strfmon' format
|
||||||
|
attribute for functions was introduced. We don't want to use it
|
||||||
|
unconditionally (although this would be possible) since it
|
||||||
|
generates warnings. */
|
||||||
|
#if __GNUC_PREREQ (2,97) || __glibc_has_attribute (__format__)
|
||||||
|
# define __attribute_format_strfmon__(a,b) \
|
||||||
|
__attribute__ ((__format__ (__strfmon__, a, b)))
|
||||||
|
#else
|
||||||
|
# define __attribute_format_strfmon__(a,b) /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The nonnull function attribute marks pointer parameters that
|
||||||
|
must not be NULL. This has the name __nonnull in glibc,
|
||||||
|
and __attribute_nonnull__ in files shared with Gnulib to avoid
|
||||||
|
collision with a different __nonnull in DragonFlyBSD 5.9. */
|
||||||
|
#ifndef __attribute_nonnull__
|
||||||
|
# if __GNUC_PREREQ (3,3) || __glibc_has_attribute (__nonnull__)
|
||||||
|
# define __attribute_nonnull__(params) __attribute__ ((__nonnull__ params))
|
||||||
|
# else
|
||||||
|
# define __attribute_nonnull__(params)
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#ifndef __nonnull
|
||||||
|
# define __nonnull(params) __attribute_nonnull__ (params)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The returns_nonnull function attribute marks the return type of the function
|
||||||
|
as always being non-null. */
|
||||||
|
#ifndef __returns_nonnull
|
||||||
|
# if __GNUC_PREREQ (4, 9) || __glibc_has_attribute (__returns_nonnull__)
|
||||||
|
# define __returns_nonnull __attribute__ ((__returns_nonnull__))
|
||||||
|
# else
|
||||||
|
# define __returns_nonnull
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* If fortification mode, we warn about unused results of certain
|
||||||
|
function calls which can lead to problems. */
|
||||||
|
#if __GNUC_PREREQ (3,4) || __glibc_has_attribute (__warn_unused_result__)
|
||||||
|
# define __attribute_warn_unused_result__ \
|
||||||
|
__attribute__ ((__warn_unused_result__))
|
||||||
|
# if defined __USE_FORTIFY_LEVEL && __USE_FORTIFY_LEVEL > 0
|
||||||
|
# define __wur __attribute_warn_unused_result__
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# define __attribute_warn_unused_result__ /* empty */
|
||||||
|
#endif
|
||||||
|
#ifndef __wur
|
||||||
|
# define __wur /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Forces a function to be always inlined. */
|
||||||
|
#if __GNUC_PREREQ (3,2) || __glibc_has_attribute (__always_inline__)
|
||||||
|
/* The Linux kernel defines __always_inline in stddef.h (283d7573), and
|
||||||
|
it conflicts with this definition. Therefore undefine it first to
|
||||||
|
allow either header to be included first. */
|
||||||
|
# undef __always_inline
|
||||||
|
# define __always_inline __inline __attribute__ ((__always_inline__))
|
||||||
|
#else
|
||||||
|
# undef __always_inline
|
||||||
|
# define __always_inline __inline
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Associate error messages with the source location of the call site rather
|
||||||
|
than with the source location inside the function. */
|
||||||
|
#if __GNUC_PREREQ (4,3) || __glibc_has_attribute (__artificial__)
|
||||||
|
# define __attribute_artificial__ __attribute__ ((__artificial__))
|
||||||
|
#else
|
||||||
|
# define __attribute_artificial__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GCC 4.3 and above with -std=c99 or -std=gnu99 implements ISO C99
|
||||||
|
inline semantics, unless -fgnu89-inline is used. Using __GNUC_STDC_INLINE__
|
||||||
|
or __GNUC_GNU_INLINE is not a good enough check for gcc because gcc versions
|
||||||
|
older than 4.3 may define these macros and still not guarantee GNU inlining
|
||||||
|
semantics.
|
||||||
|
|
||||||
|
clang++ identifies itself as gcc-4.2, but has support for GNU inlining
|
||||||
|
semantics, that can be checked for by using the __GNUC_STDC_INLINE_ and
|
||||||
|
__GNUC_GNU_INLINE__ macro definitions. */
|
||||||
|
#if (!defined __cplusplus || __GNUC_PREREQ (4,3) \
|
||||||
|
|| (defined __clang__ && (defined __GNUC_STDC_INLINE__ \
|
||||||
|
|| defined __GNUC_GNU_INLINE__)))
|
||||||
|
# if defined __GNUC_STDC_INLINE__ || defined __cplusplus
|
||||||
|
# define __extern_inline extern __inline __attribute__ ((__gnu_inline__))
|
||||||
|
# define __extern_always_inline \
|
||||||
|
extern __always_inline __attribute__ ((__gnu_inline__))
|
||||||
|
# else
|
||||||
|
# define __extern_inline extern __inline
|
||||||
|
# define __extern_always_inline extern __always_inline
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __extern_always_inline
|
||||||
|
# define __fortify_function __extern_always_inline __attribute_artificial__
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GCC 4.3 and above allow passing all anonymous arguments of an
|
||||||
|
__extern_always_inline function to some other vararg function. */
|
||||||
|
#if __GNUC_PREREQ (4,3)
|
||||||
|
# define __va_arg_pack() __builtin_va_arg_pack ()
|
||||||
|
# define __va_arg_pack_len() __builtin_va_arg_pack_len ()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* It is possible to compile containing GCC extensions even if GCC is
|
||||||
|
run in pedantic mode if the uses are carefully marked using the
|
||||||
|
`__extension__' keyword. But this is not generally available before
|
||||||
|
version 2.8. */
|
||||||
|
#if !(__GNUC_PREREQ (2,8) || defined __clang__)
|
||||||
|
# define __extension__ /* Ignore */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* __restrict is known in EGCS 1.2 and above, and in clang.
|
||||||
|
It works also in C++ mode (outside of arrays), but only when spelled
|
||||||
|
as '__restrict', not 'restrict'. */
|
||||||
|
#if !(__GNUC_PREREQ (2,92) || __clang_major__ >= 3)
|
||||||
|
# if defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L
|
||||||
|
# define __restrict restrict
|
||||||
|
# else
|
||||||
|
# define __restrict /* Ignore */
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* ISO C99 also allows to declare arrays as non-overlapping. The syntax is
|
||||||
|
array_name[restrict]
|
||||||
|
GCC 3.1 and clang support this.
|
||||||
|
This syntax is not usable in C++ mode. */
|
||||||
|
#if (__GNUC_PREREQ (3,1) || __clang_major__ >= 3) && !defined __cplusplus
|
||||||
|
# define __restrict_arr __restrict
|
||||||
|
#else
|
||||||
|
# ifdef __GNUC__
|
||||||
|
# define __restrict_arr /* Not supported in old GCC. */
|
||||||
|
# else
|
||||||
|
# if defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L
|
||||||
|
# define __restrict_arr restrict
|
||||||
|
# else
|
||||||
|
/* Some other non-C99 compiler. */
|
||||||
|
# define __restrict_arr /* Not supported. */
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (__GNUC__ >= 3) || __glibc_has_builtin (__builtin_expect)
|
||||||
|
# define __glibc_unlikely(cond) __builtin_expect ((cond), 0)
|
||||||
|
# define __glibc_likely(cond) __builtin_expect ((cond), 1)
|
||||||
|
#else
|
||||||
|
# define __glibc_unlikely(cond) (cond)
|
||||||
|
# define __glibc_likely(cond) (cond)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (!defined _Noreturn \
|
||||||
|
&& (defined __STDC_VERSION__ ? __STDC_VERSION__ : 0) < 201112 \
|
||||||
|
&& !(__GNUC_PREREQ (4,7) \
|
||||||
|
|| (3 < __clang_major__ + (5 <= __clang_minor__))))
|
||||||
|
# if __GNUC_PREREQ (2,8)
|
||||||
|
# define _Noreturn __attribute__ ((__noreturn__))
|
||||||
|
# else
|
||||||
|
# define _Noreturn
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __GNUC_PREREQ (8, 0)
|
||||||
|
/* Describes a char array whose address can safely be passed as the first
|
||||||
|
argument to strncpy and strncat, as the char array is not necessarily
|
||||||
|
a NUL-terminated string. */
|
||||||
|
# define __attribute_nonstring__ __attribute__ ((__nonstring__))
|
||||||
|
#else
|
||||||
|
# define __attribute_nonstring__
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Undefine (also defined in libc-symbols.h). */
|
||||||
|
#undef __attribute_copy__
|
||||||
|
#if __GNUC_PREREQ (9, 0)
|
||||||
|
/* Copies attributes from the declaration or type referenced by
|
||||||
|
the argument. */
|
||||||
|
# define __attribute_copy__(arg) __attribute__ ((__copy__ (arg)))
|
||||||
|
#else
|
||||||
|
# define __attribute_copy__(arg)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (!defined _Static_assert && !defined __cplusplus \
|
||||||
|
&& (defined __STDC_VERSION__ ? __STDC_VERSION__ : 0) < 201112 \
|
||||||
|
&& (!(__GNUC_PREREQ (4, 6) || __clang_major__ >= 4) \
|
||||||
|
|| defined __STRICT_ANSI__))
|
||||||
|
# define _Static_assert(expr, diagnostic) \
|
||||||
|
extern int (*__Static_assert_function (void)) \
|
||||||
|
[!!sizeof (struct { int __error_if_negative: (expr) ? 2 : -1; })]
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Gnulib avoids including these, as they don't work on non-glibc or
|
||||||
|
older glibc platforms. */
|
||||||
|
#ifndef __GNULIB_CDEFS
|
||||||
|
# include <bits/wordsize.h>
|
||||||
|
# include <bits/long-double.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __LDOUBLE_REDIRECTS_TO_FLOAT128_ABI == 1
|
||||||
|
# ifdef __REDIRECT
|
||||||
|
|
||||||
|
/* Alias name defined automatically. */
|
||||||
|
# define __LDBL_REDIR(name, proto) ... unused__ldbl_redir
|
||||||
|
# define __LDBL_REDIR_DECL(name) \
|
||||||
|
extern __typeof (name) name __asm (__ASMNAME ("__" #name "ieee128"));
|
||||||
|
|
||||||
|
/* Alias name defined automatically, with leading underscores. */
|
||||||
|
# define __LDBL_REDIR2_DECL(name) \
|
||||||
|
extern __typeof (__##name) __##name \
|
||||||
|
__asm (__ASMNAME ("__" #name "ieee128"));
|
||||||
|
|
||||||
|
/* Alias name defined manually. */
|
||||||
|
# define __LDBL_REDIR1(name, proto, alias) ... unused__ldbl_redir1
|
||||||
|
# define __LDBL_REDIR1_DECL(name, alias) \
|
||||||
|
extern __typeof (name) name __asm (__ASMNAME (#alias));
|
||||||
|
|
||||||
|
# define __LDBL_REDIR1_NTH(name, proto, alias) \
|
||||||
|
__REDIRECT_NTH (name, proto, alias)
|
||||||
|
# define __REDIRECT_NTH_LDBL(name, proto, alias) \
|
||||||
|
__LDBL_REDIR1_NTH (name, proto, __##alias##ieee128)
|
||||||
|
|
||||||
|
/* Unused. */
|
||||||
|
# define __REDIRECT_LDBL(name, proto, alias) ... unused__redirect_ldbl
|
||||||
|
# define __LDBL_REDIR_NTH(name, proto) ... unused__ldbl_redir_nth
|
||||||
|
|
||||||
|
# else
|
||||||
|
_Static_assert (0, "IEEE 128-bits long double requires redirection on this platform");
|
||||||
|
# endif
|
||||||
|
#elif defined __LONG_DOUBLE_MATH_OPTIONAL && defined __NO_LONG_DOUBLE_MATH
|
||||||
|
# define __LDBL_COMPAT 1
|
||||||
|
# ifdef __REDIRECT
|
||||||
|
# define __LDBL_REDIR1(name, proto, alias) __REDIRECT (name, proto, alias)
|
||||||
|
# define __LDBL_REDIR(name, proto) \
|
||||||
|
__LDBL_REDIR1 (name, proto, __nldbl_##name)
|
||||||
|
# define __LDBL_REDIR1_NTH(name, proto, alias) __REDIRECT_NTH (name, proto, alias)
|
||||||
|
# define __LDBL_REDIR_NTH(name, proto) \
|
||||||
|
__LDBL_REDIR1_NTH (name, proto, __nldbl_##name)
|
||||||
|
# define __LDBL_REDIR2_DECL(name) \
|
||||||
|
extern __typeof (__##name) __##name __asm (__ASMNAME ("__nldbl___" #name));
|
||||||
|
# define __LDBL_REDIR1_DECL(name, alias) \
|
||||||
|
extern __typeof (name) name __asm (__ASMNAME (#alias));
|
||||||
|
# define __LDBL_REDIR_DECL(name) \
|
||||||
|
extern __typeof (name) name __asm (__ASMNAME ("__nldbl_" #name));
|
||||||
|
# define __REDIRECT_LDBL(name, proto, alias) \
|
||||||
|
__LDBL_REDIR1 (name, proto, __nldbl_##alias)
|
||||||
|
# define __REDIRECT_NTH_LDBL(name, proto, alias) \
|
||||||
|
__LDBL_REDIR1_NTH (name, proto, __nldbl_##alias)
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#if (!defined __LDBL_COMPAT && __LDOUBLE_REDIRECTS_TO_FLOAT128_ABI == 0) \
|
||||||
|
|| !defined __REDIRECT
|
||||||
|
# define __LDBL_REDIR1(name, proto, alias) name proto
|
||||||
|
# define __LDBL_REDIR(name, proto) name proto
|
||||||
|
# define __LDBL_REDIR1_NTH(name, proto, alias) name proto __THROW
|
||||||
|
# define __LDBL_REDIR_NTH(name, proto) name proto __THROW
|
||||||
|
# define __LDBL_REDIR2_DECL(name)
|
||||||
|
# define __LDBL_REDIR_DECL(name)
|
||||||
|
# ifdef __REDIRECT
|
||||||
|
# define __REDIRECT_LDBL(name, proto, alias) __REDIRECT (name, proto, alias)
|
||||||
|
# define __REDIRECT_NTH_LDBL(name, proto, alias) \
|
||||||
|
__REDIRECT_NTH (name, proto, alias)
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* __glibc_macro_warning (MESSAGE) issues warning MESSAGE. This is
|
||||||
|
intended for use in preprocessor macros.
|
||||||
|
|
||||||
|
Note: MESSAGE must be a _single_ string; concatenation of string
|
||||||
|
literals is not supported. */
|
||||||
|
#if __GNUC_PREREQ (4,8) || __glibc_clang_prereq (3,5)
|
||||||
|
# define __glibc_macro_warning1(message) _Pragma (#message)
|
||||||
|
# define __glibc_macro_warning(message) \
|
||||||
|
__glibc_macro_warning1 (GCC warning message)
|
||||||
|
#else
|
||||||
|
# define __glibc_macro_warning(msg)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Generic selection (ISO C11) is a C-only feature, available in GCC
|
||||||
|
since version 4.9. Previous versions do not provide generic
|
||||||
|
selection, even though they might set __STDC_VERSION__ to 201112L,
|
||||||
|
when in -std=c11 mode. Thus, we must check for !defined __GNUC__
|
||||||
|
when testing __STDC_VERSION__ for generic selection support.
|
||||||
|
On the other hand, Clang also defines __GNUC__, so a clang-specific
|
||||||
|
check is required to enable the use of generic selection. */
|
||||||
|
#if !defined __cplusplus \
|
||||||
|
&& (__GNUC_PREREQ (4, 9) \
|
||||||
|
|| __glibc_has_extension (c_generic_selections) \
|
||||||
|
|| (!defined __GNUC__ && defined __STDC_VERSION__ \
|
||||||
|
&& __STDC_VERSION__ >= 201112L))
|
||||||
|
# define __HAVE_GENERIC_SELECTION 1
|
||||||
|
#else
|
||||||
|
# define __HAVE_GENERIC_SELECTION 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __GNUC_PREREQ (10, 0)
|
||||||
|
/* Designates a 1-based positional argument ref-index of pointer type
|
||||||
|
that can be used to access size-index elements of the pointed-to
|
||||||
|
array according to access mode, or at least one element when
|
||||||
|
size-index is not provided:
|
||||||
|
access (access-mode, <ref-index> [, <size-index>]) */
|
||||||
|
# define __attr_access(x) __attribute__ ((__access__ x))
|
||||||
|
/* For _FORTIFY_SOURCE == 3 we use __builtin_dynamic_object_size, which may
|
||||||
|
use the access attribute to get object sizes from function definition
|
||||||
|
arguments, so we can't use them on functions we fortify. Drop the object
|
||||||
|
size hints for such functions. */
|
||||||
|
# if __USE_FORTIFY_LEVEL == 3
|
||||||
|
# define __fortified_attr_access(a, o, s) __attribute__ ((__access__ (a, o)))
|
||||||
|
# else
|
||||||
|
# define __fortified_attr_access(a, o, s) __attr_access ((a, o, s))
|
||||||
|
# endif
|
||||||
|
# if __GNUC_PREREQ (11, 0)
|
||||||
|
# define __attr_access_none(argno) __attribute__ ((__access__ (__none__, argno)))
|
||||||
|
# else
|
||||||
|
# define __attr_access_none(argno)
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# define __fortified_attr_access(a, o, s)
|
||||||
|
# define __attr_access(x)
|
||||||
|
# define __attr_access_none(argno)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __GNUC_PREREQ (11, 0)
|
||||||
|
/* Designates dealloc as a function to call to deallocate objects
|
||||||
|
allocated by the declared function. */
|
||||||
|
# define __attr_dealloc(dealloc, argno) \
|
||||||
|
__attribute__ ((__malloc__ (dealloc, argno)))
|
||||||
|
# define __attr_dealloc_free __attr_dealloc (__builtin_free, 1)
|
||||||
|
#else
|
||||||
|
# define __attr_dealloc(dealloc, argno)
|
||||||
|
# define __attr_dealloc_free
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Specify that a function such as setjmp or vfork may return
|
||||||
|
twice. */
|
||||||
|
#if __GNUC_PREREQ (4, 1)
|
||||||
|
# define __attribute_returns_twice__ __attribute__ ((__returns_twice__))
|
||||||
|
#else
|
||||||
|
# define __attribute_returns_twice__ /* Ignore. */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* sys/cdefs.h */
|
31
emacs-libdir-vs-systemd.patch
Normal file
31
emacs-libdir-vs-systemd.patch
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
From a56539c1d7ef7aa56e575685bdfe1406aebb518d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Peter Oliver <git@mavit.org.uk>
|
||||||
|
Date: Wed, 5 Feb 2020 12:42:04 +0000
|
||||||
|
Subject: [PATCH] =?UTF-8?q?Don=E2=80=99t=20assemble=20systemdunitdir=20fro?=
|
||||||
|
=?UTF-8?q?m=20`libdir`?=
|
||||||
|
MIME-Version: 1.0
|
||||||
|
Content-Type: text/plain; charset=UTF-8
|
||||||
|
Content-Transfer-Encoding: 8bit
|
||||||
|
|
||||||
|
On 64 bit Fedora, `libdir` is `/usr/lib64`, whereas systemd services
|
||||||
|
live under `/usr/lib/systemd`.
|
||||||
|
---
|
||||||
|
Makefile.in | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile.in b/Makefile.in
|
||||||
|
index 2c82c49fba..b2468eb824 100644
|
||||||
|
--- a/Makefile.in
|
||||||
|
+++ b/Makefile.in
|
||||||
|
@@ -208,7 +208,7 @@ appdatadir=
|
||||||
|
# Other options include ~/.config/systemd/user/,
|
||||||
|
# $XDG_RUNTIME_DIR/systemd/user/
|
||||||
|
# It seems the user may end up having to make a manual link...
|
||||||
|
-systemdunitdir=$(libdir)/systemd/user
|
||||||
|
+systemdunitdir=$(shell pkg-config --variable=systemduserunitdir systemd)
|
||||||
|
|
||||||
|
# Where the etc/images/icons/hicolor directory is to be installed.
|
||||||
|
icondir=$(datarootdir)/icons
|
||||||
|
--
|
||||||
|
2.24.1
|
||||||
|
|
@ -1,13 +0,0 @@
|
|||||||
diff --git a/lisp/org/org.el b/lisp/org/org.el
|
|
||||||
index 2b5603c..52545d0 100644
|
|
||||||
--- a/lisp/org/org.el
|
|
||||||
+++ b/lisp/org/org.el
|
|
||||||
@@ -1963,7 +1963,7 @@ See `org-file-apps'.")
|
|
||||||
'((auto-mode . emacs)
|
|
||||||
("\\.mm\\'" . default)
|
|
||||||
("\\.x?html?\\'" . default)
|
|
||||||
- ("\\.pdf\\'" . default))
|
|
||||||
+ ("\\.pdf\\'" . xdg-open))
|
|
||||||
"External applications for opening `file:path' items in a document.
|
|
||||||
Org-mode uses system defaults for different file types, but
|
|
||||||
you can use this variable to set the application for a given file
|
|
171
emacs-pdmp-fingerprint.patch
Normal file
171
emacs-pdmp-fingerprint.patch
Normal file
@ -0,0 +1,171 @@
|
|||||||
|
From e81f1faca4382ed5c8f15fec84fb7c900a5468f9 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Glenn Morris <rgm@gnu.org>
|
||||||
|
Date: Mon, 11 Oct 2021 14:03:26 +0200
|
||||||
|
Subject: Make the installed pmdp file use a fingerprint
|
||||||
|
|
||||||
|
* Makefile.in (EMACS_PDMP): Use --fingerprint.
|
||||||
|
|
||||||
|
* doc/emacs/cmdargs.texi (Action Arguments): Document --fingerprint.
|
||||||
|
|
||||||
|
* src/emacs.c (load_pdump): Load the fingerprinted version of the
|
||||||
|
pdmp file (bug#42790).
|
||||||
|
(main): Support --fingerprint.
|
||||||
|
|
||||||
|
* src/pdumper.c (dump_fingerprint): Make non-static.
|
||||||
|
|
||||||
|
* src/pdumper.h: Declare dump_fingerprint.
|
||||||
|
---
|
||||||
|
Makefile.in | 3 ++-
|
||||||
|
doc/emacs/cmdargs.texi | 5 +++++
|
||||||
|
src/emacs.c | 31 +++++++++++++++++++++++++++++--
|
||||||
|
src/pdumper.c | 2 +-
|
||||||
|
src/pdumper.h | 3 +++
|
||||||
|
5 files changed, 40 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile.in b/Makefile.in
|
||||||
|
index 5fc1edc..c6c507f 100644
|
||||||
|
--- a/Makefile.in
|
||||||
|
+++ b/Makefile.in
|
||||||
|
@@ -313,6 +313,7 @@ TRANSFORM = @program_transform_name@
|
||||||
|
EMACS_NAME = `echo emacs | sed '$(TRANSFORM)'`
|
||||||
|
EMACS = ${EMACS_NAME}${EXEEXT}
|
||||||
|
EMACSFULL = `echo emacs-${version} | sed '$(TRANSFORM)'`${EXEEXT}
|
||||||
|
+EMACS_PDMP = `./src/emacs${EXEEXT} --fingerprint 2>&1 | sed 's/.* //'`.pdmp
|
||||||
|
|
||||||
|
# Subdirectories to make recursively.
|
||||||
|
SUBDIR = $(NTDIR) lib lib-src src lisp
|
||||||
|
@@ -521,7 +522,7 @@ install-arch-dep: src install-arch-indep install-etcdoc install-$(NTDIR)
|
||||||
|
ifeq (${ns_self_contained},no)
|
||||||
|
${INSTALL_PROGRAM} $(INSTALL_STRIP) src/emacs${EXEEXT} "$(DESTDIR)${bindir}/$(EMACSFULL)"
|
||||||
|
ifeq (${DUMPING},pdumper)
|
||||||
|
- ${INSTALL_DATA} src/emacs.pdmp "$(DESTDIR)${libexecdir}/emacs/${version}/${configuration}"/emacs.pdmp
|
||||||
|
+ ${INSTALL_DATA} src/emacs.pdmp "$(DESTDIR)${libexecdir}/emacs/${version}/${configuration}"/emacs-${EMACS_PDMP}
|
||||||
|
endif
|
||||||
|
-chmod 755 "$(DESTDIR)${bindir}/$(EMACSFULL)"
|
||||||
|
ifndef NO_BIN_LINK
|
||||||
|
diff --git a/doc/emacs/cmdargs.texi b/doc/emacs/cmdargs.texi
|
||||||
|
index d5177fa..313682b 100644
|
||||||
|
--- a/doc/emacs/cmdargs.texi
|
||||||
|
+++ b/doc/emacs/cmdargs.texi
|
||||||
|
@@ -185,6 +185,11 @@ successfully.
|
||||||
|
@item --version
|
||||||
|
@opindex --version
|
||||||
|
Print Emacs version, then exit successfully.
|
||||||
|
+
|
||||||
|
+@item --fingerprint
|
||||||
|
+@opindex --fingerprint
|
||||||
|
+Print the Emacs ``fingerprint'', which is used to uniquely identify
|
||||||
|
+the compiled version of Emacs.
|
||||||
|
@end table
|
||||||
|
|
||||||
|
@node Initial Options
|
||||||
|
diff --git a/src/emacs.c b/src/emacs.c
|
||||||
|
index 866e43f..cda7a9b 100644
|
||||||
|
--- a/src/emacs.c
|
||||||
|
+++ b/src/emacs.c
|
||||||
|
@@ -133,6 +133,7 @@ extern char etext;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "pdumper.h"
|
||||||
|
+#include "fingerprint.h"
|
||||||
|
#include "epaths.h"
|
||||||
|
|
||||||
|
static const char emacs_version[] = PACKAGE_VERSION;
|
||||||
|
@@ -255,6 +256,7 @@ Initialization options:\n\
|
||||||
|
#ifdef HAVE_PDUMPER
|
||||||
|
"\
|
||||||
|
--dump-file FILE read dumped state from FILE\n\
|
||||||
|
+--fingerprint output fingerprint and exit\n\
|
||||||
|
",
|
||||||
|
#endif
|
||||||
|
#if SECCOMP_USABLE
|
||||||
|
@@ -830,6 +832,8 @@ load_pdump (int argc, char **argv)
|
||||||
|
const char *const suffix = ".pdmp";
|
||||||
|
int result;
|
||||||
|
char *emacs_executable = argv[0];
|
||||||
|
+ ptrdiff_t hexbuf_size;
|
||||||
|
+ char *hexbuf;
|
||||||
|
const char *strip_suffix =
|
||||||
|
#if defined DOS_NT || defined CYGWIN
|
||||||
|
".exe"
|
||||||
|
@@ -927,9 +931,15 @@ load_pdump (int argc, char **argv)
|
||||||
|
/* Look for "emacs.pdmp" in PATH_EXEC. We hardcode "emacs" in
|
||||||
|
"emacs.pdmp" so that the Emacs binary still works if the user
|
||||||
|
copies and renames it. */
|
||||||
|
+ hexbuf_size = 2 * sizeof fingerprint;
|
||||||
|
+ hexbuf = xmalloc (hexbuf_size + 1);
|
||||||
|
+ hexbuf_digest (hexbuf, (char *)fingerprint, sizeof fingerprint);
|
||||||
|
+ hexbuf[hexbuf_size] = '\0';
|
||||||
|
needed = (strlen (path_exec)
|
||||||
|
+ 1
|
||||||
|
+ strlen (argv0_base)
|
||||||
|
+ + 1
|
||||||
|
+ + strlen (hexbuf)
|
||||||
|
+ strlen (suffix)
|
||||||
|
+ 1);
|
||||||
|
if (bufsize < needed)
|
||||||
|
@@ -937,8 +947,8 @@ load_pdump (int argc, char **argv)
|
||||||
|
xfree (dump_file);
|
||||||
|
dump_file = xpalloc (NULL, &bufsize, needed - bufsize, -1, 1);
|
||||||
|
}
|
||||||
|
- sprintf (dump_file, "%s%c%s%s",
|
||||||
|
- path_exec, DIRECTORY_SEP, argv0_base, suffix);
|
||||||
|
+ sprintf (dump_file, "%s%c%s-%s%s",
|
||||||
|
+ path_exec, DIRECTORY_SEP, argv0_base, hexbuf, suffix);
|
||||||
|
#if !defined (NS_SELF_CONTAINED)
|
||||||
|
/* Assume the Emacs binary lives in a sibling directory as set up by
|
||||||
|
the default installation configuration. */
|
||||||
|
@@ -1387,6 +1397,23 @@ main (int argc, char **argv)
|
||||||
|
exit (0);
|
||||||
|
}
|
||||||
|
|
||||||
|
+#ifdef HAVE_PDUMPER
|
||||||
|
+ if (argmatch (argv, argc, "-fingerprint", "--fingerprint", 4,
|
||||||
|
+ NULL, &skip_args))
|
||||||
|
+ {
|
||||||
|
+ if (initialized)
|
||||||
|
+ {
|
||||||
|
+ dump_fingerprint ("fingerprint", (unsigned char *)fingerprint);
|
||||||
|
+ exit (0);
|
||||||
|
+ }
|
||||||
|
+ else
|
||||||
|
+ {
|
||||||
|
+ fputs ("Not initialized\n", stderr);
|
||||||
|
+ exit (1);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
emacs_wd = emacs_get_current_dir_name ();
|
||||||
|
#ifdef HAVE_PDUMPER
|
||||||
|
if (dumped_with_pdumper_p ())
|
||||||
|
diff --git a/src/pdumper.c b/src/pdumper.c
|
||||||
|
index 11c680d..977f4fb 100644
|
||||||
|
--- a/src/pdumper.c
|
||||||
|
+++ b/src/pdumper.c
|
||||||
|
@@ -312,7 +312,7 @@ dump_reloc_set_offset (struct dump_reloc *reloc, dump_off offset)
|
||||||
|
error ("dump relocation out of range");
|
||||||
|
}
|
||||||
|
|
||||||
|
-static void
|
||||||
|
+void
|
||||||
|
dump_fingerprint (char const *label,
|
||||||
|
unsigned char const xfingerprint[sizeof fingerprint])
|
||||||
|
{
|
||||||
|
diff --git a/src/pdumper.h b/src/pdumper.h
|
||||||
|
index deec9af..bc339c4 100644
|
||||||
|
--- a/src/pdumper.h
|
||||||
|
+++ b/src/pdumper.h
|
||||||
|
@@ -50,6 +50,9 @@ enum { PDUMPER_NO_OBJECT = -1 };
|
||||||
|
#define PDUMPER_REMEMBER_SCALAR(thing) \
|
||||||
|
pdumper_remember_scalar (&(thing), sizeof (thing))
|
||||||
|
|
||||||
|
+extern void dump_fingerprint (const char *label,
|
||||||
|
+ const unsigned char *xfingerprint);
|
||||||
|
+
|
||||||
|
extern void pdumper_remember_scalar_impl (void *data, ptrdiff_t nbytes);
|
||||||
|
|
||||||
|
INLINE void
|
||||||
|
--
|
||||||
|
cgit v1.1
|
||||||
|
|
@ -1,16 +1,22 @@
|
|||||||
diff --git a/lisp/textmodes/ispell.el b/lisp/textmodes/ispell.el
|
diff --git a/lisp/textmodes/ispell.el b/lisp/textmodes/ispell.el
|
||||||
index 1d28de7..1daec44 100644
|
index 0a3a49d868..b6c0975857 100644
|
||||||
--- a/lisp/textmodes/ispell.el
|
--- a/lisp/textmodes/ispell.el
|
||||||
+++ b/lisp/textmodes/ispell.el
|
+++ b/lisp/textmodes/ispell.el
|
||||||
@@ -351,9 +351,9 @@ Must be greater than 1."
|
@@ -191,12 +191,12 @@ Must be greater than 1."
|
||||||
:group 'ispell)
|
:type 'integer)
|
||||||
|
|
||||||
(defcustom ispell-program-name
|
(defcustom ispell-program-name
|
||||||
- (or (executable-find "aspell")
|
- (or (executable-find "aspell")
|
||||||
+ (or (executable-find "hunspell")
|
- (executable-find "ispell")
|
||||||
|
+ ;; Enchant is commonly installed as `enchant-2', so use this
|
||||||
|
+ ;; name and avoid old versions of `enchant'.
|
||||||
|
+ (or (executable-find "enchant-2")
|
||||||
|
(executable-find "hunspell")
|
||||||
|
- ;; Enchant is commonly installed as `enchant-2', so use this
|
||||||
|
- ;; name and avoid old versions of `enchant'.
|
||||||
|
- (executable-find "enchant-2")
|
||||||
+ (executable-find "aspell")
|
+ (executable-find "aspell")
|
||||||
(executable-find "ispell")
|
+ (executable-find "ispell")
|
||||||
- (executable-find "hunspell")
|
|
||||||
"ispell")
|
"ispell")
|
||||||
"Program invoked by \\[ispell-word] and \\[ispell-region] commands."
|
"Program invoked by \\[ispell-word] and \\[ispell-region] commands."
|
||||||
:type 'string
|
:type 'string
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
--- a/src/gnutls.c 2016-01-24 10:29:58.000000000 +0100
|
--- a/src/gnutls.c 2016-01-24 10:29:58.000000000 +0100
|
||||||
+++ b/src/gnutls.c 2016-02-02 09:32:28.477274274 +0100
|
+++ b/src/gnutls.c 2016-02-02 09:32:28.477274274 +0100
|
||||||
@@ -1218,7 +1218,7 @@ one trustfile (usually a CA bundle). */
|
@@ -1557,7 +1557,7 @@
|
||||||
gnutls_certificate_credentials_t x509_cred = NULL;
|
gnutls_certificate_credentials_t x509_cred = NULL;
|
||||||
gnutls_anon_client_credentials_t anon_cred = NULL;
|
gnutls_anon_client_credentials_t anon_cred = NULL;
|
||||||
Lisp_Object global_init;
|
Lisp_Object global_init;
|
||||||
- char const *priority_string_ptr = "NORMAL"; /* default priority string. */
|
- char const *priority_string_ptr = "NORMAL"; /* default priority string. */
|
||||||
+ char const *priority_string_ptr = "@SYSTEM"; /* default priority string. */
|
+ char const *priority_string_ptr = "@SYSTEM"; /* default priority string. */
|
||||||
unsigned int peer_verification;
|
|
||||||
char *c_hostname;
|
char *c_hostname;
|
||||||
|
|
||||||
|
/* Placeholders for the property list elements. */
|
||||||
|
@ -1,303 +0,0 @@
|
|||||||
commit d781662873f228b110a128f7a2b6583a4d5e0a3a
|
|
||||||
Author: Ricardo Wurmus <rekado@elephly.net>
|
|
||||||
Date: Tue Oct 25 23:00:35 2016 -0700
|
|
||||||
|
|
||||||
xwidget: Use WebKit2 API
|
|
||||||
|
|
||||||
* configure.ac: Check for webkit2gtk-4.0.
|
|
||||||
* src/xwidget.c: Adjust to use WebKit2 API.
|
|
||||||
* lisp/xwidget.el (xwidget-webkit-callback): Adjust matches for
|
|
||||||
`xwidget-event-type'.
|
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
|
||||||
index 998ff52..46fd434 100644
|
|
||||||
--- a/configure.ac
|
|
||||||
+++ b/configure.ac
|
|
||||||
@@ -2630,8 +2630,8 @@ if test "$with_xwidgets" != "no"; then
|
|
||||||
test "$USE_GTK_TOOLKIT" = "GTK3" && test "$window_system" != "none" ||
|
|
||||||
AC_MSG_ERROR([xwidgets requested but gtk3 not used.])
|
|
||||||
|
|
||||||
- WEBKIT_REQUIRED=1.4.0
|
|
||||||
- WEBKIT_MODULES="webkitgtk-3.0 >= $WEBKIT_REQUIRED"
|
|
||||||
+ WEBKIT_REQUIRED=2.12
|
|
||||||
+ WEBKIT_MODULES="webkit2gtk-4.0 >= $WEBKIT_REQUIRED"
|
|
||||||
EMACS_CHECK_MODULES([WEBKIT], [$WEBKIT_MODULES])
|
|
||||||
HAVE_XWIDGETS=$HAVE_WEBKIT
|
|
||||||
test $HAVE_XWIDGETS = yes ||
|
|
||||||
diff --git a/lisp/xwidget.el b/lisp/xwidget.el
|
|
||||||
index 7a0ca8b..1bae6bb 100644
|
|
||||||
--- a/lisp/xwidget.el
|
|
||||||
+++ b/lisp/xwidget.el
|
|
||||||
@@ -187,7 +187,7 @@ XWIDGET instance, XWIDGET-EVENT-TYPE depends on the originating xwidget."
|
|
||||||
"error: callback called for xwidget with dead buffer")
|
|
||||||
(with-current-buffer (xwidget-buffer xwidget)
|
|
||||||
(let* ((strarg (nth 3 last-input-event)))
|
|
||||||
- (cond ((eq xwidget-event-type 'document-load-finished)
|
|
||||||
+ (cond ((eq xwidget-event-type 'load-changed)
|
|
||||||
(xwidget-log "webkit finished loading: '%s'"
|
|
||||||
(xwidget-webkit-get-title xwidget))
|
|
||||||
;;TODO - check the native/internal scroll
|
|
||||||
@@ -196,8 +196,7 @@ XWIDGET instance, XWIDGET-EVENT-TYPE depends on the originating xwidget."
|
|
||||||
(rename-buffer (format "*xwidget webkit: %s *"
|
|
||||||
(xwidget-webkit-get-title xwidget)))
|
|
||||||
(pop-to-buffer (current-buffer)))
|
|
||||||
- ((eq xwidget-event-type
|
|
||||||
- 'navigation-policy-decision-requested)
|
|
||||||
+ ((eq xwidget-event-type 'decide-policy)
|
|
||||||
(if (string-match ".*#\\(.*\\)" strarg)
|
|
||||||
(xwidget-webkit-show-id-or-named-element
|
|
||||||
xwidget
|
|
||||||
diff --git a/src/xwidget.c b/src/xwidget.c
|
|
||||||
index f5f4da0..78349a8 100644
|
|
||||||
--- a/src/xwidget.c
|
|
||||||
+++ b/src/xwidget.c
|
|
||||||
@@ -98,13 +98,7 @@ along with GNU Emacs. If not, see <http
|
|
||||||
|
|
||||||
#include <wchar.h>
|
|
||||||
|
|
||||||
-#include <webkit/webkitwebview.h>
|
|
||||||
-#include <webkit/webkitwebplugindatabase.h>
|
|
||||||
-#include <webkit/webkitwebplugin.h>
|
|
||||||
-#include <webkit/webkitglobals.h>
|
|
||||||
-#include <webkit/webkitwebnavigationaction.h>
|
|
||||||
-#include <webkit/webkitdownload.h>
|
|
||||||
-#include <webkit/webkitwebpolicydecision.h>
|
|
||||||
+#include <webkit2/webkit2.h>
|
|
||||||
|
|
||||||
static struct xwidget *
|
|
||||||
allocate_xwidget (void)
|
|
||||||
@@ -50,34 +47,16 @@ allocate_xwidget_view (void)
|
|
||||||
|
|
||||||
static struct xwidget_view *xwidget_view_lookup (struct xwidget *,
|
|
||||||
struct window *);
|
|
||||||
-static void webkit_document_load_finished_cb (WebKitWebView *, WebKitWebFrame *,
|
|
||||||
- gpointer);
|
|
||||||
-static gboolean webkit_download_cb (WebKitWebView *, WebKitDownload *, gpointer);
|
|
||||||
+static void webkit_view_load_changed_cb (WebKitWebView *,
|
|
||||||
+ WebKitLoadEvent,
|
|
||||||
+ gpointer);
|
|
||||||
+static gboolean webkit_download_cb (WebKitWebContext *, WebKitDownload *, gpointer);
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
-webkit_mime_type_policy_typedecision_requested_cb (WebKitWebView *,
|
|
||||||
- WebKitWebFrame *,
|
|
||||||
- WebKitNetworkRequest *,
|
|
||||||
- gchar *,
|
|
||||||
- WebKitWebPolicyDecision *,
|
|
||||||
- gpointer);
|
|
||||||
-
|
|
||||||
-static gboolean
|
|
||||||
-webkit_new_window_policy_decision_requested_cb (WebKitWebView *,
|
|
||||||
- WebKitWebFrame *,
|
|
||||||
- WebKitNetworkRequest *,
|
|
||||||
- WebKitWebNavigationAction *,
|
|
||||||
- WebKitWebPolicyDecision *,
|
|
||||||
- gpointer);
|
|
||||||
-
|
|
||||||
-static gboolean
|
|
||||||
-webkit_navigation_policy_decision_requested_cb (WebKitWebView *,
|
|
||||||
- WebKitWebFrame *,
|
|
||||||
- WebKitNetworkRequest *,
|
|
||||||
- WebKitWebNavigationAction *,
|
|
||||||
- WebKitWebPolicyDecision *,
|
|
||||||
- gpointer);
|
|
||||||
-
|
|
||||||
+webkit_decide_policy_cb (WebKitWebView *,
|
|
||||||
+ WebKitPolicyDecision *,
|
|
||||||
+ WebKitPolicyDecisionType,
|
|
||||||
+ gpointer);
|
|
||||||
|
|
||||||
|
|
||||||
DEFUN ("make-xwidget",
|
|
||||||
@@ -168,29 +147,17 @@ Returns the newly constructed xwidget, or nil if construction fails. */)
|
|
||||||
if (EQ (xw->type, Qwebkit))
|
|
||||||
{
|
|
||||||
g_signal_connect (G_OBJECT (xw->widget_osr),
|
|
||||||
- "document-load-finished",
|
|
||||||
- G_CALLBACK (webkit_document_load_finished_cb), xw);
|
|
||||||
+ "load-changed",
|
|
||||||
+ G_CALLBACK (webkit_view_load_changed_cb), xw);
|
|
||||||
|
|
||||||
- g_signal_connect (G_OBJECT (xw->widget_osr),
|
|
||||||
- "download-requested",
|
|
||||||
+ g_signal_connect (G_OBJECT (webkit_web_context_get_default ()),
|
|
||||||
+ "download-started",
|
|
||||||
G_CALLBACK (webkit_download_cb), xw);
|
|
||||||
|
|
||||||
g_signal_connect (G_OBJECT (xw->widget_osr),
|
|
||||||
- "mime-type-policy-decision-requested",
|
|
||||||
- G_CALLBACK
|
|
||||||
- (webkit_mime_type_policy_typedecision_requested_cb),
|
|
||||||
- xw);
|
|
||||||
-
|
|
||||||
- g_signal_connect (G_OBJECT (xw->widget_osr),
|
|
||||||
- "new-window-policy-decision-requested",
|
|
||||||
- G_CALLBACK
|
|
||||||
- (webkit_new_window_policy_decision_requested_cb),
|
|
||||||
- xw);
|
|
||||||
-
|
|
||||||
- g_signal_connect (G_OBJECT (xw->widget_osr),
|
|
||||||
- "navigation-policy-decision-requested",
|
|
||||||
+ "decide-policy",
|
|
||||||
G_CALLBACK
|
|
||||||
- (webkit_navigation_policy_decision_requested_cb),
|
|
||||||
+ (webkit_decide_policy_cb),
|
|
||||||
xw);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -284,81 +251,83 @@ store_xwidget_event_string (struct xwidget *xw, const char *eventname,
|
|
||||||
kbd_buffer_store_event (&event);
|
|
||||||
}
|
|
||||||
|
|
||||||
-/* TODO deprecated, use load-status. */
|
|
||||||
void
|
|
||||||
-webkit_document_load_finished_cb (WebKitWebView *webkitwebview,
|
|
||||||
- WebKitWebFrame *arg1,
|
|
||||||
- gpointer data)
|
|
||||||
+webkit_view_load_changed_cb (WebKitWebView *webkitwebview,
|
|
||||||
+ WebKitLoadEvent load_event,
|
|
||||||
+ gpointer data)
|
|
||||||
{
|
|
||||||
- struct xwidget *xw = g_object_get_data (G_OBJECT (webkitwebview),
|
|
||||||
- XG_XWIDGET);
|
|
||||||
-
|
|
||||||
- store_xwidget_event_string (xw, "document-load-finished", "");
|
|
||||||
+ switch (load_event) {
|
|
||||||
+ case WEBKIT_LOAD_FINISHED:
|
|
||||||
+ {
|
|
||||||
+ struct xwidget *xw = g_object_get_data (G_OBJECT (webkitwebview),
|
|
||||||
+ XG_XWIDGET);
|
|
||||||
+ store_xwidget_event_string (xw, "load-changed", "");
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ default:
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
|
|
||||||
gboolean
|
|
||||||
-webkit_download_cb (WebKitWebView *webkitwebview,
|
|
||||||
+webkit_download_cb (WebKitWebContext *webkitwebcontext,
|
|
||||||
WebKitDownload *arg1,
|
|
||||||
gpointer data)
|
|
||||||
{
|
|
||||||
- struct xwidget *xw = g_object_get_data (G_OBJECT (webkitwebview),
|
|
||||||
+ WebKitWebView *view = webkit_download_get_web_view(arg1);
|
|
||||||
+ WebKitURIRequest *request = webkit_download_get_request(arg1);
|
|
||||||
+ struct xwidget *xw = g_object_get_data (G_OBJECT (view),
|
|
||||||
XG_XWIDGET);
|
|
||||||
- store_xwidget_event_string (xw, "download-requested",
|
|
||||||
- webkit_download_get_uri (arg1));
|
|
||||||
+
|
|
||||||
+ store_xwidget_event_string (xw, "download-started",
|
|
||||||
+ webkit_uri_request_get_uri(request));
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
-webkit_mime_type_policy_typedecision_requested_cb (WebKitWebView *webView,
|
|
||||||
- WebKitWebFrame *frame,
|
|
||||||
- WebKitNetworkRequest *request,
|
|
||||||
- gchar *mimetype,
|
|
||||||
- WebKitWebPolicyDecision *policy_decision,
|
|
||||||
- gpointer user_data)
|
|
||||||
+webkit_decide_policy_cb (WebKitWebView *webView,
|
|
||||||
+ WebKitPolicyDecision *decision,
|
|
||||||
+ WebKitPolicyDecisionType type,
|
|
||||||
+ gpointer user_data)
|
|
||||||
{
|
|
||||||
- /* This function makes webkit send a download signal for all unknown
|
|
||||||
- mime types. TODO: Defer the decision to Lisp, so that it's
|
|
||||||
- possible to make Emacs handle mime text for instance. */
|
|
||||||
- if (!webkit_web_view_can_show_mime_type (webView, mimetype))
|
|
||||||
+ switch (type) {
|
|
||||||
+ case WEBKIT_POLICY_DECISION_TYPE_RESPONSE:
|
|
||||||
+ /* This function makes webkit send a download signal for all unknown
|
|
||||||
+ mime types. TODO: Defer the decision to Lisp, so that it's
|
|
||||||
+ possible to make Emacs handle mime text for instance. */
|
|
||||||
{
|
|
||||||
- webkit_web_policy_decision_download (policy_decision);
|
|
||||||
- return TRUE;
|
|
||||||
+ WebKitResponsePolicyDecision *response =
|
|
||||||
+ WEBKIT_RESPONSE_POLICY_DECISION (decision);
|
|
||||||
+ if (!webkit_response_policy_decision_is_mime_type_supported (response))
|
|
||||||
+ {
|
|
||||||
+ webkit_policy_decision_download (decision);
|
|
||||||
+ return TRUE;
|
|
||||||
+ }
|
|
||||||
+ else
|
|
||||||
+ return FALSE;
|
|
||||||
+ break;
|
|
||||||
}
|
|
||||||
- else
|
|
||||||
+ case WEBKIT_POLICY_DECISION_TYPE_NEW_WINDOW_ACTION:
|
|
||||||
+ case WEBKIT_POLICY_DECISION_TYPE_NAVIGATION_ACTION:
|
|
||||||
+ {
|
|
||||||
+ WebKitNavigationPolicyDecision *navigation_decision =
|
|
||||||
+ WEBKIT_NAVIGATION_POLICY_DECISION (decision);
|
|
||||||
+ WebKitNavigationAction *navigation_action =
|
|
||||||
+ webkit_navigation_policy_decision_get_navigation_action (navigation_decision);
|
|
||||||
+ WebKitURIRequest *request =
|
|
||||||
+ webkit_navigation_action_get_request (navigation_action);
|
|
||||||
+
|
|
||||||
+ struct xwidget *xw = g_object_get_data (G_OBJECT (webView), XG_XWIDGET);
|
|
||||||
+ store_xwidget_event_string (xw, "decide-policy",
|
|
||||||
+ webkit_uri_request_get_uri (request));
|
|
||||||
+ return FALSE;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ default:
|
|
||||||
return FALSE;
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
|
|
||||||
-static gboolean
|
|
||||||
-webkit_new_window_policy_decision_requested_cb (WebKitWebView *webView,
|
|
||||||
- WebKitWebFrame *frame,
|
|
||||||
- WebKitNetworkRequest *request,
|
|
||||||
- WebKitWebNavigationAction *navigation_action,
|
|
||||||
- WebKitWebPolicyDecision *policy_decision,
|
|
||||||
- gpointer user_data)
|
|
||||||
-{
|
|
||||||
- struct xwidget *xw = g_object_get_data (G_OBJECT (webView), XG_XWIDGET);
|
|
||||||
- webkit_web_navigation_action_get_original_uri (navigation_action);
|
|
||||||
-
|
|
||||||
- store_xwidget_event_string (xw, "new-window-policy-decision-requested",
|
|
||||||
- webkit_web_navigation_action_get_original_uri
|
|
||||||
- (navigation_action));
|
|
||||||
- return FALSE;
|
|
||||||
-}
|
|
||||||
-
|
|
||||||
-static gboolean
|
|
||||||
-webkit_navigation_policy_decision_requested_cb (WebKitWebView *webView,
|
|
||||||
- WebKitWebFrame *frame,
|
|
||||||
- WebKitNetworkRequest *request,
|
|
||||||
- WebKitWebNavigationAction *navigation_action,
|
|
||||||
- WebKitWebPolicyDecision *policy_decision,
|
|
||||||
- gpointer user_data)
|
|
||||||
-{
|
|
||||||
- struct xwidget *xw = g_object_get_data (G_OBJECT (webView), XG_XWIDGET);
|
|
||||||
- store_xwidget_event_string (xw, "navigation-policy-decision-requested",
|
|
||||||
- webkit_web_navigation_action_get_original_uri
|
|
||||||
- (navigation_action));
|
|
||||||
- return FALSE;
|
|
||||||
-}
|
|
||||||
|
|
||||||
/* For gtk3 offscreen rendered widgets. */
|
|
||||||
static gboolean
|
|
||||||
@@ -599,8 +568,13 @@ DEFUN ("xwidget-webkit-execute-script",
|
|
||||||
{
|
|
||||||
WEBKIT_FN_INIT ();
|
|
||||||
CHECK_STRING (script);
|
|
||||||
- webkit_web_view_execute_script (WEBKIT_WEB_VIEW (xw->widget_osr),
|
|
||||||
- SSDATA (script));
|
|
||||||
+ // TODO: provide callback function to do something with the return
|
|
||||||
+ // value! This allows us to get rid of the title hack.
|
|
||||||
+ webkit_web_view_run_javascript (WEBKIT_WEB_VIEW (xw->widget_osr),
|
|
||||||
+ SSDATA (script),
|
|
||||||
+ NULL, /*cancellable*/
|
|
||||||
+ NULL, /*callback*/
|
|
||||||
+ NULL /*user data*/);
|
|
||||||
return Qnil;
|
|
||||||
}
|
|
||||||
|
|
@ -1,64 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!-- Copyright 2014 Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> -->
|
|
||||||
<component type="desktop">
|
|
||||||
<id>emacs.desktop</id>
|
|
||||||
<metadata_license>CC0-1.0</metadata_license>
|
|
||||||
<project_license>GPL-3.0+</project_license>
|
|
||||||
<name>GNU Emacs</name>
|
|
||||||
<summary>Edit text files, view pictures and binary files</summary>
|
|
||||||
<description>
|
|
||||||
<p>
|
|
||||||
Emacs is a powerful, customizable, self-documenting, modeless
|
|
||||||
editor. It is used primarely to edit text, including text
|
|
||||||
documents, source code of programs, web pages and XML documents,
|
|
||||||
but can also be used to display and edit binary files.
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
Emacs allows efficient editing of text with shortcuts which
|
|
||||||
allow operating on letters, words, sentences, and paragraphs as
|
|
||||||
single units. This includes both moving around and operations
|
|
||||||
like copying, deleting, transposing, and pasting. Macros can be
|
|
||||||
conveniently defined to repeat sequences of commands. In
|
|
||||||
addition, Emacs is (partially) built in a scripting language
|
|
||||||
(elisp) which can also be used to define further functions
|
|
||||||
extending existing capabilities.
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
Emacs has extensive support for editing source code, including
|
|
||||||
programmable syntax highlighting, automatic indentation, source
|
|
||||||
code indexing, overview modes, and navigation based on language
|
|
||||||
specific units like functions and blocks. It is also possible to
|
|
||||||
invoke the compiler from within Emacs and easily move between
|
|
||||||
compiler output and corresponding positions in the source.
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
Emacs has multiple modules which provide further functionality.
|
|
||||||
This provides the capability to read mail, news, browse
|
|
||||||
pictures, read man and info pages, browse the web, execute
|
|
||||||
arbitrary programs, and more, without leaving the editor.
|
|
||||||
</p>
|
|
||||||
</description>
|
|
||||||
<screenshots>
|
|
||||||
<screenshot type="default" height="888" width="1595">
|
|
||||||
<image>http://in.waw.pl/~zbyszek/fedora/emacs-two-buffers.png</image>
|
|
||||||
</screenshot>
|
|
||||||
<screenshot height="667" width="1199">
|
|
||||||
<image>http://in.waw.pl/~zbyszek/fedora/emacs-editing-xml.png</image>
|
|
||||||
</screenshot>
|
|
||||||
<screenshot height="572" width="1019">
|
|
||||||
<image>http://in.waw.pl/~zbyszek/fedora/emacs-hexl-mode.png</image>
|
|
||||||
</screenshot>
|
|
||||||
<screenshot height="667" width="1199">
|
|
||||||
<image>http://in.waw.pl/~zbyszek/fedora/emacs-showing-svg.png</image>
|
|
||||||
</screenshot>
|
|
||||||
<screenshot height="439" width="794">
|
|
||||||
<image>http://in.waw.pl/~zbyszek/fedora/emacs-with-python-source.png</image>
|
|
||||||
</screenshot>
|
|
||||||
</screenshots>
|
|
||||||
<url type="homepage">http://www.gnu.org/software/emacs/</url>
|
|
||||||
<url type="bugtracker">https://www.gnu.org/software/emacs/manual/html_node/emacs/Bugs.html</url>
|
|
||||||
<url type="donation">https://my.fsf.org/donate/</url>
|
|
||||||
<url type="help">https://www.gnu.org/software/emacs/manual/</url>
|
|
||||||
<update_contact>zbyszek@in.waw.pl</update_contact>
|
|
||||||
<translation/>
|
|
||||||
</component>
|
|
@ -1,12 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Name=Emacs
|
|
||||||
GenericName=Text Editor
|
|
||||||
Comment=Edit text
|
|
||||||
Comment[zh_TW]=編輯文字
|
|
||||||
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
|
|
||||||
Type=Application
|
|
||||||
Terminal=false
|
|
||||||
Categories=Utility;TextEditor;X-Red-Hat-Base;
|
|
||||||
StartupWMClass=Emacs
|
|
@ -1,11 +0,0 @@
|
|||||||
[Unit]
|
|
||||||
Description=Emacs: the extensible, self-documenting text editor
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=forking
|
|
||||||
ExecStart=/usr/bin/emacs --daemon
|
|
||||||
ExecStop=/usr/bin/emacsclient --eval "(kill-emacs)"
|
|
||||||
Restart=always
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=default.target
|
|
399
emacs.spec
399
emacs.spec
@ -4,30 +4,29 @@
|
|||||||
Summary: GNU Emacs text editor
|
Summary: GNU Emacs text editor
|
||||||
Name: emacs
|
Name: emacs
|
||||||
Epoch: 1
|
Epoch: 1
|
||||||
Version: 25.3
|
Version: 28.1
|
||||||
Release: 3%{?dist}
|
Release: 3%{?dist}
|
||||||
License: GPLv3+ and CC0-1.0
|
License: GPLv3+ and CC0
|
||||||
URL: http://www.gnu.org/software/emacs/
|
URL: http://www.gnu.org/software/emacs/
|
||||||
Group: Applications/Editors
|
Source0: https://ftp.gnu.org/gnu/emacs/emacs-%{version}.tar.xz
|
||||||
Source0: ftp://ftp.gnu.org/gnu/emacs/emacs-%{version}.tar.xz
|
Source1: https://ftp.gnu.org/gnu/emacs/emacs-%{version}.tar.xz.sig
|
||||||
Source1: emacs.desktop
|
# get Eli Zaretskii's key
|
||||||
Source3: dotemacs.el
|
# wget https://keys.openpgp.org/vks/v1/by-fingerprint/17E90D521672C04631B1183EE78DAE0F3115E06B -O gpgkey-17E90D521672C04631B1183EE78DAE0F3115E06B.gpg
|
||||||
Source4: site-start.el
|
Source2: gpgkey-17E90D521672C04631B1183EE78DAE0F3115E06B.gpg
|
||||||
Source5: default.el
|
Source3: https://git.savannah.gnu.org/gitweb/?p=gnulib.git;a=blob_plain;f=lib/cdefs.h;hb=refs/heads/master#./cdefs.h
|
||||||
|
Source4: dotemacs.el
|
||||||
|
Source5: site-start.el
|
||||||
|
Source6: default.el
|
||||||
# Emacs Terminal Mode, #551949, #617355
|
# Emacs Terminal Mode, #551949, #617355
|
||||||
Source6: emacs-terminal.desktop
|
Source7: emacs-terminal.desktop
|
||||||
Source7: emacs-terminal.sh
|
Source8: emacs-terminal.sh
|
||||||
Source8: emacs.service
|
|
||||||
Source9: %{name}.appdata.xml
|
|
||||||
# rhbz#713600
|
# rhbz#713600
|
||||||
Patch1: emacs-spellchecker.patch
|
Patch1: emacs-spellchecker.patch
|
||||||
|
Patch2: emacs-system-crypto-policies.patch
|
||||||
|
Patch3: emacs-libdir-vs-systemd.patch
|
||||||
|
Patch4: emacs-pdmp-fingerprint.patch
|
||||||
|
|
||||||
# Fix for default PDF viewer bug #971162
|
BuildRequires: gcc
|
||||||
Patch2: emacs-pdf-default.patch
|
|
||||||
Patch3: emacs-system-crypto-policies.patch
|
|
||||||
# http://git.savannah.gnu.org/cgit/emacs.git/commit/?id=d781662873f228b110a128f7a2b6583a4d5e0a3a
|
|
||||||
Patch4: emacs-xwidget.patch
|
|
||||||
|
|
||||||
BuildRequires: atk-devel
|
BuildRequires: atk-devel
|
||||||
BuildRequires: cairo-devel
|
BuildRequires: cairo-devel
|
||||||
BuildRequires: freetype-devel
|
BuildRequires: freetype-devel
|
||||||
@ -52,24 +51,28 @@ BuildRequires: gnutls-devel
|
|||||||
BuildRequires: librsvg2-devel
|
BuildRequires: librsvg2-devel
|
||||||
BuildRequires: m17n-lib-devel
|
BuildRequires: m17n-lib-devel
|
||||||
BuildRequires: libotf-devel
|
BuildRequires: libotf-devel
|
||||||
BuildRequires: ImageMagick-devel
|
|
||||||
BuildRequires: libselinux-devel
|
BuildRequires: libselinux-devel
|
||||||
BuildRequires: GConf2-devel
|
|
||||||
BuildRequires: alsa-lib-devel
|
BuildRequires: alsa-lib-devel
|
||||||
BuildRequires: gpm-devel
|
BuildRequires: gpm-devel
|
||||||
BuildRequires: liblockfile-devel
|
BuildRequires: liblockfile-devel
|
||||||
BuildRequires: libxml2-devel
|
BuildRequires: libxml2-devel
|
||||||
|
BuildRequires: autoconf
|
||||||
BuildRequires: bzip2
|
BuildRequires: bzip2
|
||||||
BuildRequires: cairo
|
BuildRequires: cairo
|
||||||
BuildRequires: texinfo
|
BuildRequires: texinfo
|
||||||
BuildRequires: gzip
|
BuildRequires: gzip
|
||||||
BuildRequires: desktop-file-utils
|
BuildRequires: desktop-file-utils
|
||||||
|
BuildRequires: libappstream-glib
|
||||||
BuildRequires: libacl-devel
|
BuildRequires: libacl-devel
|
||||||
|
BuildRequires: harfbuzz-devel
|
||||||
|
BuildRequires: jansson-devel
|
||||||
|
BuildRequires: systemd-devel
|
||||||
|
BuildRequires: libgccjit-devel
|
||||||
|
|
||||||
BuildRequires: gtk3-devel
|
BuildRequires: gtk3-devel
|
||||||
BuildRequires: webkitgtk4-devel
|
BuildRequires: webkit2gtk3-devel
|
||||||
BuildRequires: python2-devel
|
|
||||||
BuildRequires: python3-devel
|
BuildRequires: gnupg2
|
||||||
|
|
||||||
# For lucid
|
# For lucid
|
||||||
BuildRequires: Xaw3d-devel
|
BuildRequires: Xaw3d-devel
|
||||||
@ -77,25 +80,25 @@ BuildRequires: Xaw3d-devel
|
|||||||
%ifarch %{ix86}
|
%ifarch %{ix86}
|
||||||
BuildRequires: util-linux
|
BuildRequires: util-linux
|
||||||
%endif
|
%endif
|
||||||
|
BuildRequires: make
|
||||||
|
|
||||||
|
# Emacs requires info for info mode, rhbz#1989264
|
||||||
|
Requires: info
|
||||||
# Emacs doesn't run without dejavu-sans-mono-fonts, rhbz#732422
|
# Emacs doesn't run without dejavu-sans-mono-fonts, rhbz#732422
|
||||||
Requires: desktop-file-utils
|
Requires: desktop-file-utils
|
||||||
Requires: dejavu-sans-mono-fonts
|
Requires: dejavu-sans-mono-fonts
|
||||||
|
Requires: libgccjit
|
||||||
Requires(preun): %{_sbindir}/alternatives
|
Requires(preun): %{_sbindir}/alternatives
|
||||||
Requires(posttrans): %{_sbindir}/alternatives
|
Requires(posttrans): %{_sbindir}/alternatives
|
||||||
Requires: emacs-common = %{epoch}:%{version}-%{release}
|
Requires: emacs-common = %{epoch}:%{version}-%{release}
|
||||||
Provides: emacs(bin) = %{epoch}:%{version}-%{release}
|
Provides: emacs(bin) = %{epoch}:%{version}-%{release}
|
||||||
|
|
||||||
# Turn off the brp-python-bytecompile script since this script doesn't
|
|
||||||
# properly dtect the correct python runtime for the files emacs2.py and
|
|
||||||
# emacs3.py
|
|
||||||
%global __os_install_post %(echo '%{__os_install_post}' | sed -e 's!/usr/lib[^[:space:]]*/brp-python-bytecompile[[:space:]].*$!!g')
|
|
||||||
|
|
||||||
%define site_lisp %{_datadir}/emacs/site-lisp
|
%define site_lisp %{_datadir}/emacs/site-lisp
|
||||||
%define site_start_d %{site_lisp}/site-start.d
|
%define site_start_d %{site_lisp}/site-start.d
|
||||||
%define bytecompargs -batch --no-init-file --no-site-file -f batch-byte-compile
|
%define bytecompargs -batch --no-init-file --no-site-file -f batch-byte-compile
|
||||||
%define pkgconfig %{_datadir}/pkgconfig
|
%define pkgconfig %{_datadir}/pkgconfig
|
||||||
%define emacs_libexecdir %{_libexecdir}/emacs/%{version}/%{_host}
|
%define emacs_libexecdir %{_libexecdir}/emacs/%{version}/%{_host}
|
||||||
|
%define native_lisp %{_libdir}/emacs/%{version}/native-lisp
|
||||||
|
|
||||||
%description
|
%description
|
||||||
Emacs is a powerful, customizable, self-documenting, modeless text
|
Emacs is a powerful, customizable, self-documenting, modeless text
|
||||||
@ -107,7 +110,7 @@ This package provides an emacs binary with support for X windows.
|
|||||||
|
|
||||||
%package lucid
|
%package lucid
|
||||||
Summary: GNU Emacs text editor with LUCID toolkit X support
|
Summary: GNU Emacs text editor with LUCID toolkit X support
|
||||||
Group: Applications/Editors
|
Requires: libgccjit
|
||||||
Requires(preun): %{_sbindir}/alternatives
|
Requires(preun): %{_sbindir}/alternatives
|
||||||
Requires(posttrans): %{_sbindir}/alternatives
|
Requires(posttrans): %{_sbindir}/alternatives
|
||||||
Requires: emacs-common = %{epoch}:%{version}-%{release}
|
Requires: emacs-common = %{epoch}:%{version}-%{release}
|
||||||
@ -124,7 +127,7 @@ using LUCID toolkit.
|
|||||||
|
|
||||||
%package nox
|
%package nox
|
||||||
Summary: GNU Emacs text editor without X support
|
Summary: GNU Emacs text editor without X support
|
||||||
Group: Applications/Editors
|
Requires: libgccjit
|
||||||
Requires(preun): %{_sbindir}/alternatives
|
Requires(preun): %{_sbindir}/alternatives
|
||||||
Requires(posttrans): %{_sbindir}/alternatives
|
Requires(posttrans): %{_sbindir}/alternatives
|
||||||
Requires: emacs-common = %{epoch}:%{version}-%{release}
|
Requires: emacs-common = %{epoch}:%{version}-%{release}
|
||||||
@ -144,14 +147,17 @@ Summary: Emacs common files
|
|||||||
# The entire source code is GPLv3+ except lib-src/etags.c which is
|
# The entire source code is GPLv3+ except lib-src/etags.c which is
|
||||||
# also BSD. Manual (info) is GFDL.
|
# also BSD. Manual (info) is GFDL.
|
||||||
License: GPLv3+ and GFDL and BSD
|
License: GPLv3+ and GFDL and BSD
|
||||||
Group: Applications/Editors
|
|
||||||
Requires(preun): /sbin/install-info
|
|
||||||
Requires(preun): %{_sbindir}/alternatives
|
Requires(preun): %{_sbindir}/alternatives
|
||||||
Requires(posttrans): %{_sbindir}/alternatives
|
Requires(posttrans): %{_sbindir}/alternatives
|
||||||
Requires(post): /sbin/install-info
|
|
||||||
Requires: %{name}-filesystem = %{epoch}:%{version}-%{release}
|
Requires: %{name}-filesystem = %{epoch}:%{version}-%{release}
|
||||||
|
Recommends: enchant2
|
||||||
Provides: %{name}-el = %{epoch}:%{version}-%{release}
|
Provides: %{name}-el = %{epoch}:%{version}-%{release}
|
||||||
Obsoletes: emacs-el < 1:24.3-29
|
Obsoletes: emacs-el < 1:24.3-29
|
||||||
|
# transient.el is provided by emacs in lisp/transient.el
|
||||||
|
Provides: emacs-transient = 0.3.7
|
||||||
|
# the existing emacs-transient package is obsoleted by emacs 28+, last package
|
||||||
|
# version as of the release of emacs 28.1 is obsoleted
|
||||||
|
Obsoletes: emacs-transient < 0.3.0-4
|
||||||
|
|
||||||
%description common
|
%description common
|
||||||
Emacs is a powerful, customizable, self-documenting, modeless text
|
Emacs is a powerful, customizable, self-documenting, modeless text
|
||||||
@ -164,7 +170,6 @@ or emacs-nox.
|
|||||||
|
|
||||||
%package terminal
|
%package terminal
|
||||||
Summary: A desktop menu item for GNU Emacs terminal.
|
Summary: A desktop menu item for GNU Emacs terminal.
|
||||||
Group: Applications/Editors
|
|
||||||
Requires: emacs = %{epoch}:%{version}-%{release}
|
Requires: emacs = %{epoch}:%{version}-%{release}
|
||||||
BuildArch: noarch
|
BuildArch: noarch
|
||||||
|
|
||||||
@ -177,24 +182,30 @@ removed when another terminal becomes capable of handling Malayalam.
|
|||||||
|
|
||||||
%package filesystem
|
%package filesystem
|
||||||
Summary: Emacs filesystem layout
|
Summary: Emacs filesystem layout
|
||||||
Group: Applications/Editors
|
|
||||||
BuildArch: noarch
|
BuildArch: noarch
|
||||||
|
|
||||||
%description filesystem
|
%description filesystem
|
||||||
This package provides some directories which are required by other
|
This package provides some directories which are required by other
|
||||||
packages that add functionality to Emacs.
|
packages that add functionality to Emacs.
|
||||||
|
|
||||||
|
%package devel
|
||||||
|
Summary: Development header files for Emacs
|
||||||
|
|
||||||
|
%description devel
|
||||||
|
Development header files for Emacs.
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
|
%{gpgverify} --keyring='%{SOURCE2}' --signature='%{SOURCE1}' --data='%{SOURCE0}'
|
||||||
%setup -q
|
%setup -q
|
||||||
|
|
||||||
%patch1 -p1 -b .spellchecker
|
# workaround for ftbfs on ppc64, see https://bugzilla.redhat.com/show_bug.cgi?id=2045780#c8
|
||||||
%patch2 -p1 -b .pdf-default.patch
|
cp -p %{SOURCE3} lib/
|
||||||
%patch3 -p1 -b .system-crypto-policies
|
|
||||||
%patch4 -p1
|
|
||||||
autoconf
|
|
||||||
|
|
||||||
# We prefer our emacs.desktop file
|
%patch1 -p1 -b .spellchecker
|
||||||
cp %SOURCE1 etc/emacs.desktop
|
%patch2 -p1 -b .system-crypto-policies
|
||||||
|
%patch3 -p1 -b .libdir-vs-systemd
|
||||||
|
%patch4 -p1 -b .pdmp-fingerprint
|
||||||
|
autoconf
|
||||||
|
|
||||||
grep -v "tetris.elc" lisp/Makefile.in > lisp/Makefile.in.new \
|
grep -v "tetris.elc" lisp/Makefile.in > lisp/Makefile.in.new \
|
||||||
&& mv lisp/Makefile.in.new lisp/Makefile.in
|
&& mv lisp/Makefile.in.new lisp/Makefile.in
|
||||||
@ -234,20 +245,8 @@ ln -s ../../%{name}/%{version}/etc/NEWS doc
|
|||||||
|
|
||||||
|
|
||||||
%build
|
%build
|
||||||
export CFLAGS="-DMAIL_USE_LOCKF $RPM_OPT_FLAGS"
|
export CFLAGS="-DMAIL_USE_LOCKF %{build_cflags}"
|
||||||
|
%set_build_flags
|
||||||
# Build GTK+ binary
|
|
||||||
mkdir build-gtk && cd build-gtk
|
|
||||||
ln -s ../configure .
|
|
||||||
|
|
||||||
LDFLAGS=-Wl,-z,relro; export LDFLAGS;
|
|
||||||
|
|
||||||
%configure --with-dbus --with-gif --with-jpeg --with-png --with-rsvg \
|
|
||||||
--with-tiff --with-xft --with-xpm --with-x-toolkit=gtk3 --with-gpm=no \
|
|
||||||
--with-xwidgets --with-modules
|
|
||||||
make bootstrap
|
|
||||||
%{setarch} make %{?_smp_mflags}
|
|
||||||
cd ..
|
|
||||||
|
|
||||||
# Build Lucid binary
|
# Build Lucid binary
|
||||||
mkdir build-lucid && cd build-lucid
|
mkdir build-lucid && cd build-lucid
|
||||||
@ -257,16 +256,32 @@ LDFLAGS=-Wl,-z,relro; export LDFLAGS;
|
|||||||
|
|
||||||
%configure --with-dbus --with-gif --with-jpeg --with-png --with-rsvg \
|
%configure --with-dbus --with-gif --with-jpeg --with-png --with-rsvg \
|
||||||
--with-tiff --with-xft --with-xpm --with-x-toolkit=lucid --with-gpm=no \
|
--with-tiff --with-xft --with-xpm --with-x-toolkit=lucid --with-gpm=no \
|
||||||
--with-modules
|
--with-modules --with-harfbuzz --with-cairo --with-json \
|
||||||
make bootstrap
|
--with-native-compilation
|
||||||
%{setarch} make %{?_smp_mflags}
|
%{setarch} %make_build bootstrap NATIVE_FULL_AOT=1
|
||||||
|
%{setarch} %make_build
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
# Build binary without X support
|
# Build binary without X support
|
||||||
mkdir build-nox && cd build-nox
|
mkdir build-nox && cd build-nox
|
||||||
ln -s ../configure .
|
ln -s ../configure .
|
||||||
%configure --with-x=no --with-modules
|
%configure --with-x=no --with-modules --with-json --with-native-compilation
|
||||||
%{setarch} make %{?_smp_mflags}
|
%{setarch} %make_build bootstrap NATIVE_FULL_AOT=1
|
||||||
|
%{setarch} %make_build
|
||||||
|
cd ..
|
||||||
|
|
||||||
|
# Build GTK+ binary
|
||||||
|
mkdir build-gtk && cd build-gtk
|
||||||
|
ln -s ../configure .
|
||||||
|
|
||||||
|
LDFLAGS=-Wl,-z,relro; export LDFLAGS;
|
||||||
|
|
||||||
|
%configure --with-dbus --with-gif --with-jpeg --with-png --with-rsvg \
|
||||||
|
--with-tiff --with-xpm --with-x-toolkit=gtk3 --with-gpm=no \
|
||||||
|
--with-xwidgets --with-modules --with-harfbuzz --with-cairo --with-json \
|
||||||
|
--with-native-compilation
|
||||||
|
%{setarch} %make_build bootstrap NATIVE_FULL_AOT=1
|
||||||
|
%{setarch} %make_build
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
# Remove versioned file so that we end up with .1 suffix and only one DOC file
|
# Remove versioned file so that we end up with .1 suffix and only one DOC file
|
||||||
@ -294,7 +309,7 @@ EOF
|
|||||||
|
|
||||||
%install
|
%install
|
||||||
cd build-gtk
|
cd build-gtk
|
||||||
make install INSTALL="%{__install} -p" DESTDIR=%{buildroot}
|
%make_install
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
# Let alternatives manage the symlink
|
# Let alternatives manage the symlink
|
||||||
@ -315,8 +330,8 @@ install -p -m 0755 build-nox/src/emacs %{buildroot}%{_bindir}/emacs-%{version}-n
|
|||||||
chmod 755 %{buildroot}%{emacs_libexecdir}/movemail
|
chmod 755 %{buildroot}%{emacs_libexecdir}/movemail
|
||||||
|
|
||||||
mkdir -p %{buildroot}%{site_lisp}
|
mkdir -p %{buildroot}%{site_lisp}
|
||||||
install -p -m 0644 %SOURCE4 %{buildroot}%{site_lisp}/site-start.el
|
install -p -m 0644 %SOURCE5 %{buildroot}%{site_lisp}/site-start.el
|
||||||
install -p -m 0644 %SOURCE5 %{buildroot}%{site_lisp}
|
install -p -m 0644 %SOURCE6 %{buildroot}%{site_lisp}
|
||||||
|
|
||||||
# This solves bz#474958, "update-directory-autoloads" now finally
|
# This solves bz#474958, "update-directory-autoloads" now finally
|
||||||
# works the path is different each version, so we'll generate it here
|
# works the path is different each version, so we'll generate it here
|
||||||
@ -334,42 +349,33 @@ mkdir -p %{buildroot}%{site_lisp}/site-start.d
|
|||||||
|
|
||||||
# Default initialization file
|
# Default initialization file
|
||||||
mkdir -p %{buildroot}%{_sysconfdir}/skel
|
mkdir -p %{buildroot}%{_sysconfdir}/skel
|
||||||
install -p -m 0644 %SOURCE3 %{buildroot}%{_sysconfdir}/skel/.emacs
|
install -p -m 0644 %SOURCE4 %{buildroot}%{_sysconfdir}/skel/.emacs
|
||||||
|
|
||||||
# Install pkgconfig file
|
# Install pkgconfig file
|
||||||
mkdir -p %{buildroot}/%{pkgconfig}
|
mkdir -p %{buildroot}/%{pkgconfig}
|
||||||
install -p -m 0644 emacs.pc %{buildroot}/%{pkgconfig}
|
install -p -m 0644 emacs.pc %{buildroot}/%{pkgconfig}
|
||||||
|
|
||||||
# Install app data
|
|
||||||
mkdir -p %{buildroot}/%{_datadir}/appdata
|
|
||||||
cp -a %SOURCE9 %{buildroot}/%{_datadir}/appdata
|
|
||||||
|
|
||||||
# Install rpm macro definition file
|
# Install rpm macro definition file
|
||||||
mkdir -p %{buildroot}%{_rpmconfigdir}/macros.d
|
mkdir -p %{buildroot}%{_rpmconfigdir}/macros.d
|
||||||
install -p -m 0644 macros.emacs %{buildroot}%{_rpmconfigdir}/macros.d/
|
install -p -m 0644 macros.emacs %{buildroot}%{_rpmconfigdir}/macros.d/
|
||||||
|
|
||||||
# Installing emacs-terminal binary
|
# Installing emacs-terminal binary
|
||||||
install -p -m 755 %SOURCE7 %{buildroot}%{_bindir}/emacs-terminal
|
install -p -m 755 %SOURCE8 %{buildroot}%{_bindir}/emacs-terminal
|
||||||
|
|
||||||
# After everything is installed, remove info dir
|
# After everything is installed, remove info dir
|
||||||
rm -f %{buildroot}%{_infodir}/dir
|
rm -f %{buildroot}%{_infodir}/dir
|
||||||
rm %{buildroot}%{_localstatedir}/games/emacs/*
|
|
||||||
|
|
||||||
# Installing service file
|
|
||||||
mkdir -p %{buildroot}%{_userunitdir}
|
|
||||||
install -p -m 0644 %SOURCE8 %{buildroot}%{_userunitdir}/emacs.service
|
|
||||||
|
|
||||||
# Install desktop files
|
# Install desktop files
|
||||||
mkdir -p %{buildroot}%{_datadir}/applications
|
|
||||||
desktop-file-install --dir=%{buildroot}%{_datadir}/applications \
|
desktop-file-install --dir=%{buildroot}%{_datadir}/applications \
|
||||||
%SOURCE1
|
%SOURCE7
|
||||||
desktop-file-install --dir=%{buildroot}%{_datadir}/applications \
|
|
||||||
%SOURCE6
|
|
||||||
|
|
||||||
# Byte compile emacs*.py with correct python interpreters
|
# Remove duplicate desktop-related files
|
||||||
%py_byte_compile %{__python} %{buildroot}%{_datadir}/%{name}/%{version}/etc/emacs.py
|
rm %{buildroot}%{_datadir}/%{name}/%{version}/etc/%{name}.{desktop,service}
|
||||||
%py_byte_compile %{__python} %{buildroot}%{_datadir}/%{name}/%{version}/etc/emacs2.py
|
|
||||||
%py_byte_compile %{__python3} %{buildroot}%{_datadir}/%{name}/%{version}/etc/emacs3.py
|
# We don't ship the client variants yet
|
||||||
|
# https://src.fedoraproject.org/rpms/emacs/pull-request/12
|
||||||
|
rm %{buildroot}%{_datadir}/applications/emacsclient.desktop
|
||||||
|
rm %{buildroot}%{_datadir}/applications/emacsclient-mail.desktop
|
||||||
|
|
||||||
#
|
#
|
||||||
# Create file lists
|
# Create file lists
|
||||||
@ -393,80 +399,82 @@ cat el-*-files common-lisp-dir-files > el-filelist
|
|||||||
# Remove old icon
|
# Remove old icon
|
||||||
rm %{buildroot}%{_datadir}/icons/hicolor/scalable/mimetypes/emacs-document23.svg
|
rm %{buildroot}%{_datadir}/icons/hicolor/scalable/mimetypes/emacs-document23.svg
|
||||||
|
|
||||||
%post
|
# Install all the pdmp with fingerprints
|
||||||
update-desktop-database &> /dev/null || :
|
gtk_pdmp="emacs-$(./build-gtk/src/emacs --fingerprint 2>&1 | sed 's/.* //').pdmp"
|
||||||
touch --no-create %{_datadir}/icons/hicolor
|
install -p -m 0644 build-gtk/src/emacs.pdmp %{buildroot}%{emacs_libexecdir}/${gtk_pdmp}
|
||||||
if [ -x %{_bindir}/gtk-update-icon-cache ] ; then
|
|
||||||
%{_bindir}/gtk-update-icon-cache --quiet %{_datadir}/icons/hicolor || :
|
lucid_pdmp="emacs-$(./build-lucid/src/emacs --fingerprint 2>&1 | sed 's/.* //').pdmp"
|
||||||
fi
|
install -p -m 0644 build-lucid/src/emacs.pdmp %{buildroot}%{emacs_libexecdir}/${lucid_pdmp}
|
||||||
|
|
||||||
|
nox_pdmp="emacs-$(./build-nox/src/emacs --fingerprint 2>&1 | sed 's/.* //').pdmp"
|
||||||
|
install -p -m 0644 build-nox/src/emacs.pdmp %{buildroot}%{emacs_libexecdir}/${nox_pdmp}
|
||||||
|
|
||||||
|
# Install native compiled Lisp of all builds
|
||||||
|
gtk_comp_native_ver=$(ls -1 build-gtk/native-lisp)
|
||||||
|
lucid_comp_native_ver=$(ls -1 build-lucid/native-lisp)
|
||||||
|
nox_comp_native_ver=$(ls -1 build-nox/native-lisp)
|
||||||
|
cp -ar build-gtk/native-lisp/${gtk_comp_native_ver} %{buildroot}%{native_lisp}
|
||||||
|
cp -ar build-lucid/native-lisp/${lucid_comp_native_ver} %{buildroot}%{native_lisp}
|
||||||
|
cp -ar build-nox/native-lisp/${nox_comp_native_ver} %{buildroot}%{native_lisp}
|
||||||
|
|
||||||
|
# List of binary specific files
|
||||||
|
echo %{emacs_libexecdir}/${gtk_pdmp} > gtk-filelist
|
||||||
|
echo %{emacs_libexecdir}/${lucid_pdmp} > lucid-filelist
|
||||||
|
echo %{emacs_libexecdir}/${nox_pdmp} > nox-filelist
|
||||||
|
echo %{native_lisp}/${gtk_comp_native_ver} >> gtk-filelist
|
||||||
|
echo %{native_lisp}/${lucid_comp_native_ver} >> lucid-filelist
|
||||||
|
echo %{native_lisp}/${nox_comp_native_ver} >> nox-filelist
|
||||||
|
|
||||||
|
%check
|
||||||
|
appstream-util validate-relax --nonet %{buildroot}/%{_metainfodir}/*.metainfo.xml
|
||||||
|
desktop-file-validate %{buildroot}/%{_datadir}/applications/*.desktop
|
||||||
|
|
||||||
%preun
|
%preun
|
||||||
%{_sbindir}/alternatives --remove emacs %{_bindir}/emacs-%{version}
|
%{_sbindir}/alternatives --remove emacs %{_bindir}/emacs-%{version} || :
|
||||||
|
|
||||||
%postun
|
|
||||||
update-desktop-database &> /dev/null || :
|
|
||||||
touch --no-create %{_datadir}/icons/hicolor
|
|
||||||
if [ -x %{_bindir}/gtk-update-icon-cache ] ; then
|
|
||||||
%{_bindir}/gtk-update-icon-cache --quiet %{_datadir}/icons/hicolor || :
|
|
||||||
fi
|
|
||||||
|
|
||||||
%posttrans
|
%posttrans
|
||||||
%{_sbindir}/alternatives --install %{_bindir}/emacs emacs %{_bindir}/emacs-%{version} 80
|
%{_sbindir}/alternatives --install %{_bindir}/emacs emacs %{_bindir}/emacs-%{version} 80 || :
|
||||||
|
|
||||||
%preun lucid
|
%preun lucid
|
||||||
%{_sbindir}/alternatives --remove emacs %{_bindir}/emacs-%{version}-lucid
|
%{_sbindir}/alternatives --remove emacs %{_bindir}/emacs-%{version}-lucid || :
|
||||||
%{_sbindir}/alternatives --remove emacs-lucid %{_bindir}/emacs-%{version}-lucid
|
%{_sbindir}/alternatives --remove emacs-lucid %{_bindir}/emacs-%{version}-lucid || :
|
||||||
|
|
||||||
%posttrans lucid
|
%posttrans lucid
|
||||||
%{_sbindir}/alternatives --install %{_bindir}/emacs emacs %{_bindir}/emacs-%{version}-lucid 70
|
%{_sbindir}/alternatives --install %{_bindir}/emacs emacs %{_bindir}/emacs-%{version}-lucid 70 || :
|
||||||
%{_sbindir}/alternatives --install %{_bindir}/emacs-lucid emacs-lucid %{_bindir}/emacs-%{version}-lucid 60
|
%{_sbindir}/alternatives --install %{_bindir}/emacs-lucid emacs-lucid %{_bindir}/emacs-%{version}-lucid 60 || :
|
||||||
|
|
||||||
%preun nox
|
%preun nox
|
||||||
%{_sbindir}/alternatives --remove emacs %{_bindir}/emacs-%{version}-nox
|
%{_sbindir}/alternatives --remove emacs %{_bindir}/emacs-%{version}-nox || :
|
||||||
%{_sbindir}/alternatives --remove emacs-nox %{_bindir}/emacs-%{version}-nox
|
%{_sbindir}/alternatives --remove emacs-nox %{_bindir}/emacs-%{version}-nox || :
|
||||||
|
|
||||||
%posttrans nox
|
%posttrans nox
|
||||||
%{_sbindir}/alternatives --install %{_bindir}/emacs emacs %{_bindir}/emacs-%{version}-nox 70
|
%{_sbindir}/alternatives --install %{_bindir}/emacs emacs %{_bindir}/emacs-%{version}-nox 70 || :
|
||||||
%{_sbindir}/alternatives --install %{_bindir}/emacs-nox emacs-nox %{_bindir}/emacs-%{version}-nox 60
|
%{_sbindir}/alternatives --install %{_bindir}/emacs-nox emacs-nox %{_bindir}/emacs-%{version}-nox 60 || :
|
||||||
|
|
||||||
%post common
|
|
||||||
for f in %{info_files}; do
|
|
||||||
/sbin/install-info %{_infodir}/$f.info.gz %{_infodir}/dir 2> /dev/null || :
|
|
||||||
done
|
|
||||||
|
|
||||||
%preun common
|
%preun common
|
||||||
%{_sbindir}/alternatives --remove emacs.etags %{_bindir}/etags.emacs
|
%{_sbindir}/alternatives --remove emacs.etags %{_bindir}/etags.emacs || :
|
||||||
if [ "$1" = 0 ]; then
|
|
||||||
for f in %{info_files}; do
|
|
||||||
/sbin/install-info --delete %{_infodir}/$f.info.gz %{_infodir}/dir 2> /dev/null || :
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
%posttrans common
|
%posttrans common
|
||||||
%{_sbindir}/alternatives --install %{_bindir}/etags emacs.etags %{_bindir}/etags.emacs 80 \
|
%{_sbindir}/alternatives --install %{_bindir}/etags emacs.etags %{_bindir}/etags.emacs 80 \
|
||||||
--slave %{_mandir}/man1/etags.1.gz emacs.etags.man %{_mandir}/man1/etags.emacs.1.gz
|
--slave %{_mandir}/man1/etags.1.gz emacs.etags.man %{_mandir}/man1/etags.emacs.1.gz || :
|
||||||
|
|
||||||
%post terminal
|
%files -f gtk-filelist
|
||||||
update-desktop-database &> /dev/null || :
|
|
||||||
|
|
||||||
%postun terminal
|
|
||||||
update-desktop-database &> /dev/null || :
|
|
||||||
|
|
||||||
%files
|
|
||||||
%{_bindir}/emacs-%{version}
|
%{_bindir}/emacs-%{version}
|
||||||
%attr(0755,-,-) %ghost %{_bindir}/emacs
|
%attr(0755,-,-) %ghost %{_bindir}/emacs
|
||||||
%{_datadir}/applications/emacs.desktop
|
%{_datadir}/applications/emacs.desktop
|
||||||
%{_datadir}/appdata/%{name}.appdata.xml
|
%{_datadir}/applications/emacs-mail.desktop
|
||||||
|
%{_metainfodir}/%{name}.metainfo.xml
|
||||||
%{_datadir}/icons/hicolor/*/apps/emacs.png
|
%{_datadir}/icons/hicolor/*/apps/emacs.png
|
||||||
%{_datadir}/icons/hicolor/scalable/apps/emacs.svg
|
%{_datadir}/icons/hicolor/scalable/apps/emacs.svg
|
||||||
|
%{_datadir}/icons/hicolor/scalable/apps/emacs.ico
|
||||||
%{_datadir}/icons/hicolor/scalable/mimetypes/emacs-document.svg
|
%{_datadir}/icons/hicolor/scalable/mimetypes/emacs-document.svg
|
||||||
|
|
||||||
%files lucid
|
%files lucid -f lucid-filelist
|
||||||
%{_bindir}/emacs-%{version}-lucid
|
%{_bindir}/emacs-%{version}-lucid
|
||||||
%attr(0755,-,-) %ghost %{_bindir}/emacs
|
%attr(0755,-,-) %ghost %{_bindir}/emacs
|
||||||
%attr(0755,-,-) %ghost %{_bindir}/emacs-lucid
|
%attr(0755,-,-) %ghost %{_bindir}/emacs-lucid
|
||||||
|
|
||||||
%files nox
|
%files nox -f nox-filelist
|
||||||
%{_bindir}/emacs-%{version}-nox
|
%{_bindir}/emacs-%{version}-nox
|
||||||
%attr(0755,-,-) %ghost %{_bindir}/emacs
|
%attr(0755,-,-) %ghost %{_bindir}/emacs
|
||||||
%attr(0755,-,-) %ghost %{_bindir}/emacs-nox
|
%attr(0755,-,-) %ghost %{_bindir}/emacs-nox
|
||||||
@ -500,7 +508,140 @@ update-desktop-database &> /dev/null || :
|
|||||||
%dir %{_datadir}/emacs/site-lisp
|
%dir %{_datadir}/emacs/site-lisp
|
||||||
%dir %{_datadir}/emacs/site-lisp/site-start.d
|
%dir %{_datadir}/emacs/site-lisp/site-start.d
|
||||||
|
|
||||||
|
%files devel
|
||||||
|
%{_includedir}/emacs-module.h
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Jul 21 2022 Fedora Release Engineering <releng@fedoraproject.org> - 1:28.1-3
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild
|
||||||
|
|
||||||
|
* Thu Jul 14 2022 Dan Čermák <dan.cermak@cgc-instruments.com> - 1:28.1-2
|
||||||
|
- Obsolete emacs-transient to prevent update issues, fixes rhbz#2107269
|
||||||
|
|
||||||
|
* Mon Apr 4 2022 Bhavin Gandhi <bhavin7392@gmail.com> - 1:28.1-1
|
||||||
|
- emacs-28.1 is available, fixes rhbz#2071638
|
||||||
|
- Build with Native Compilation support and natively compile all .el files
|
||||||
|
- Use upstream app data file
|
||||||
|
- Use pdmp files with fingerprints
|
||||||
|
|
||||||
|
* Wed Mar 23 2022 Dan Čermák <dan.cermak@cgc-instruments.com> - 1:27.2-11
|
||||||
|
- Include upstream version of bundled glib cdefs.h, fixes rhbz#2045136
|
||||||
|
|
||||||
|
* Thu Jan 20 2022 Fedora Release Engineering <releng@fedoraproject.org> - 1:27.2-10
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild
|
||||||
|
|
||||||
|
* Sat Aug 7 2021 Dan Čermák <dan.cermak@cgc-instruments.com> - 1:27.2-9
|
||||||
|
- Add Requires: info to fix info-mode
|
||||||
|
- Fixes rhbz#1989264
|
||||||
|
|
||||||
|
* Wed Jul 21 2021 Fedora Release Engineering <releng@fedoraproject.org> - 1:27.2-8
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild
|
||||||
|
|
||||||
|
* Sun Jul 11 2021 Dan Čermák <dan.cermak@cgc-instruments.com> - 1:27.2-7
|
||||||
|
- Add patch to fix pdump page size incompatibility
|
||||||
|
- Fixes rhbz#1974244
|
||||||
|
|
||||||
|
* Sun Jun 13 2021 Dan Čermák <dan.cermak@cgc-instruments.com> - 1:27.2-6
|
||||||
|
- Swallow %%preun and %%posttrans scriptlet exit status
|
||||||
|
- Fixes rhbz#1962181
|
||||||
|
|
||||||
|
* Sat Jun 5 2021 Peter Oliver <rpm@mavit.org.uk> - 1:27.2-5
|
||||||
|
- Validate AppStream metainfo.
|
||||||
|
|
||||||
|
* Tue May 25 2021 Peter Oliver <rpm@mavit.org.uk> - 1:27.2-4
|
||||||
|
- Prefer upstream emacs.desktop.
|
||||||
|
- Remove duplicate emacs.desktop from /usr/share/emacs/27.2/etc/.
|
||||||
|
|
||||||
|
* Mon Apr 26 2021 Dan Čermák <dan.cermak@cgc-instruments.com> - 1:27.2-3
|
||||||
|
- Add emacs-modula2.patch
|
||||||
|
- Fixes rhbz#1950158
|
||||||
|
|
||||||
|
* Sat Mar 27 2021 Peter Oliver <rpm@mavit.org.uk> - 1:27.2-2
|
||||||
|
- Prefer upstream systemd service definition.
|
||||||
|
|
||||||
|
* Sat Mar 27 2021 Scott Talbert <swt@techie.net> - 1:27.1-5
|
||||||
|
- Fix FTBFS with glibc 2.34
|
||||||
|
|
||||||
|
* Thu Mar 25 2021 Bhavin Gandhi <bhavin7392@gmail.com> - 1:27.2-1
|
||||||
|
- emacs-27.2 is available
|
||||||
|
|
||||||
|
* Fri Feb 05 2021 Peter Oliver <rpm@mavit.org.uk> - 1:27.1-4
|
||||||
|
- Make Enchant the default for ispell-program-name when available.
|
||||||
|
|
||||||
|
* Tue Jan 26 2021 Fedora Release Engineering <releng@fedoraproject.org> - 1:27.1-3
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild
|
||||||
|
|
||||||
|
* Tue Aug 18 2020 Jan Synáček <jsynacek@redhat.com> - 1:27.1-2
|
||||||
|
- use make macros (original patch provided by Tom Stellard)
|
||||||
|
- https://fedoraproject.org/wiki/Changes/UseMakeBuildInstallMacro
|
||||||
|
|
||||||
|
* Tue Aug 11 2020 Bhavin Gandhi <bhavin7392@gmail.com> - 1:27.1-1
|
||||||
|
- emacs-27.1 is available (#1867841)
|
||||||
|
- Add systemd-devel to support Type=notify in unit file
|
||||||
|
- Build with Cairo and Jansson support
|
||||||
|
- Remove ImageMagick dependency as it's no longer used
|
||||||
|
|
||||||
|
* Mon Jul 27 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1:26.3-4
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild
|
||||||
|
|
||||||
|
* Thu Apr 16 2020 Dan Čermák <dan.cermak@cgc-instruments.com> - 1:26.3-3
|
||||||
|
- Drop dependency on GConf2
|
||||||
|
|
||||||
|
* Tue Jan 28 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1:26.3-2
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild
|
||||||
|
|
||||||
|
* Sun Sep 08 2019 Maximiliano Sandoval <msandoval@protonmail.com> - 1:26.3-1
|
||||||
|
- emacs-26.3 is available (#1747101)
|
||||||
|
|
||||||
|
* Wed Jul 24 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1:26.2-2
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
|
||||||
|
|
||||||
|
* Wed Apr 17 2019 Jan Synáček <jsynacek@redhat.com> - 1:26.2-1
|
||||||
|
- emacs-26.2 is available (#1699434)
|
||||||
|
|
||||||
|
* Thu Jan 31 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1:26.1-8
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
|
||||||
|
|
||||||
|
* Tue Aug 28 2018 Michael Cronenworth <mike@cchtml.com> - 1:26.1-7
|
||||||
|
- Rebuild for new ImageMagick 6.9.10
|
||||||
|
|
||||||
|
* Mon Aug 13 2018 Jan Synáček <jsynacek@redhat.com> - 1:26.1-6
|
||||||
|
- remove python dependencies, emacs*.py have not been there for a while
|
||||||
|
|
||||||
|
* Thu Jul 12 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1:26.1-5
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
|
||||||
|
|
||||||
|
* Mon Jul 02 2018 Miro Hrončok <mhroncok@redhat.com> - 1:26.1-4
|
||||||
|
- Rebuilt for Python 3.7
|
||||||
|
|
||||||
|
* Tue Jun 26 2018 Jan Synáček <jsynacek@redhat.com> - 1:26.1-3
|
||||||
|
- Refix: Emacs crashes when loading color fonts (#1519038)
|
||||||
|
+ emacs SIGABRT after XProtocolError on displaying an email in Gnus (#1591223)
|
||||||
|
|
||||||
|
* Tue Jun 19 2018 Miro Hrončok <mhroncok@redhat.com> - 1:26.1-2
|
||||||
|
- Rebuilt for Python 3.7
|
||||||
|
|
||||||
|
* Wed May 30 2018 Jan Synáček <jsynacek@redhat.com> - 1:26.1-1
|
||||||
|
- emacs-26.1 is available (#1583433)
|
||||||
|
|
||||||
|
* Wed Apr 4 2018 Jan Synáček <jsynacek@redhat.com> - 1:25.3-9
|
||||||
|
- Emacs crashes when loading color fonts (#1519038)
|
||||||
|
|
||||||
|
* Sun Feb 11 2018 Sandro Mani <manisandro@gmail.com> - 1:25.3-8
|
||||||
|
- Rebuild (giflib)
|
||||||
|
|
||||||
|
* Fri Feb 09 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1:25.3-7
|
||||||
|
- Escape macros in %%changelog
|
||||||
|
|
||||||
|
* Wed Feb 07 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1:25.3-6
|
||||||
|
- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild
|
||||||
|
|
||||||
|
* Fri Jan 12 2018 Tomas Popela <tpopela@redhat.com> - 1:25.3-5
|
||||||
|
- Adapt to the webkitgtk4 rename
|
||||||
|
|
||||||
|
* Thu Jan 11 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1:25.3-4
|
||||||
|
- Remove obsolete scriptlets
|
||||||
|
|
||||||
* Thu Sep 14 2017 Pete Walter <pwalter@fedoraproject.org> - 1:25.3-3
|
* Thu Sep 14 2017 Pete Walter <pwalter@fedoraproject.org> - 1:25.3-3
|
||||||
- Rebuilt for ImageMagick 6.9.9 soname bump
|
- Rebuilt for ImageMagick 6.9.9 soname bump
|
||||||
|
|
||||||
@ -681,7 +822,7 @@ update-desktop-database &> /dev/null || :
|
|||||||
- remove /usr/bin/emacs-nox from install section
|
- remove /usr/bin/emacs-nox from install section
|
||||||
|
|
||||||
* Mon Aug 04 2014 Petr Hracek <phracek@redhat.com> - 1:24.3-21
|
* Mon Aug 04 2014 Petr Hracek <phracek@redhat.com> - 1:24.3-21
|
||||||
- /usr/bin/emacs-nox link marked as %ghost file (#1123573)
|
- /usr/bin/emacs-nox link marked as %%ghost file (#1123573)
|
||||||
|
|
||||||
* Fri Aug 01 2014 Petr Hracek <phracek@redhat.com> - 1:24.3-20
|
* Fri Aug 01 2014 Petr Hracek <phracek@redhat.com> - 1:24.3-20
|
||||||
- Provide /usr/bin/emacs-nox (#1123573)
|
- Provide /usr/bin/emacs-nox (#1123573)
|
||||||
|
53
gpgkey-17E90D521672C04631B1183EE78DAE0F3115E06B.gpg
Normal file
53
gpgkey-17E90D521672C04631B1183EE78DAE0F3115E06B.gpg
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||||
|
Comment: 17E9 0D52 1672 C046 31B1 183E E78D AE0F 3115 E06B
|
||||||
|
Comment: Eli Zaretskii <eliz@gnu.org>
|
||||||
|
|
||||||
|
xsFNBGIorlcBEADDfvr2wRY5BvUYDRelVXoyPg9kmufSw7M4mNRgjJ/ACzTL0DrT
|
||||||
|
/MiItj/9hFYofCKvqbKNXoidD0K8yW3hg6C4EKEBdh7Tgd1owcn6R4QlxPyWd9a+
|
||||||
|
bJBf/9TV4RtJDdgFSysxpg+q6IiKu91+RH6ioHMHHbMt1VHV8hRwrfr/z9NbWGKw
|
||||||
|
Q5V3dyd+bJcxa2Jrq4Bai1JUj3CJFXmLq7tRqnJwXWURgmyG2R6hV0pGiscxcIAt
|
||||||
|
+aP6iFPVIjOg7y8ttI2DoTA59pqpRD1kcQ3h9wgzRHIKKJwlEkhudeoGgwciGPyp
|
||||||
|
GYKDC5gY02BFRcEr669DP24toJ9RiGA6YBg6ajZZ4k/qLBoBChN9HrbnG+Jh2/ZC
|
||||||
|
ncXTpnwQpGOrdJ20kdUI816PoUISIVTrb2jXJbiYVsJ1PVXYKoSOBr4Zdk2KJLLB
|
||||||
|
L69QCJLf3ERaV4t7lknpSVqyglSPnuQf42FmdXwsu4w4BoD+p2oKsqWaNVIWjCwH
|
||||||
|
kBXCVxhs0lqpce8X60tQ3fo66QQ0UyznEg0wOYFxDqnMo2DF2YMTMW+GQ5W1gHEr
|
||||||
|
+Ehtz4lV/PMlUaTc0bIPz05+b18WWNSZl7squblpJHvjsEjb01W20EZGIiXFwNpJ
|
||||||
|
LepB3Pnvalhmyuq8lB7ISZH5C1dSUzxIr863I8kjVS74GFsi0sKF4mjpcwARAQAB
|
||||||
|
zRxFbGkgWmFyZXRza2lpIDxlbGl6QGdudS5vcmc+wsGOBBMBCgA4FiEEF+kNUhZy
|
||||||
|
wEYxsRg+542uDzEV4GsFAmIorlcCGwMFCwkIBwIGFQoJCAsCBBYCAwECHgECF4AA
|
||||||
|
CgkQ542uDzEV4GvMPQ//XJOVwvXE0AWHt6XHBQa5vgpZlabRuQQ9C5Di/eC8zs2X
|
||||||
|
TCvkUzGsuDwW0H/Ne+nFp8m97Ykd4Z/02HPf4YVFyF4EEM4q7ThSxbpVsagZ8YJl
|
||||||
|
VckZauLxFE36M/Ask1WwJalMNLudPULJXKe8h7JciHPnO6axCzXkWrR7jr199rSo
|
||||||
|
VdKwuvPcEe9Iu9nophxkaUO2Bls7UFDmA4SkGfeu9L2XJbaxkVooCRf7oazWrUaj
|
||||||
|
ts3X7bQZDeiOvjJQsLUOQDb6b99Y9XFV0rpj2hIlIla0owmPw96kWaF7/m18Hqyt
|
||||||
|
RcHBcscOrR1lZfG/mu+bd+kBccFF58d9XJiyzF8qNp5drXh0CvVSRPwtyXD19jF2
|
||||||
|
mkPLR+sqYPcUavZJN+Zlx6OuhF6b969IRuo04QP82Z6uzoG6XUQdtvSvQuaumwiX
|
||||||
|
QX4V8ZwLgDpjtGWK8s/fSBDOyedPDhLzjQ2Iz2uzWHPFSzisVuD0FBFLv/MzylGo
|
||||||
|
XvkroFcM+o1phc9QELnfQie3mCDHmIxnDJvEKgdAVagN44DlD3/5NtVq0TbZDy+I
|
||||||
|
qTBtX13eBrJ6f/31Mzvlw9C6orbFT9t8hlwg4kqLYCGKEYwW9LIKOcwrWiW5L+cI
|
||||||
|
VoTQaqVvk7++9Qv4Hz/JfWsI7vsuXfrh6fo+oI0x1OhCjRLgmsrFyYiM8bS09ODO
|
||||||
|
wU0EYiiuVwEQANRJHvhVcTBssEJiJW1RK/FrlS8SBrwQczM3UxBbnNsD4PjYQvEA
|
||||||
|
oF9r6qTB5+rWuIYLqsIIdRMrbxsDXyrRI3rGhXAjZMNSuvt4ShmUzHMWXT5S2/xJ
|
||||||
|
TvPVs4WSlUc6Z/His31JpM6Pw5vEg2KklcvYfCuO2CM6xjgS+uyNT7MnVYOZEkil
|
||||||
|
GdjpEqoQ5SqE6iXlvcTujTrNt1cotpi5SKFT+eSV4QXbIpvIJvIpzDtT3SOTN4JD
|
||||||
|
6dcrbYHiYOnBBcbYL/rPDObwCUlK01ed+UkiZU24ByJdpLRhBHeH0wS1OIhdeWEJ
|
||||||
|
Iqae4JQ3L76ZBGorjQOlLy/KCKAifwi4pyjssnvcyYrRFwamRl4DVjNsbydzr+Em
|
||||||
|
SSmxiLaBron9q8PYTaTBzDdSgHNEaJxTsYW0oxCf3iSAOtTNq99CJwd/xTQd+9Ou
|
||||||
|
JAnyA9Km5zL8idFk9BaFpGGXf+kOB7Wd66E2ThdBuz7GiVd+2B9n70cOuMCrt58M
|
||||||
|
lsD/yRVfABSspfIWd2yjOp4qvjX/xiv41s89l0bi6mmozauWkQIA+zaEdpUIA82m
|
||||||
|
nhsTdgvRBxvubJbTDjXT7R26hk2bm7bQQWe4HZYfSTh1RvAokg4/ZoFu1EKWreuw
|
||||||
|
uSzuJCW/KKyvfiabjNQE1n7z+Pqfnfke9xhSRZx3QHJlu6peAMAODJo5ABEBAAHC
|
||||||
|
wXYEGAEKACAWIQQX6Q1SFnLARjGxGD7nja4PMRXgawUCYiiuVwIbDAAKCRDnja4P
|
||||||
|
MRXga1AWD/0Z8yTCJR5oES4m+Yrarn7g6xIYaf2t94J+1qBXHdK5zpSXjt122+ys
|
||||||
|
5bNGFS/R2qB1CxxjJURze9g1nv8n9Rh1xWxd7j0/oFAziluGeybkSJ4iReb1qfIF
|
||||||
|
bn1HvLiD4Cz1RjGDaIScZiuLg1qXjXUcOr90EQ5O8hAnLAeb8kR8d5PeMDfPVfP2
|
||||||
|
2pRM5Hwy3pxeK7zSidrYBSH8PcRuJogS3p3GnNxQoolEtf6qQoDm09Mqi83fvXHE
|
||||||
|
kLh2accy3HuqTekRxL19/IS2lIRmI5CO9Z8gwOVJrJ+YQklqR0VEpgzGcZD85Haw
|
||||||
|
BrmrKV8Eap62Pm8UPwFnOevJ6dj5nhFMc04gHeOjhUsQR7fKNspaYt1O6DiGXhf6
|
||||||
|
yyeEyZu+38hpqqKJ8rMHF64ltbzwOyTiADgR9n8r6wIFBhIyVShhuKgeNpaTJaJ5
|
||||||
|
kNuc3kYwPV8bliblKiYdkN/dSWEn8TDW5cAhKyxyRho0XoZoDO54/sfApSEHM/S1
|
||||||
|
43PMSZp+0WpV/znm87mv68DhzMBby45MaIfcPFszbvtTyLDK/vcQKenTQIG/CFZ3
|
||||||
|
cIrRlfOjtQf2abs/xxfQXknl38jD6IXG3g/kN9XVLRXVYPK58nNnjaU0b2Cb1gy8
|
||||||
|
keZsV/4wEN1Mipv0SFLcd5zNzirfAlJMecPv8cCNHDkA8IOR7zp/VQ==
|
||||||
|
=+3ql
|
||||||
|
-----END PGP PUBLIC KEY BLOCK-----
|
3
sources
3
sources
@ -1 +1,2 @@
|
|||||||
SHA512 (emacs-25.3.tar.xz) = 1cce656451b6ca8502ebb229e88bd3ef48b7f9444a10eeac4ea43bd5491b2efacd641dfa35227a33362c3866493d3449cf1df81606563eef44bba0ed668e457f
|
SHA512 (emacs-28.1.tar.xz) = c146ff7086aba49fa6c18adf4e485a59eb4c6525fddb9d385034446830b8bb0ac9e6fb76e7b6d94a9fddc41643415f36acad57a1ae16a841c97f61bc211459d9
|
||||||
|
SHA512 (emacs-28.1.tar.xz.sig) = cc905fb3d75c2f03c491fb1e0edd883312147d65125a667dcf77e6a078a6381f0674e321feba24a205d819275b6f31282a54910b3fc1c1284421a0fd35a2882a
|
||||||
|
Loading…
Reference in New Issue
Block a user