Hide keyboard shortcuts

Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

""" 

NTL error handler 

  

AUTHOR: 

  

- Jeroen Demeyer (2015-02-15): initial version, see :trac:`17784` 

  

- Jeroen Demeyer (2015-07-09): use standard NTL ``ErrorMsgCallback``, 

see :trac:`18875` 

""" 

  

#***************************************************************************** 

# Copyright (C) 2015 Jeroen Demeyer <jdemeyer@cage.ugent.be> 

# 

# This program is free software: you can redistribute it and/or modify 

# it under the terms of the GNU General Public License as published by 

# the Free Software Foundation, either version 2 of the License, or 

# (at your option) any later version. 

# http://www.gnu.org/licenses/ 

#***************************************************************************** 

  

  

from .ntl_tools cimport ErrorMsgCallback 

from ...cpython.string cimport char_to_str 

  

  

class NTLError(RuntimeError): 

""" 

Exceptions from the NTL library. 

  

EXAMPLES:: 

  

sage: a = ntl.ZZX([0]) 

sage: a.quo_rem(a) 

Traceback (most recent call last): 

... 

NTLError: DivRem: division by zero 

""" 

  

  

cdef void NTL_error_callback(const char* s) except *: 

raise NTLError(char_to_str(s)) 

  

  

def setup_NTL_error_callback(): 

""" 

Setup the NTL error handler callback. 

  

EXAMPLES:: 

  

sage: from sage.libs.ntl.error import setup_NTL_error_callback 

sage: setup_NTL_error_callback() 

""" 

global ErrorMsgCallback 

ErrorMsgCallback = NTL_error_callback