[arch-commits] Commit in sagemath-doc/trunk (6 files)

Antonio Rojas arojas at archlinux.org
Fri Aug 5 13:01:03 UTC 2016


    Date: Friday, August 5, 2016 @ 13:01:03
  Author: arojas
Revision: 185317

Update to 7.3

Added:
  sagemath-doc/trunk/sagemath-ipython5.patch
Modified:
  sagemath-doc/trunk/PKGBUILD
  sagemath-doc/trunk/disable-fes.patch
  sagemath-doc/trunk/is-package-installed.patch
  sagemath-doc/trunk/linbox-1.4.patch
  sagemath-doc/trunk/paths.patch

----------------------------+
 PKGBUILD                   |   26 +-
 disable-fes.patch          |    6 
 is-package-installed.patch |   56 ++--
 linbox-1.4.patch           |   50 +--
 paths.patch                |   34 --
 sagemath-ipython5.patch    |  548 +++++++++++++++++++++++++++++++++++++++++++
 6 files changed, 621 insertions(+), 99 deletions(-)

Modified: PKGBUILD
===================================================================
--- PKGBUILD	2016-08-05 12:54:53 UTC (rev 185316)
+++ PKGBUILD	2016-08-05 13:01:03 UTC (rev 185317)
@@ -3,22 +3,23 @@
 
 pkgbase=sagemath-doc
 pkgname=(sagemath-doc sagemath-src)
-pkgver=7.2
-pkgrel=2
+pkgver=7.3
+pkgrel=1
 arch=(any)
 url="http://www.sagemath.org"
 license=(GPL)
 makedepends=(sagemath sage-notebook python2-pyzmq python2-pillow python2-docutils ipython2-notebook python2-pkgconfig cython2 python2-sphinx)
 source=("$pkgbase-$pkgver.tar.gz::https://github.com/sagemath/sage/archive/$pkgver.tar.gz"
-	package.patch paths.patch disable-fes.patch docbuild_main.patch linbox-1.4.patch is-package-installed.patch ecm-7.patch)
-md5sums=('2afeb8f75a33107fef5d509698c0eabc'
+	package.patch paths.patch disable-fes.patch docbuild_main.patch linbox-1.4.patch is-package-installed.patch ecm-7.patch sagemath-ipython5.patch)
+md5sums=('cb2aed3d24de7b2228a9b34e81a27870'
          '9ba81f717ffd4e20b8b2f2a318307488'
-         '52d30e91110183489f66d7bf73c36c64'
-         '4eb23a3c7363258bc9ba764d6e5512ba'
+         '45b84ae5579273196df44f7464a01a30'
+         '06a67e611d10aa2381efe1f08ea4ffd9'
          'f3bf3fa4e11e5af2bd0573cf2620e1f8'
-         '9f1cef3e477bafebe2ad301db56db8a2'
-         '541988696465f204235d595a349017f3'
-         '0c9a57d35de80c2cd418ebec912efbbb')
+         'a276f0fbbff6eade409d0569ebd728d4'
+         'b3ecf7c93a90e0afccbc686af9fdc85f'
+         '0c9a57d35de80c2cd418ebec912efbbb'
+         '2bcaca7284dda963ebdc17daf78cf6c9')
 
 prepare() {
   cd sage-$pkgver
@@ -42,6 +43,8 @@
   patch -p0 -i ../disable-fes.patch
 # port to new fflas-ffpack/givaro/linbox http://trac.sagemath.org/ticket/17635
   patch -p1 -i ../linbox-1.4.patch
+# port to ipython 5.0 https://trac.sagemath.org/ticket/21006
+  patch -p1 -i ../sagemath-ipython5.patch
 # replace is_package_installed usage http://trac.sagemath.org/ticket/20377
   patch -p1 -i ../is-package-installed.patch
 
@@ -63,7 +66,7 @@
   export SAGE_DOC_SRC="$SAGE_SRC"/doc
   export SAGE_DOC="$SAGE_SRC"/doc
   export SAGE_DOC_MATHJAX=yes
-  export PYTHONPATH="$srcdir/sage-$pkgver/local-python"
+  export PYTHONPATH="/usr/lib/sage/site-packages:$srcdir/sage-$pkgver/local-python"
   python2 sage_setup/docbuild --no-pdf-links -k all html
 }
 
@@ -101,7 +104,4 @@
   mkdir -p "$pkgdir"/usr/share/sage/source
   cp -r sage-$pkgver/src/{sage,sage_setup} "$pkgdir"/usr/share/sage/source
   ln -s /usr/share/doc/sage/html "$pkgdir"/usr/share/sage/source/doc
-
-# remove developer interface
-  rm -r "$pkgdir"/usr/share/sage/source/sage/dev
 }

Modified: disable-fes.patch
===================================================================
--- disable-fes.patch	2016-08-05 12:54:53 UTC (rev 185316)
+++ disable-fes.patch	2016-08-05 13:01:03 UTC (rev 185317)
@@ -1,8 +1,8 @@
 --- src/module_list.py.orig	2015-06-07 11:29:30.710612146 +0200
 +++ src/module_list.py	2015-06-07 11:30:21.877506106 +0200
-@@ -685,11 +685,11 @@
-               include_dirs = [SAGE_INC + '/ecl'],
-               depends = [SAGE_INC + '/ecl/ecl.h']),
+@@ -564,11 +564,11 @@
+               sources = ["sage/libs/ecl.pyx"],
+               libraries = ["ecl"]),
  
 -    OptionalExtension("sage.libs.fes",
 -             ["sage/libs/fes.pyx"],

Modified: is-package-installed.patch
===================================================================
--- is-package-installed.patch	2016-08-05 12:54:53 UTC (rev 185316)
+++ is-package-installed.patch	2016-08-05 13:01:03 UTC (rev 185317)
@@ -2,15 +2,15 @@
 index 0a5f794..2969d92 100644
 --- a/src/sage/databases/cremona.py
 +++ b/src/sage/databases/cremona.py
-@@ -52,7 +52,6 @@ from sage.misc.prandom import randint
+@@ -53,7 +53,6 @@ from sage.misc.prandom import randint
  
  import sage.schemes.elliptic_curves.constructor as elliptic
- from sql_db import SQLDatabase, verify_column
+ from .sql_db import SQLDatabase, verify_column
 -from sage.misc.package import is_package_installed
  from sage.env import SAGE_SHARE
  from sage.misc.all import walltime
  
-@@ -827,7 +826,7 @@ class MiniCremonaDatabase(SQLDatabase):
+@@ -828,7 +827,7 @@ class MiniCremonaDatabase(SQLDatabase):
              if N < self.largest_conductor():
                  message = "There is no elliptic curve with label " + label \
                      + " in the database"
@@ -19,7 +19,7 @@
                  message = "There is no elliptic curve with label " + label \
                      + " in the currently available databases"
              else:
-@@ -1676,7 +1675,7 @@ def CremonaDatabase(name=None,mini=None,set_global=None):
+@@ -1677,7 +1676,7 @@ def CremonaDatabase(name=None,mini=None,set_global=None):
      if name is None and not set_global:
          return _db
      if set_global and name is None:
@@ -32,7 +32,7 @@
 index b917d2a..80fb20c 100644
 --- a/src/sage/game_theory/normal_form_game.py
 +++ b/src/sage/game_theory/normal_form_game.py
-@@ -612,8 +612,9 @@ from sage.rings.all import QQ
+@@ -614,8 +614,9 @@ from sage.rings.all import QQ
  from sage.structure.sage_object import SageObject
  from sage.matrix.constructor import matrix
  from sage.matrix.constructor import vector
@@ -43,7 +43,7 @@
  
  try:
      from gambit import Game
-@@ -1315,13 +1316,13 @@ class NormalFormGame(SageObject, MutableMapping):
+@@ -1317,13 +1318,13 @@ class NormalFormGame(SageObject, MutableMapping):
              raise ValueError("utilities have not been populated")
  
          if not algorithm:
@@ -63,7 +63,7 @@
 index 2f58d8b..eb519a2 100644
 --- a/src/sage/geometry/polyhedron/base.py
 +++ b/src/sage/geometry/polyhedron/base.py
-@@ -20,7 +20,6 @@ import six
+@@ -21,7 +21,6 @@ import six
  from sage.structure.element import Element, coerce_binop, is_Vector
  
  from sage.misc.all import cached_method, prod
@@ -71,7 +71,7 @@
  
  from sage.rings.all import QQ, ZZ
  from sage.rings.real_double import RDF
-@@ -3690,7 +3689,9 @@ class Polyhedron_base(Element):
+@@ -3691,7 +3690,9 @@ class Polyhedron_base(Element):
  
               David Avis's lrs program.
          """
@@ -103,7 +103,7 @@
 index 252984f..ce19682 100644
 --- a/src/sage/graphs/generic_graph.py
 +++ b/src/sage/graphs/generic_graph.py
-@@ -7833,7 +7833,6 @@ class GenericGraph(GenericGraph_pyx):
+@@ -7856,7 +7856,6 @@ class GenericGraph(GenericGraph_pyx):
             sage: abs(flow_ff-flow_igraph) < 0.00001         # optional python_igraph
             True
          """
@@ -111,7 +111,7 @@
          self._scream_if_not_simple(allow_loops=True)
          if vertex_bound and algorithm in ["FF", "igraph"]:
              raise ValueError("This method does not support both " +
-@@ -7851,10 +7850,12 @@ class GenericGraph(GenericGraph_pyx):
+@@ -7874,10 +7873,12 @@ class GenericGraph(GenericGraph_pyx):
          if algorithm is None:
              if vertex_bound:
                  algorithm = "LP"
@@ -127,7 +127,7 @@
  
          if (algorithm == "FF"):
              return self._ford_fulkerson(x,y, value_only=value_only, integer=integer, use_edge_labels=use_edge_labels)
-@@ -20134,17 +20135,22 @@ class GenericGraph(GenericGraph_pyx):
+@@ -20251,17 +20252,22 @@ class GenericGraph(GenericGraph_pyx):
              Subgroup of (Permutation Group with generators [(0,7)(1,4)(2,3)(6,8)]) generated by [(0,7)(1,4)(2,3)(6,8)]]
  
          """
@@ -156,7 +156,7 @@
  
              A = automorphism_group(self, partition)
  
-@@ -20786,17 +20792,22 @@ class GenericGraph(GenericGraph_pyx):
+@@ -20903,17 +20909,22 @@ class GenericGraph(GenericGraph_pyx):
              True
  
          """
@@ -189,7 +189,7 @@
 index 5919ab3..1766796 100644
 --- a/src/sage/graphs/graph_generators.py
 +++ b/src/sage/graphs/graph_generators.py
-@@ -1192,8 +1192,9 @@ class GraphGenerators():
+@@ -1195,8 +1195,9 @@ class GraphGenerators():
          .. [buckygen] \G. Brinkmann, J. Goedgebeur and B.D. McKay, Generation of Fullerenes,
            Journal of Chemical Information and Modeling, 52(11):2910-2918, 2012.
          """
@@ -201,7 +201,7 @@
              raise TypeError("the optional buckygen package is not installed")
  
          # number of vertices should be positive
-@@ -1277,8 +1278,9 @@ class GraphGenerators():
+@@ -1280,8 +1281,9 @@ class GraphGenerators():
          .. [benzene] \G. Brinkmann, G. Caporossi and P. Hansen, A Constructive Enumeration of Fusenes and Benzenoids,
            Journal of Algorithms, 45:155-166, 2002.
          """
@@ -213,7 +213,7 @@
              raise TypeError("the optional benzene package is not installed")
  
          # number of hexagons should be positive
-@@ -1430,8 +1432,9 @@ class GraphGenerators():
+@@ -1433,8 +1435,9 @@ class GraphGenerators():
          .. [plantri] \G. Brinkmann and B.D. McKay, Fast generation of planar graphs,
             MATCH-Communications in Mathematical and in Computer Chemistry, 58(2):323-357, 2007.
          """
@@ -225,7 +225,7 @@
              raise TypeError("the optional plantri package is not installed")
  
          # number of vertices should be positive
-@@ -1629,8 +1632,9 @@ class GraphGenerators():
+@@ -1632,8 +1635,9 @@ class GraphGenerators():
              sage: [g.size() for g in graphs.triangulations(6, minimum_connectivity=3)] # optional plantri
              [12, 12]
          """
@@ -237,7 +237,7 @@
              raise TypeError("the optional plantri package is not installed")
  
          # number of vertices should be positive
-@@ -1783,8 +1787,9 @@ class GraphGenerators():
+@@ -1786,8 +1790,9 @@ class GraphGenerators():
              sage: [len(g) for g in graphs.quadrangulations(12, no_nonfacial_quadrangles=True, dual=True)]  # optional plantri
              [10, 10]
          """
@@ -293,7 +293,7 @@
 index e42db61..d4d5684 100644
 --- a/src/sage/groups/perm_gps/permgroup.py
 +++ b/src/sage/groups/perm_gps/permgroup.py
-@@ -143,7 +143,6 @@ from sage.groups.perm_gps.permgroup_element import PermutationGroupElement, stan
+@@ -145,7 +145,6 @@ from sage.groups.perm_gps.permgroup_element import PermutationGroupElement, stan
  from sage.groups.abelian_gps.abelian_group import AbelianGroup
  from sage.misc.cachefunc import cached_method
  from sage.groups.class_function import ClassFunction
@@ -301,7 +301,7 @@
  from sage.sets.finite_enumerated_set import FiniteEnumeratedSet
  from sage.categories.all import FiniteEnumeratedSets
  from sage.groups.conjugacy_classes import ConjugacyClassGAP
-@@ -188,8 +187,6 @@ def hap_decorator(f):
+@@ -190,8 +189,6 @@ def hap_decorator(f):
      """
      @wraps(f)
      def wrapped(self, n, p=0):
@@ -310,7 +310,7 @@
          load_hap()
          from sage.arith.all import is_prime
          if not (p == 0 or is_prime(p)):
-@@ -1681,9 +1678,7 @@ class PermutationGroup_generic(group.FiniteGroup):
+@@ -1683,9 +1680,7 @@ class PermutationGroup_generic(group.FiniteGroup):
          try:
              return [Integer(n) for n in self._gap_().IdGroup()]
          except RuntimeError:
@@ -321,7 +321,7 @@
  
      def id(self):
          """
-@@ -1734,9 +1729,7 @@ class PermutationGroup_generic(group.FiniteGroup):
+@@ -1736,9 +1731,7 @@ class PermutationGroup_generic(group.FiniteGroup):
          try:
              return Integer(self._gap_().PrimitiveIdentification())
          except RuntimeError:
@@ -332,7 +332,7 @@
  
      def center(self):
          """
-@@ -4112,8 +4105,6 @@ class PermutationGroup_generic(group.FiniteGroup):
+@@ -4114,8 +4107,6 @@ class PermutationGroup_generic(group.FiniteGroup):
          - David Joyner and Graham Ellis
  
          """
@@ -345,16 +345,16 @@
 index 90e6985..21daeb0 100644
 --- a/src/sage/misc/all.py
 +++ b/src/sage/misc/all.py
-@@ -52,11 +52,6 @@ from fpickle import pickle_function, unpickle_function
+@@ -53,11 +53,6 @@ from fpickle import pickle_function, unpickle_function
  
- from dist import install_scripts
+ from .dist import install_scripts
  
--from package import (install_package,
+-from .package import (install_package,
 -        installed_packages, is_package_installed,
 -        standard_packages, optional_packages, experimental_packages,
 -        upgrade, package_versions)
 -
- from pager import pager
+ from .pager import pager
  
  lazy_import('sage.misc.sagedoc', ['browse_sage_doc',
 diff --git a/src/sage/rings/polynomial/multi_polynomial_sequence.py b/src/sage/rings/polynomial/multi_polynomial_sequence.py
@@ -361,7 +361,7 @@
 index da41cb0..49cae0b 100644
 --- a/src/sage/rings/polynomial/multi_polynomial_sequence.py
 +++ b/src/sage/rings/polynomial/multi_polynomial_sequence.py
-@@ -158,7 +158,6 @@ from sage.misc.cachefunc import cached_method
+@@ -159,7 +159,6 @@ from sage.misc.cachefunc import cached_method
  
  from types import GeneratorType
  from sage.misc.converting_dict import KeyConvertingDict
@@ -369,7 +369,7 @@
  
  from sage.structure.sequence import Sequence, Sequence_generic
  
-@@ -1428,10 +1427,11 @@ class PolynomialSequence_gf2(PolynomialSequence_generic):
+@@ -1429,10 +1428,11 @@ class PolynomialSequence_gf2(PolynomialSequence_generic):
  
          if S != []:
              if algorithm == "exhaustive_search":

Modified: linbox-1.4.patch
===================================================================
--- linbox-1.4.patch	2016-08-05 12:54:53 UTC (rev 185316)
+++ linbox-1.4.patch	2016-08-05 13:01:03 UTC (rev 185317)
@@ -53,7 +53,7 @@
  )
  
  #########################################################
-@@ -85,12 +112,6 @@ except ValueError:
+@@ -91,12 +118,6 @@ except ValueError:
  singular_libs = ['singular', 'flint', 'ntl', 'gmpxx', 'gmp', 'readline', 'm']
  
  #########################################################
@@ -66,7 +66,7 @@
  ### Library order
  #########################################################
  
-@@ -105,8 +126,7 @@ givaro_extra_compile_args =['-D__STDC_LIMIT_MACROS']
+@@ -111,8 +132,7 @@ givaro_extra_compile_args =['-D__STDC_LIMIT_MACROS']
  # at the very end of the list.
  library_order_list = [
      "singular", "ec", "ecm",
@@ -75,8 +75,8 @@
 +] + linbox_libs  + gsl_libs + [
      "pari", "flint", "ratpoints", "ecl", "glpk", "ppl",
      "arb", "fplll", "mpfi", "mpfr", "mpc", "gmp", "gmpxx",
-     "polybori",
-@@ -593,13 +613,10 @@ ext_modules = [
+     "brial",
+@@ -611,13 +631,10 @@ ext_modules = [
  
      Extension('sage.libs.linbox.linbox',
                sources = ['sage/libs/linbox/linbox.pyx'],
@@ -92,7 +92,7 @@
  
      Extension('sage.libs.lcalc.lcalc_Lfunction',
                sources = ['sage/libs/lcalc/lcalc_Lfunction.pyx'],
-@@ -645,9 +662,8 @@ ext_modules = [
+@@ -665,9 +682,8 @@ ext_modules = [
  
      Extension('sage.libs.singular.singular',
                sources = ['sage/libs/singular/singular.pyx'],
@@ -104,7 +104,7 @@
  
      Extension('sage.libs.singular.polynomial',
                sources = ['sage/libs/singular/polynomial.pyx'],
-@@ -667,8 +683,7 @@ ext_modules = [
+@@ -687,8 +703,7 @@ ext_modules = [
      Extension('sage.libs.singular.function',
                sources = ['sage/libs/singular/function.pyx'],
                libraries = singular_libs,
@@ -114,7 +114,7 @@
  
      Extension('sage.libs.singular.option',
                sources = ['sage/libs/singular/option.pyx'],
-@@ -923,19 +938,17 @@ ext_modules = [
+@@ -944,19 +959,17 @@ ext_modules = [
      Extension('sage.matrix.matrix_modn_dense_float',
                sources = ['sage/matrix/matrix_modn_dense_float.pyx'],
                language="c++",
@@ -122,7 +122,7 @@
 +              libraries = linbox_libs + cblas_libs,
                library_dirs = cblas_library_dirs,
 -              include_dirs = cblas_include_dirs,
--              extra_compile_args = ['-DDISABLE_COMMENTATOR'] + givaro_extra_compile_args),
+-              extra_compile_args = nocxx11_args + ['-DDISABLE_COMMENTATOR'] + givaro_extra_compile_args),
 +              include_dirs = cblas_include_dirs),
  
      Extension('sage.matrix.matrix_modn_dense_double',
@@ -132,13 +132,13 @@
 +              libraries = linbox_libs + cblas_libs,
                library_dirs = cblas_library_dirs,
                include_dirs = cblas_include_dirs,
--              extra_compile_args = ["-D_XPG6", "-DDISABLE_COMMENTATOR"]
+-              extra_compile_args = nocxx11_args + ["-D_XPG6", "-DDISABLE_COMMENTATOR"]
 -                    + m4ri_extra_compile_args + givaro_extra_compile_args),
 +              extra_compile_args = ["-D_XPG6"]),
  
      Extension('sage.matrix.matrix_modn_sparse',
                sources = ['sage/matrix/matrix_modn_sparse.pyx']),
-@@ -1374,8 +1387,7 @@ ext_modules = [
+@@ -1400,8 +1413,7 @@ ext_modules = [
      Extension('sage.rings.finite_rings.element_givaro',
                sources = ["sage/rings/finite_rings/element_givaro.pyx"],
                libraries = ['givaro', 'ntl', 'gmpxx', 'gmp', 'm'],
@@ -148,7 +148,7 @@
  
      Extension('sage.rings.finite_rings.element_ntl_gf2e',
                sources = ['sage/rings/finite_rings/element_ntl_gf2e.pyx'],
-@@ -1395,8 +1407,7 @@ ext_modules = [
+@@ -1421,8 +1433,7 @@ ext_modules = [
                sources = ["sage/rings/finite_rings/hom_finite_field_givaro.pyx"],
                # this order is needed to compile under windows.
                libraries = ['givaro', 'ntl', 'gmpxx', 'gmp', 'm'],
@@ -158,7 +158,7 @@
  
      ################################
      ##
-@@ -1548,8 +1559,7 @@ ext_modules = [
+@@ -1574,8 +1585,7 @@ ext_modules = [
      Extension('sage.rings.polynomial.plural',
                sources = ['sage/rings/polynomial/plural.pyx'],
                libraries = ['m', 'readline', 'singular', 'givaro', 'gmpxx', 'gmp'],
@@ -214,7 +214,7 @@
 +# distutils: libraries = FFLASFFPACK_LIBRARIES
 +# distutils: library_dirs = FFLASFFPACK_LIBDIR
 +
- from modular cimport ModDoubleField, ModFloatField, ModDoubleFieldElement, ModFloatFieldElement
+ from .modular cimport ModDoubleField, ModFloatField, ModDoubleFieldElement, ModFloatFieldElement
  
  cdef extern from "fflas-ffpack/fflas-ffpack.h" namespace "std":
 diff --git a/src/sage/libs/linbox/linbox.pyx b/src/sage/libs/linbox/linbox.pyx
@@ -264,7 +264,7 @@
 index 33d7f7ec..77f6e0a 100644
 --- a/src/sage/libs/singular/singular.pyx
 +++ b/src/sage/libs/singular/singular.pyx
-@@ -22,6 +22,7 @@ cdef extern from "limits.h":
+@@ -23,6 +23,7 @@ cdef extern from "limits.h":
  
  import os
  
@@ -272,7 +272,7 @@
  from sage.libs.singular.decl cimport intvec
  from sage.libs.singular.decl cimport SR_HDL, SR_INT, SR_TO_INT
  from sage.libs.singular.decl cimport singular_options, singular_verbose_options
-@@ -155,7 +156,7 @@ cdef FFgivE si2sa_GFqGivaro(number *n, ring *_ring, Cache_givaro cache):
+@@ -156,7 +157,7 @@ cdef FFgivE si2sa_GFqGivaro(number *n, ring *_ring, Cache_givaro cache):
      order = cache.objectptr.cardinality() - 1
  
      while z:
@@ -365,7 +365,7 @@
 index d32b5cf..f2afa44 100644
 --- a/src/sage/rings/finite_rings/element_givaro.pyx
 +++ b/src/sage/rings/finite_rings/element_givaro.pyx
-@@ -58,8 +58,9 @@ from sage.misc.randstate cimport randstate, current_randstate
+@@ -59,8 +59,9 @@ from sage.misc.randstate cimport randstate, current_randstate
  from sage.rings.finite_rings.finite_field_base cimport FiniteField
  from sage.rings.ring cimport Ring
  from element_ext_pari import FiniteField_ext_pariElement
@@ -376,7 +376,7 @@
  import operator
  import sage.arith.all
  import finite_field_constructor as finite_field
-@@ -373,18 +374,16 @@ cdef class Cache_givaro(SageObject):
+@@ -374,18 +375,16 @@ cdef class Cache_givaro(SageObject):
          elif isinstance(e, int) or \
               isinstance(e, Integer) or \
               isinstance(e, long) or is_IntegerMod(e):
@@ -399,8 +399,8 @@
  
          elif isinstance(e, str):
              return self.parent(eval(e.replace("^","**"),self.parent.gens_dict()))
-@@ -394,8 +393,8 @@ cdef class Cache_givaro(SageObject):
-                 raise TypeError, "e.parent must match self.vector_space"
+@@ -395,8 +394,8 @@ cdef class Cache_givaro(SageObject):
+                 raise TypeError("e.parent must match self.vector_space")
              ret = self._zero_element
              for i in range(len(e)):
 -                e_entry = e[i] % self.characteristic()
@@ -410,8 +410,8 @@
                  to_add = make_FiniteField_givaroElement(self, res)
                  ret = ret + to_add*self.parent.gen()**i
              return ret
-@@ -434,8 +433,8 @@ cdef class Cache_givaro(SageObject):
-                 raise ValueError, "list is too long"
+@@ -435,8 +434,8 @@ cdef class Cache_givaro(SageObject):
+                 raise ValueError("list is too long")
              ret = self._zero_element
              for i in range(len(e)):
 -                e_entry = e[i] % self.characteristic()
@@ -421,7 +421,7 @@
                  to_add = make_FiniteField_givaroElement(self, res)
                  ret = ret + to_add*self.parent.gen()**i
              return ret
-@@ -572,19 +571,17 @@ cdef class Cache_givaro(SageObject):
+@@ -573,19 +572,17 @@ cdef class Cache_givaro(SageObject):
          cdef int ret = k.zero
          cdef int a = k.indeterminate()
          cdef int at = k.one
@@ -431,7 +431,7 @@
 +        cdef int t, i
  
          if n<0 or n>k.cardinality():
-             raise TypeError, "n must be between 0 and self.order()"
+             raise TypeError("n must be between 0 and self.order()")
  
 -        _n = n
 -
@@ -449,7 +449,7 @@
 index adbaab3..c431f6d 100644
 --- a/src/sage/rings/finite_rings/finite_field_givaro.py
 +++ b/src/sage/rings/finite_rings/finite_field_givaro.py
-@@ -269,7 +269,8 @@ class FiniteField_givaro(FiniteField):
+@@ -270,7 +270,8 @@ class FiniteField_givaro(FiniteField):
              sage: k(2) # indirect doctest
              0
  
@@ -459,7 +459,7 @@
              sage: k(float(2.0))
              0
  
-@@ -343,7 +344,7 @@ class FiniteField_givaro(FiniteField):
+@@ -344,7 +345,7 @@ class FiniteField_givaro(FiniteField):
              sage: k(pari('Mod(1,2)'))
              1
              sage: k(pari('Mod(2,3)'))

Modified: paths.patch
===================================================================
--- paths.patch	2016-08-05 12:54:53 UTC (rev 185316)
+++ paths.patch	2016-08-05 13:01:03 UTC (rev 185317)
@@ -1,39 +1,13 @@
 --- src/sage/env.py.orig	2014-06-25 10:47:25.827203554 +1200
 +++ src/sage/env.py	2014-06-25 10:49:07.667402821 +1200
-@@ -87,25 +87,22 @@
- _add_variable_or_fallback('LOCAL_IDENTIFIER','$HOSTNAME.%s'%os.getpid())
+@@ -90,8 +90,8 @@
  
  # bunch of sage directories and files
--_add_variable_or_fallback('SAGE_ROOT',       None)
+ _add_variable_or_fallback('SAGE_ROOT',       None)
 -_add_variable_or_fallback('SAGE_LOCAL',      opj('$SAGE_ROOT', 'local'))
 -_add_variable_or_fallback('SAGE_ETC',        opj('$SAGE_LOCAL', 'etc'))
--_add_variable_or_fallback('SAGE_INC',        opj('$SAGE_LOCAL', 'include'))
--_add_variable_or_fallback('SAGE_SHARE',      opj('$SAGE_LOCAL', 'share'))
-+_add_variable_or_fallback('SAGE_ROOT',       '/usr')
 +_add_variable_or_fallback('SAGE_LOCAL',      '/usr')
 +_add_variable_or_fallback('SAGE_ETC',        '/etc/sage')
-+_add_variable_or_fallback('SAGE_INC',        opj('$SAGE_LOCAL', 'include'))
-+_add_variable_or_fallback('SAGE_SHARE',      opj('$SAGE_LOCAL', 'share', 'sage'))
+ _add_variable_or_fallback('SAGE_INC',        opj('$SAGE_LOCAL', 'include'))
+ _add_variable_or_fallback('SAGE_SHARE',      opj('$SAGE_LOCAL', 'share'))
  
- _add_variable_or_fallback('SAGE_SRC',        opj('$SAGE_ROOT', 'src'))
--_add_variable_or_fallback('SITE_PACKAGES',   site.getsitepackages())
-+_add_variable_or_fallback('SITE_PACKAGES',   site.getsitepackages()+['/usr/lib/sage/site-packages'])
- _add_variable_or_fallback('SAGE_LIB',        SITE_PACKAGES[0])
- 
- _add_variable_or_fallback('SAGE_CYTHONIZED', opj('$SAGE_SRC', 'build', 'cythonized'))
- 
--_add_variable_or_fallback('SAGE_EXTCODE',    opj('$SAGE_SHARE', 'sage', 'ext'))
--_add_variable_or_fallback('SAGE_LOGS',       opj('$SAGE_ROOT', 'logs', 'pkgs'))
--_add_variable_or_fallback('SAGE_SPKG_INST',  opj('$SAGE_LOCAL', 'var', 'lib', 'sage', 'installed'))
--_add_variable_or_fallback('SAGE_DOC_SRC',    opj('$SAGE_SRC', 'doc'))
--_add_variable_or_fallback('SAGE_DOC',        opj('$SAGE_SHARE', 'doc', 'sage'))
--_add_variable_or_fallback('DOT_SAGE',        opj(os.environ.get('HOME','$SAGE_ROOT'), '.sage'))
--_add_variable_or_fallback('SAGE_DOT_GIT',    opj('$SAGE_ROOT', '.git'))
-+_add_variable_or_fallback('SAGE_EXTCODE',    opj('$SAGE_SHARE', 'ext'))
-+_add_variable_or_fallback('SAGE_DOC_SRC',    opj('$SAGE_SRC', 'doc'))
-+_add_variable_or_fallback('SAGE_DOC',        opj('/usr/share', 'doc', 'sage'))        
-+_add_variable_or_fallback('DOT_SAGE',        opj(os.environ.get('HOME'), '.sage'))
- _add_variable_or_fallback('SAGE_DISTFILES',  opj('$SAGE_ROOT', 'upstream'))
- 
- # misc
-

Added: sagemath-ipython5.patch
===================================================================
--- sagemath-ipython5.patch	                        (rev 0)
+++ sagemath-ipython5.patch	2016-08-05 13:01:03 UTC (rev 185317)
@@ -0,0 +1,548 @@
+diff --git a/src/sage/doctest/forker.py b/src/sage/doctest/forker.py
+index 2654016..d3daed6 100644
+--- a/src/sage/doctest/forker.py
++++ b/src/sage/doctest/forker.py
+@@ -116,10 +116,6 @@ def init_sage():
+     from sage.structure.debug_options import debug
+     debug.refine_category_hash_check = True
+ 
+-    # Disable IPython colors during doctests
+-    from sage.repl.interpreter import DEFAULT_SAGE_CONFIG
+-    DEFAULT_SAGE_CONFIG.TerminalInteractiveShell.colors = 'NoColor'
+-
+     # We import readline before forking, otherwise Pdb doesn't work
+     # os OS X: http://trac.sagemath.org/14289
+     import readline
+@@ -1088,15 +1084,13 @@ class SageDocTestRunner(doctest.DocTestRunner):
+             sage: _ = sage0.eval("import doctest, sys, os, multiprocessing, subprocess")
+             sage: _ = sage0.eval("from sage.doctest.parsing import SageOutputChecker")
+             sage: _ = sage0.eval("import sage.doctest.forker as sdf")
+-            sage: _ = sage0.eval("sdf.init_sage()")
+             sage: _ = sage0.eval("from sage.doctest.control import DocTestDefaults")
+             sage: _ = sage0.eval("DD = DocTestDefaults(debug=True)")
+             sage: _ = sage0.eval("ex1 = doctest.Example('a = 17', '')")
+             sage: _ = sage0.eval("ex2 = doctest.Example('2*a', '1')")
+             sage: _ = sage0.eval("DT = doctest.DocTest([ex1,ex2], globals(), 'doubling', None, 0, None)")
+             sage: _ = sage0.eval("DTR = sdf.SageDocTestRunner(SageOutputChecker(), verbose=False, sage_options=DD, optionflags=doctest.NORMALIZE_WHITESPACE|doctest.ELLIPSIS)")
+-            sage: sage0._prompt = r"debug: "
+-            sage: print(sage0.eval("DTR.run(DT, clear_globs=False)")) # indirect doctest
++            sage: print(sage0.eval("sdf.init_sage(); DTR.run(DT, clear_globs=False)")) # indirect doctest
+             **********************************************************************
+             Line 1, in doubling
+             Failed example:
+@@ -1110,7 +1104,6 @@ class SageDocTestRunner(doctest.DocTestRunner):
+             ...
+             sage: sage0.eval("a")
+             '...17'
+-            sage: sage0._prompt = "sage: "
+             sage: sage0.eval("quit")
+             'Returning to doctests...TestResults(failed=1, attempted=2)'
+         """
+@@ -1144,13 +1137,14 @@ class SageDocTestRunner(doctest.DocTestRunner):
+                         print(src)
+                         if ex.want:
+                             print(doctest._indent(ex.want[:-1]))
+-                    from sage.repl.interpreter import DEFAULT_SAGE_CONFIG
++                    from sage.repl.configuration import sage_ipython_config
++                    from sage.repl.prompts import DebugPrompts
+                     from IPython.terminal.embed import InteractiveShellEmbed
+-                    import copy
+-                    cfg = copy.deepcopy(DEFAULT_SAGE_CONFIG)
+-                    prompt_config = cfg.PromptManager
+-                    prompt_config.in_template = 'debug: '
+-                    prompt_config.in2_template = '.....: '
++                    cfg = sage_ipython_config.default()
++                    # Currently this doesn't work: prompts only work in pty
++                    # We keep simple_prompt=True, prompts will be "In [0]:"
++                    # cfg.InteractiveShell.prompts_class = DebugPrompts
++                    # cfg.InteractiveShell.simple_prompt = False
+                     shell = InteractiveShellEmbed(config=cfg, banner1='', user_ns=dict(globs))
+                     shell(header='', stack_depth=2)
+                 except KeyboardInterrupt:
+@@ -1248,6 +1242,7 @@ class SageDocTestRunner(doctest.DocTestRunner):
+             sage: _ = sage0.eval("ex = doctest.Example('E = EllipticCurve([0,0]); E', 'A singular Elliptic Curve')")
+             sage: _ = sage0.eval("DT = doctest.DocTest([ex], globals(), 'singular_curve', None, 0, None)")
+             sage: _ = sage0.eval("DTR = sdf.SageDocTestRunner(SageOutputChecker(), verbose=False, sage_options=DD, optionflags=doctest.NORMALIZE_WHITESPACE|doctest.ELLIPSIS)")
++            sage: old_prompt = sage0._prompt
+             sage: sage0._prompt = r"\(Pdb\) "
+             sage: sage0.eval("DTR.run(DT, clear_globs=False)") # indirect doctest
+             '... ArithmeticError("invariants " + str(ainvs) + " define a singular curve")'
+@@ -1257,7 +1252,7 @@ class SageDocTestRunner(doctest.DocTestRunner):
+             '...EllipticCurve_field.__init__(self, K, ainvs)'
+             sage: sage0.eval("p ainvs")
+             '(0, 0, 0, 0, 0)'
+-            sage: sage0._prompt = "sage: "
++            sage: sage0._prompt = old_prompt
+             sage: sage0.eval("quit")
+             'TestResults(failed=1, attempted=1)'
+         """
+diff --git a/src/sage/doctest/test.py b/src/sage/doctest/test.py
+index d69136f..a6cc4d0 100644
+--- a/src/sage/doctest/test.py
++++ b/src/sage/doctest/test.py
+@@ -360,7 +360,7 @@ Test the ``--debug`` option::
+         s...: b = 5
+         s...: a + b
+         8
+-    debug:
++    In [1]:
+     <BLANKLINE>
+     Returning to doctests...
+     **********************************************************************
+diff --git a/src/sage/interfaces/sage0.py b/src/sage/interfaces/sage0.py
+index 87bfc0b..77cd151 100644
+--- a/src/sage/interfaces/sage0.py
++++ b/src/sage/interfaces/sage0.py
+@@ -18,6 +18,7 @@ from __future__ import absolute_import
+ 
+ import cPickle
+ import os
++import re
+ 
+ from .expect import Expect, ExpectElement, FunctionElement
+ import sage.repl.preparse
+@@ -146,10 +147,17 @@ class Sage(ExtraTabCompletion, Expect):
+             if init_code is None:
+                 init_code = ['from sage.all import *', 'import cPickle']
+         else:
+-            # Disable the IPython history (implemented as SQLite database)
+-            # to avoid problems with locking.
+-            command = "sage-ipython --HistoryManager.hist_file=:memory: --colors=NoColor"
+-            prompt = "sage: "
++            command = ' '.join([
++                'sage-ipython',
++                # Disable the IPython history (implemented as SQLite database)
++                # to avoid problems with locking.
++                '--HistoryManager.hist_file=:memory:',
++                # Disable everything that prints ANSI codes
++                '--colors=NoColor',
++                '--no-term-title',
++                '--simple-prompt',
++            ])
++            prompt = re.compile('In \[\d+\]: ')
+             if init_code is None:
+                 init_code = ['import cPickle']
+ 
+diff --git a/src/sage/misc/trace.py b/src/sage/misc/trace.py
+index 0da17e7..efcaa33 100644
+--- a/src/sage/misc/trace.py
++++ b/src/sage/misc/trace.py
+@@ -54,6 +54,7 @@ def trace(code, preparse=True):
+         sage: import pexpect
+         sage: s = pexpect.spawn('sage')
+         sage: _ = s.sendline("trace('print(factor(10))'); print(3+97)")
++        sage: _ = s.expect('ipdb>', timeout=90)
+         sage: _ = s.sendline("s"); _ = s.sendline("c");
+         sage: _ = s.expect('100', timeout=90)
+ 
+diff --git a/src/sage/repl/configuration.py b/src/sage/repl/configuration.py
+new file mode 100644
+index 0000000..5034039
+--- /dev/null
++++ b/src/sage/repl/configuration.py
+@@ -0,0 +1,152 @@
++r"""
++Sage's IPython Configuration
++"""
++
++#*****************************************************************************
++#       Copyright (C) 2016 Volker Braun <vbraun.name at gmail.com>
++#
++#  Distributed under the terms of the GNU General Public License (GPL)
++#  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 __future__ import absolute_import
++
++import sys
++import copy
++from traitlets.config.loader import Config
++
++from sage.repl.prompts import SagePrompts
++
++
++# Name of the Sage IPython extension
++SAGE_EXTENSION = 'sage'
++
++
++class SageIpythonConfiguration(object):
++
++    def _doctest_mode(self):
++        """
++        Whether we are in doctest mode
++
++        This returns ``True`` during doctests.
++
++        EXAMPLES::
++        
++            sage: from sage.repl.configuration import sage_ipython_config
++            sage: sage_ipython_config._doctest_mode()
++            True
++        """
++        from sage.doctest import DOCTEST_MODE
++        return DOCTEST_MODE
++    
++    def _allow_ansi(self):
++        """
++        Whether to allow ANSI escape sequences
++
++        This returns ``False`` during doctests to avoid ANSI escape 
++        sequences.
++
++        EXAMPLES::
++        
++            sage: from sage.repl.configuration import sage_ipython_config
++            sage: sage_ipython_config._allow_ansi()
++            False
++        """
++        return (not self._doctest_mode()) and sys.stdout.isatty()
++
++    def colors(self):
++        """
++        Return the IPython color palette
++
++        This returns ``'NoColor'`` during doctests to avoid ANSI escape 
++        sequences.
++
++        EXAMPLES::
++        
++            sage: from sage.repl.configuration import sage_ipython_config
++            sage: sage_ipython_config.simple_prompt()
++            True
++        """
++        return 'LightBG' if self._allow_ansi() else 'NoColor'
++
++    def simple_prompt(self):
++        """
++        Return whether to use the simple prompt
++
++        This returns ``True`` during doctests to avoid ANSI escape sequences.
++
++        EXAMPLES::
++        
++            sage: from sage.repl.configuration import sage_ipython_config
++            sage: sage_ipython_config.simple_prompt()
++            True
++        """
++        return not self._allow_ansi()
++
++    def term_title(self):
++        """
++        Return whether to set the terminal title
++
++        This returns false during doctests to avoid ANSI escape sequences.
++
++        EXAMPLES::
++        
++            sage: from sage.repl.configuration import sage_ipython_config
++            sage: sage_ipython_config.term_title()
++            False
++        """
++        return self._allow_ansi()
++
++    def default(self):
++        """
++        Return a new default configuration object
++
++        EXAMPLES::
++        
++            sage: from sage.repl.configuration import sage_ipython_config
++            sage: sage_ipython_config.default()
++            {'InteractiveShell': {'colors': ...
++        """
++        from sage.repl.interpreter import SageTerminalInteractiveShell
++        cfg = Config(
++            TerminalIPythonApp=Config(
++                display_banner=False,
++                verbose_crash=True,
++                test_shell=False,
++                shell_class=SageTerminalInteractiveShell,
++            ),
++            InteractiveShell=Config(
++                prompts_class=SagePrompts,
++                ast_node_interactivity='all',
++                colors=self.colors(),
++                simple_prompt=self.simple_prompt(),
++                term_title=self.term_title(),
++                confirm_exit=False,
++                separate_in=''
++            ),
++            InteractiveShellApp=Config(extensions=[SAGE_EXTENSION]),
++        )
++        if self._doctest_mode():
++            # Using the file-backed history causes problems in parallel tests
++            cfg.HistoryManager = Config(hist_file=':memory:')
++        return cfg
++
++    def copy(self):
++        """
++        Return a copy of the current configuration
++
++        EXAMPLES::
++        
++            sage: from sage.repl.configuration import sage_ipython_config
++            sage: sage_ipython_config.copy()
++            {'InteractiveShell': {'colors': ...
++        """
++        try:
++            return copy.deepcopy(get_ipython().config)
++        except NameError:
++            return self.default()
++
++
++sage_ipython_config = SageIpythonConfiguration()
+diff --git a/src/sage/repl/interpreter.py b/src/sage/repl/interpreter.py
+index e0499c7..1f4eda7 100644
+--- a/src/sage/repl/interpreter.py
++++ b/src/sage/repl/interpreter.py
+@@ -102,18 +102,15 @@ Check that Cython source code appears in tracebacks::
+ #*****************************************************************************
+ 
+ 
+-import copy
+ import os
+ import re
+-import sys
+ from sage.repl.preparse import preparse
++from sage.repl.prompts import SagePrompts, InterfacePrompts
+ 
+-from traitlets.config.loader import Config
+ from traitlets import Bool, Type
+ 
+ from sage.env import SAGE_LOCAL
+-
+-SAGE_EXTENSION = 'sage'
++from sage.repl.configuration import sage_ipython_config, SAGE_EXTENSION
+ 
+ def embedded():
+     """
+@@ -370,31 +367,7 @@ class SageTestShell(SageShellOverride, TerminalInteractiveShell):
+         rc = super(SageTestShell, self).run_cell(*args, **kwds)
+ 
+ 
+-###################################################################
+-# Default configuration
+-###################################################################
+-
+-DEFAULT_SAGE_CONFIG = Config(
+-    PromptManager = Config(
+-        in_template = 'sage: ',
+-        in2_template = '....: ',
+-        justify = False,
+-        out_template = ''),
+-    TerminalIPythonApp = Config(
+-        display_banner = False,
+-        verbose_crash = True,
+-        test_shell = False,
+-        shell_class = SageTerminalInteractiveShell,
+-    ),
+-    InteractiveShell = Config(
+-        ast_node_interactivity = 'all',
+-        colors = 'LightBG' if sys.stdout.isatty() else 'NoColor',
+-        confirm_exit = False,
+-        separate_in = ''),
+-    InteractiveShellApp = Config(extensions=[SAGE_EXTENSION]),
+-)
+-
+-
++    
+ ###################################################################
+ # Transformers used in the SageInputSplitter
+ ###################################################################
+@@ -614,19 +587,17 @@ def interface_shell_embed(interface):
+         sage: shell = interface_shell_embed(gap)
+         sage: shell.run_cell('List( [1..10], IsPrime )')
+         [ false, true, true, false, true, false, true, false, false, false ]
+-        <IPython.core.interactiveshell.ExecutionResult object at 0x...>
+-    """
+-    try:
+-        cfg = copy.deepcopy(get_ipython().config)
+-    except NameError:
+-        cfg = copy.deepcopy(DEFAULT_SAGE_CONFIG)
+-    cfg.PromptManager['in_template'] = interface.name() + ': '
+-    cfg.PromptManager['in2_template'] = len(interface.name())*'.' + ': '
++        <repr(<IPython.core.interactiveshell.ExecutionResult at 0x...>) failed: 
++        AttributeError: type object 'ExecutionResult' has no attribute '__qualname__'>
+ 
++    Note that the repr error is https://github.com/ipython/ipython/issues/9756
++    """
++    cfg = sage_ipython_config.copy()
+     ipshell = InteractiveShellEmbed(config=cfg,
+                                     banner1='\n  --> Switching to %s <--\n\n'%interface,
+-                                    exit_msg = '\n  --> Exiting back to Sage <--\n')
++                                    exit_msg='\n  --> Exiting back to Sage <--\n')
+     ipshell.interface = interface
++    ipshell.prompts = InterfacePrompts(interface.name())
+ 
+     while ipshell.prefilter_manager.transformers:
+         ipshell.prefilter_manager.transformers.pop()
+@@ -669,7 +640,7 @@ def get_test_shell():
+         sage: out + err
+         ''
+     """
+-    config = copy.deepcopy(DEFAULT_SAGE_CONFIG)
++    config = sage_ipython_config.default()
+     config.TerminalIPythonApp.test_shell = True
+     config.TerminalIPythonApp.shell_class = SageTestShell
+     app = SageTerminalApp.instance(config=config)
+@@ -748,12 +719,9 @@ class SageTerminalApp(TerminalIPythonApp):
+             sage: os.environ['IPYTHONDIR'] = IPYTHONDIR
+         """
+         super(SageTerminalApp, self).load_config_file(*args, **kwds)
+-
+-        newconfig = copy.deepcopy(DEFAULT_SAGE_CONFIG)
+-
++        newconfig = sage_ipython_config.default()
+         # merge in the config loaded from file
+         newconfig.merge(self.config)
+-
+         self.config = newconfig
+ 
+     def init_shell(self):
+@@ -767,7 +735,7 @@ class SageTerminalApp(TerminalIPythonApp):
+ 
+         EXAMPLES::
+ 
+-            sage: from sage.repl.interpreter import SageTerminalApp, DEFAULT_SAGE_CONFIG
++            sage: from sage.repl.interpreter import SageTerminalApp
+             sage: app = SageTerminalApp.instance()
+             sage: app.shell
+             <sage.repl.interpreter.SageTestShell object at 0x...>
+@@ -776,7 +744,6 @@ class SageTerminalApp(TerminalIPythonApp):
+         self.shell = self.shell_class.instance(
+             parent=self,
+             config=self.config,
+-            display_banner=False,
+             profile_dir=self.profile_dir,
+             ipython_dir=self.ipython_dir)
+         self.shell.configurables.append(self)
+diff --git a/src/sage/repl/ipython_tests.py b/src/sage/repl/ipython_tests.py
+index 0fa568d..2bb34cd 100644
+--- a/src/sage/repl/ipython_tests.py
++++ b/src/sage/repl/ipython_tests.py
+@@ -100,6 +100,12 @@ Next, test the pinfo2 magic for Cython code::
+     ...
+     File:   .../sage/tests/stl_vector.pyx
+     Type:   type
++
++Test that there are no warnings being ignored internally::
++
++    sage: import warnings
++    sage: warnings.simplefilter('error');  get_test_shell()
++    <sage.repl.interpreter.SageTestShell object at 0x...>
+ '''
+ 
+ 
+diff --git a/src/sage/repl/prompts.py b/src/sage/repl/prompts.py
+new file mode 100644
+index 0000000..e885730
+--- /dev/null
++++ b/src/sage/repl/prompts.py
+@@ -0,0 +1,92 @@
++r"""
++Sage Commandline Prompts
++"""
++
++#*****************************************************************************
++#       Copyright (C) 2016 Volker Braun <vbraun.name at gmail.com>
++#
++# 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 pygments.token import Token
++from IPython.terminal.prompts import Prompts
++
++
++class SagePrompts(Prompts):
++
++    def in_prompt_tokens(self, cli=None):
++        return [
++            (Token.Prompt, 'sage: '),
++        ]
++
++    def continuation_prompt_tokens(self, cli=None, width=None):
++        return [
++            (Token.Prompt, '....: '),
++        ]
++
++    def rewrite_prompt_tokens(self):
++        return [
++            (Token.Prompt, '----> '),
++        ]
++
++    def out_prompt_tokens(self):
++        return [
++            (Token.OutPrompt, ''),
++        ]
++
++    
++class InterfacePrompts(Prompts):
++
++    def __init__(self, interface_name):
++        self.__name = interface_name
++        self.__width = len(interface_name)
++    
++    def in_prompt_tokens(self, cli=None):
++        return [
++            (Token.Prompt, self.__name + ': '),
++        ]
++
++    def continuation_prompt_tokens(self, cli=None, width=None):
++        return [
++            (Token.Prompt, '.' * self.__width + ': '),
++        ]
++
++    def rewrite_prompt_tokens(self):
++        return [
++            (Token.Prompt, '-' * self.__width + '> '),
++        ]
++
++    def out_prompt_tokens(self):
++        return [
++            (Token.OutPrompt, ''),
++        ]
++
++
++class DebugPrompts(Prompts):
++
++    def in_prompt_tokens(self, cli=None):
++        return [
++            (Token.Prompt, 'debug: '),
++        ]
++
++    def continuation_prompt_tokens(self, cli=None, width=None):
++        return [
++            (Token.Prompt, '.....: '),
++        ]
++
++    def rewrite_prompt_tokens(self):
++        return [
++            (Token.Prompt, '-----> '),
++        ]
++
++    def out_prompt_tokens(self):
++        return [
++            (Token.OutPrompt, ''),
++        ]
++
++    
++    
+diff --git a/src/sage/tests/cmdline.py b/src/sage/tests/cmdline.py
+index 0d15d82..417ec5e 100644
+--- a/src/sage/tests/cmdline.py
++++ b/src/sage/tests/cmdline.py
+@@ -385,7 +385,7 @@ def test_executable(args, input="", timeout=100.0, **kwds):
+         **********************************************************************
+         Previously executed commands:
+             s...: assert True == False
+-        debug:
++        In [1]:
+         <BLANKLINE>
+         Returning to doctests...
+         **********************************************************************



More information about the arch-commits mailing list