Dear my friends,

After I installed the sagemath 8.7 in Windows Subsystem for Linux Ubuntu
18.04, crash happend.

*(decomperssed ==> move folder to my home directory ==> sudo ./sage).*

When I first finished the installation, the first running is very normal.
However when the second time I add "alias sage='~/SageMath/sage'" and type
sage in terminal, it crashed.

what happened here? Is WSL not so stable or the bugs in Sage 8.7 made the
crash?

-- 
You received this message because you are subscribed to the Google Groups 
"sage-support" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to sage-support+unsubscr...@googlegroups.com.
To post to this group, send email to sage-support@googlegroups.com.
Visit this group at https://groups.google.com/group/sage-support.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/sage-support/CADUebW4jES4_6HJLoVAs9tFwUKBgCuGZ0d_rfJkH80r0OxLwZg%40mail.gmail.com.
For more options, visit https://groups.google.com/d/optout.
***************************************************************************

IPython post-mortem report

{'commit_hash': u'033ab93c7',
 'commit_source': 'installation',
 'default_encoding': 'UTF-8',
 'ipython_path': 
'/home/newton/SageMath/local/lib/python2.7/site-packages/IPython',
 'ipython_version': '5.8.0',
 'os_name': 'posix',
 'platform': 'Linux-4.4.0-17763-Microsoft-x86_64-with-debian-buster-sid',
 'sys_executable': '/home/newton/SageMath/local/bin/python2',
 'sys_platform': 'linux2',
 'sys_version': '2.7.15 (default, Mar 24 2019, 09:25:31) \n[GCC 7.2.0]'}

***************************************************************************



***************************************************************************

Crash traceback:

---------------------------------------------------------------------------
---------------------------------------------------------------------------
OSError              Python 2.7.15: /home/newton/SageMath/local/bin/python2
                                                   Wed May 15 05:05:23 2019
A problem occurred executing Python code.  Here is the sequence of function
calls leading up to the error, with the most recent (innermost) call last.
/home/newton/SageMath/src/bin/sage-ipython in <module>()
      1 #!/usr/bin/env sage-python23
      2 # -*- coding: utf-8 -*-
      3 """
      4 Sage IPython startup script.
      5 """
      6 
      7 # Display startup banner. Do this before anything else to give the user
      8 # early feedback that Sage is starting.
      9 from sage.misc.banner import banner
     10 banner()
     11 
     12 from sage.repl.interpreter import SageTerminalApp
     13 
     14 app = SageTerminalApp.instance()
---> 15 app.initialize()
        global app.initialize = <bound method SageTerminalApp.initialize of 
<sage.repl.interpreter.SageTerminalApp object at 0x7fade1f22850>>
     16 app.start()

<decorator-gen-110> in initialize(self=<sage.repl.interpreter.SageTerminalApp 
object>, argv=None)

/home/newton/SageMath/local/lib/python2.7/site-packages/traitlets/config/application.pyc
 in catch_config_error(method=<function initialize>, 
app=<sage.repl.interpreter.SageTerminalApp object>, *args=(None,), **kwargs={})
     72     TRAITLETS_APPLICATION_RAISE_CONFIG_FILE_ERROR = False
     73 else:
     74     raise ValueError("Unsupported value for environment variable: 
'TRAITLETS_APPLICATION_RAISE_CONFIG_FILE_ERROR' is set to '%s' which is none of 
 {'0', '1', 'false', 'true', ''}."% _envvar )
     75 
     76 
     77 @decorator
     78 def catch_config_error(method, app, *args, **kwargs):
     79     """Method decorator for catching invalid config 
(Trait/ArgumentErrors) during init.
     80 
     81     On a TraitError (generally caused by bad config), this will print 
the trait's
     82     message, and exit the app.
     83 
     84     For use on init methods, to prevent invoking excepthook on invalid 
input.
     85     """
     86     try:
---> 87         return method(app, *args, **kwargs)
        method = <function initialize at 0x7faddc6946e0>
        app = <sage.repl.interpreter.SageTerminalApp object at 0x7fade1f22850>
        args = (None,)
        kwargs = {}
     88     except (TraitError, ArgumentError) as e:
     89         app.print_help()
     90         app.log.fatal("Bad config encountered during initialization:")
     91         app.log.fatal(str(e))
     92         app.log.debug("Config at the time: %s", app.config)
     93         app.exit(1)
     94 
     95 
     96 class ApplicationError(Exception):
     97     pass
     98 
     99 
    100 class LevelFormatter(logging.Formatter):
    101     """Formatter with additional `highlevel` record
    102 

/home/newton/SageMath/local/lib/python2.7/site-packages/IPython/terminal/ipapp.pyc
 in initialize(self=<sage.repl.interpreter.SageTerminalApp object>, argv=None)
    301 
    302         return super(TerminalIPythonApp, self).parse_command_line(argv)
    303     
    304     @catch_config_error
    305     def initialize(self, argv=None):
    306         """Do actions after construct, but before starting the app."""
    307         super(TerminalIPythonApp, self).initialize(argv)
    308         if self.subapp is not None:
    309             # don't bother initializing further, starting subapp
    310             return
    311         # print self.extra_args
    312         if self.extra_args and not self.something_to_run:
    313             self.file_to_run = self.extra_args[0]
    314         self.init_path()
    315         # create the shell
--> 316         self.init_shell()
        self.init_shell = <bound method SageTerminalApp.init_shell of 
<sage.repl.interpreter.SageTerminalApp object at 0x7fade1f22850>>
    317         # and draw the banner
    318         self.init_banner()
    319         # Now a variety of things that happen after the banner is 
printed.
    320         self.init_gui_pylab()
    321         self.init_extensions()
    322         self.init_code()
    323 
    324     def init_shell(self):
    325         """initialize the InteractiveShell instance"""
    326         # Create an InteractiveShell instance.
    327         # shell.display_banner should always be False for the terminal
    328         # based app, because we call shell.show_banner() by hand below
    329         # so the banner shows *before* all extension loading stuff.
    330         self.shell = self.interactive_shell_class.instance(parent=self,
    331                         profile_dir=self.profile_dir,

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/repl/interpreter.pyc
 in init_shell(self=<sage.repl.interpreter.SageTerminalApp object>)
    743         self.shell.has_sage_extensions = SAGE_EXTENSION in 
self.extensions
    744 
    745         # Load the %lprun extension if available
    746         try:
    747             import line_profiler
    748         except ImportError:
    749             pass
    750         else:
    751             self.extensions.append('line_profiler')
    752 
    753         if self.shell.has_sage_extensions:
    754             self.extensions.remove(SAGE_EXTENSION)
    755 
    756             # load sage extension here to get a crash if
    757             # something is wrong with the sage library
--> 758             self.shell.extension_manager.load_extension(SAGE_EXTENSION)
        self.shell.extension_manager.load_extension = <bound method 
ExtensionManager.load_extension of <IPython.core.extensions.ExtensionManager 
object at 0x7fadd113c950>>
        global SAGE_EXTENSION = 'sage'
    759 
    760 

/home/newton/SageMath/local/lib/python2.7/site-packages/IPython/core/extensions.pyc
 in load_extension(self=<IPython.core.extensions.ExtensionManager object>, 
module_str='sage')
     70 
     71         Returns the string "already loaded" if the extension is already 
loaded,
     72         "no load function" if the module doesn't have a 
load_ipython_extension
     73         function, or None if it succeeded.
     74         """
     75         if module_str in self.loaded:
     76             return "already loaded"
     77         
     78         from IPython.utils.syspathcontext import prepended_to_syspath
     79         
     80         with self.shell.builtin_trap:
     81             if module_str not in sys.modules:
     82                 with prepended_to_syspath(self.ipython_extension_dir):
     83                     __import__(module_str)
     84             mod = sys.modules[module_str]
---> 85             if self._call_load_ipython_extension(mod):
        self._call_load_ipython_extension = <bound method 
ExtensionManager._call_load_ipython_extension of 
<IPython.core.extensions.ExtensionManager object at 0x7fadd113c950>>
        mod = <module 'sage' from 
'/home/newton/SageMath/local/lib/python2.7/site-packages/sage/__init__.pyc'>
     86                 self.loaded.add(module_str)
     87             else:
     88                 return "no load function"
     89 
     90     def unload_extension(self, module_str):
     91         """Unload an IPython extension by its module name.
     92 
     93         This function looks up the extension's name in ``sys.modules`` 
and
     94         simply calls ``mod.unload_ipython_extension(self)``.
     95         
     96         Returns the string "no unload function" if the extension 
doesn't define
     97         a function to unload itself, "not loaded" if the extension 
isn't loaded,
     98         otherwise None.
     99         """
    100         if module_str not in self.loaded:

/home/newton/SageMath/local/lib/python2.7/site-packages/IPython/core/extensions.pyc
 in _call_load_ipython_extension(self=<IPython.core.extensions.ExtensionManager 
object>, mod=<module 'sage' from 
'/home/newton/SageMath/local/lib/python2.7/site-packages/sage/__init__.pyc'>)
    117         """
    118         from IPython.utils.syspathcontext import prepended_to_syspath
    119 
    120         if (module_str in self.loaded) and (module_str in sys.modules):
    121             self.unload_extension(module_str)
    122             mod = sys.modules[module_str]
    123             with prepended_to_syspath(self.ipython_extension_dir):
    124                 reload(mod)
    125             if self._call_load_ipython_extension(mod):
    126                 self.loaded.add(module_str)
    127         else:
    128             self.load_extension(module_str)
    129 
    130     def _call_load_ipython_extension(self, mod):
    131         if hasattr(mod, 'load_ipython_extension'):
--> 132             mod.load_ipython_extension(self.shell)
        mod.load_ipython_extension = <function load_ipython_extension at 
0x7fade405c848>
        self.shell = <sage.repl.interpreter.SageTerminalInteractiveShell object 
at 0x7faddc62d910>
    133             return True
    134 
    135     def _call_unload_ipython_extension(self, mod):
    136         if hasattr(mod, 'unload_ipython_extension'):
    137             mod.unload_ipython_extension(self.shell)
    138             return True
    139 
    140     def install_extension(self, url, filename=None):
    141         """Download and install an IPython extension. 
    142 
    143         If filename is given, the file will be so named (inside the 
extension
    144         directory). Otherwise, the name from the URL will be used. The 
file must
    145         have a .py or .zip extension; otherwise, a ValueError will be 
raised.
    146 
    147         Returns the full path to the installed file.

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/__init__.pyc in 
load_ipython_extension(*args=(<sage.repl.interpreter.SageTerminalInteractiveShell
 object>,))
      1 __all__ = ['all']
      2 
      3 # Set sage.__version__ to the current version number. This is analogous
      4 # to many other Python packages.
      5 from sage.version import version as __version__
      6 
      7 # Make sure that the correct zlib library is loaded. This is needed
      8 # to prevent the system zlib to be loaded instead of the Sage one.
      9 # See https://trac.sagemath.org/ticket/23122
     10 import zlib
     11 
     12 # IPython calls this when starting up
     13 def load_ipython_extension(*args):
     14     import sage.repl.ipython_extension
---> 15     sage.repl.ipython_extension.load_ipython_extension(*args)
        sage.repl.ipython_extension.load_ipython_extension = <function 
load_ipython_extension at 0x7fadd0c9d230>
        args = (<sage.repl.interpreter.SageTerminalInteractiveShell object at 
0x7faddc62d910>,)
     16 
     17 
     18 # Monkey-patch inspect.isfunction() to support Cython functions.
     19 def isfunction(obj):
     20     """
     21     Check whether something is a function.
     22 
     23     We assume that anything which has a genuine ``__code__``
     24     attribute (not using ``__getattr__`` overrides) is a function.
     25     This is meant to support Cython functions.
     26 
     27     EXAMPLES::
     28 
     29         sage: from inspect import isfunction
     30         sage: def f(): pass
     31         sage: isfunction(f)

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/repl/ipython_extension.pyc
 in wrapper(*args=(<sage.repl.interpreter.SageTerminalInteractiveShell 
object>,), **kwargs={})
    547         ....:     if work:
    548         ....:         return 'foo worked'
    549         ....:     raise RuntimeError("foo didn't work")
    550         sage: foo(False)
    551         Traceback (most recent call last):
    552         ...
    553         RuntimeError: foo didn't work
    554         sage: foo(True)
    555         'foo worked'
    556         sage: foo(False)
    557         sage: foo(True)
    558     """
    559     @wraps(func)
    560     def wrapper(*args, **kwargs):
    561         if not wrapper.has_run:
--> 562             result = func(*args, **kwargs)
        result = undefined
        global func = undefined
        args = (<sage.repl.interpreter.SageTerminalInteractiveShell object at 
0x7faddc62d910>,)
        kwargs = {}
    563             wrapper.has_run = True
    564             return result
    565     wrapper.has_run = False
    566     return wrapper
    567 
    568 
    569 @run_once
    570 def load_ipython_extension(ip):
    571     """
    572     Load the extension in IPython.
    573     """
    574     # this modifies ip
    575     SageCustomizations(shell=ip)

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/repl/ipython_extension.pyc
 in 
load_ipython_extension(ip=<sage.repl.interpreter.SageTerminalInteractiveShell 
object>)
    560     def wrapper(*args, **kwargs):
    561         if not wrapper.has_run:
    562             result = func(*args, **kwargs)
    563             wrapper.has_run = True
    564             return result
    565     wrapper.has_run = False
    566     return wrapper
    567 
    568 
    569 @run_once
    570 def load_ipython_extension(ip):
    571     """
    572     Load the extension in IPython.
    573     """
    574     # this modifies ip
--> 575     SageCustomizations(shell=ip)
        global SageCustomizations = <class 
'sage.repl.ipython_extension.SageCustomizations'>
        global shell = undefined
        ip = <sage.repl.interpreter.SageTerminalInteractiveShell object at 
0x7faddc62d910>

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/repl/ipython_extension.pyc
 in __init__(self=<sage.repl.ipython_extension.SageCustomizations object>, 
shell=<sage.repl.interpreter.SageTerminalInteractiveShell object>)
    418     def __init__(self, shell=None):
    419         """
    420         Initialize the Sage plugin.
    421         """
    422         self.shell = shell
    423 
    424         self.auto_magics = SageMagics(shell)
    425         self.shell.register_magics(self.auto_magics)
    426 
    427         import sage.misc.edit_module as edit_module
    428         self.shell.set_hook('editor', edit_module.edit_devel)
    429 
    430         self.init_inspector()
    431         self.init_line_transforms()
    432 
--> 433         import sage.all # until sage's import hell is fixed
        sage.all = undefined
    434 
    435         self.shell.verbose_quit = True
    436         self.set_quit_hook()
    437 
    438         self.register_interface_magics()
    439 
    440         if SAGE_IMPORTALL == 'yes':
    441             self.init_environment()
    442 
    443     def register_interface_magics(self):
    444         """
    445         Register magics for each of the Sage interfaces
    446         """
    447         from sage.repl.interface_magic import InterfaceMagic
    448         InterfaceMagic.register_all(self.shell)

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/all.py in 
<module>()
    250     symmetrica.end()
    251 
    252 
    253 from sage.misc.persist import register_unpickle_override
    254 register_unpickle_override('sage.categories.category', 'Sets', Sets)
    255 register_unpickle_override('sage.categories.category_types', 
'HeckeModules', HeckeModules)
    256 register_unpickle_override('sage.categories.category_types', 'Objects', 
Objects)
    257 register_unpickle_override('sage.categories.category_types', 'Rings', 
Rings)
    258 register_unpickle_override('sage.categories.category_types', 'Fields', 
Fields)
    259 register_unpickle_override('sage.categories.category_types', 
'VectorSpaces', VectorSpaces)
    260 register_unpickle_override('sage.categories.category_types', 
'Schemes_over_base', sage.categories.schemes.Schemes_over_base)
    261 register_unpickle_override('sage.categories.category_types', 
'ModularAbelianVarieties', ModularAbelianVarieties)
    262 register_unpickle_override('sage.libs.pari.gen_py', 'pari', pari)
    263 
    264 # Cache the contents of star imports.
--> 265 sage.misc.lazy_import.save_cache_file()
        global sage.misc.lazy_import.save_cache_file = undefined
    266 
    267 
    268 ### Debugging for Singular, see trac #10903
    269 # from sage.libs.singular.ring import poison_currRing
    270 # sys.settrace(poison_currRing)
    271 
    272 
    273 # Write a file indicating that Sage was started up successfully.
    274 # This is called by the sage-starts script.
    275 def _write_started_file():
    276     """
    277     Write a ``sage-started.txt`` file if it does not exist.  The
    278     contents of this file do not matter, only its existence.
    279 
    280     The non-existence of this file will be used as a trigger to run

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/misc/lazy_import.pyx
 in sage.misc.lazy_import.save_cache_file 
(build/cythonized/sage/misc/lazy_import.c:7927)()
   1101     TESTS::
   1102 
   1103         sage: import sage.misc.lazy_import
   1104         sage: sage.misc.lazy_import.save_cache_file()
   1105     """
   1106     from sage.misc.misc import sage_makedirs
   1107     from sage.misc.temporary_file import atomic_write
   1108 
   1109     global star_imports
   1110     if star_imports is None:
   1111         star_imports = {}
   1112     cache_file = get_cache_file()
   1113     cache_dir = os.path.dirname(cache_file)
   1114 
   1115     sage_makedirs(cache_dir)
-> 1116     with atomic_write(cache_file, binary=True) as f:
        global atomic_write = undefined
        global cache_file = undefined
        global binary = undefined
        global True = undefined
        global f = undefined
   1117         pickle.dump(star_imports, f)
   1118 
   1119 def get_star_imports(module_name):
   1120     """
   1121     Lookup the list of names in a module that would be imported with 
"import \\*"
   1122     either via a cache or actually importing.
   1123 
   1124     EXAMPLES::
   1125 
   1126         sage: from sage.misc.lazy_import import get_star_imports
   1127         sage: 'get_star_imports' in 
get_star_imports('sage.misc.lazy_import')
   1128         True
   1129         sage: 'EllipticCurve' in get_star_imports('sage.schemes.all')
   1130         True
   1131 

/home/newton/SageMath/local/lib/python2.7/site-packages/sage/misc/temporary_file.pyc
 in __enter__(self=<sage.misc.temporary_file.atomic_write object>)
    407 
    408         If ``self.append``, then copy the current contents of
    409         ``self.target`` to the temporary file.
    410 
    411         OUTPUT: a file returned by :func:`tempfile.NamedTemporaryFile`.
    412 
    413         TESTS::
    414 
    415             sage: from sage.misc.temporary_file import atomic_write
    416             sage: aw = atomic_write(tmp_filename())
    417             sage: with aw as f:
    418             ....:     os.path.dirname(aw.target) == 
os.path.dirname(f.name)
    419             True
    420         """
    421 
--> 422         fd, name = tempfile.mkstemp(dir=self.tmpdir)
        fd = undefined
        name = undefined
        global tempfile.mkstemp = <function mkstemp at 0x7fadde11acf8>
        global dir = undefined
        self.tmpdir = '/home/newton/.sage/cache'
    423         self.tempname = os.path.abspath(name)
    424 
    425         rmode = 'r' + ('b' if self.binary else '')
    426         wmode = 'w+' + ('b' if self.binary else '')
    427 
    428         try:
    429             self.tempfile = io.open(name, wmode, **self.kwargs)
    430         except Exception:
    431             # Some invalid arguments were passed to io.open
    432             os.unlink(name)
    433             raise
    434         finally:
    435             os.close(fd)
    436 
    437         os.chmod(name, self.mode)

/home/newton/SageMath/local/lib/python2.7/tempfile.pyc in mkstemp(suffix='', 
prefix='tmp', dir='/home/newton/.sage/cache', text=False)
    299     If the operating system uses permission bits to indicate whether a
    300     file is executable, the file is executable by no one. The file
    301     descriptor is not inherited by children of this process.
    302 
    303     Caller is responsible for deleting the file when done with it.
    304     """
    305 
    306     if dir is None:
    307         dir = gettempdir()
    308 
    309     if text:
    310         flags = _text_openflags
    311     else:
    312         flags = _bin_openflags
    313 
--> 314     return _mkstemp_inner(dir, prefix, suffix, flags)
        global _mkstemp_inner = <function _mkstemp_inner at 0x7fadde11ab90>
        dir = '/home/newton/.sage/cache'
        prefix = 'tmp'
        suffix = ''
        flags = 131266
    315 
    316 
    317 def mkdtemp(suffix="", prefix=template, dir=None):
    318     """User-callable function to create and return a unique temporary
    319     directory.  The return value is the pathname of the directory.
    320 
    321     Arguments are as for mkstemp, except that the 'text' argument is
    322     not accepted.
    323 
    324     The directory is readable, writable, and searchable only by the
    325     creating user.
    326 
    327     Caller is responsible for deleting the directory when done with it.
    328     """
    329 

/home/newton/SageMath/local/lib/python2.7/tempfile.pyc in 
_mkstemp_inner(dir='/home/newton/.sage/cache', pre='tmp', suf='', flags=131266)
    229                 _name_sequence = _RandomNameSequence()
    230         finally:
    231             _once_lock.release()
    232     return _name_sequence
    233 
    234 
    235 def _mkstemp_inner(dir, pre, suf, flags):
    236     """Code common to mkstemp, TemporaryFile, and NamedTemporaryFile."""
    237 
    238     names = _get_candidate_names()
    239 
    240     for seq in xrange(TMP_MAX):
    241         name = names.next()
    242         file = _os.path.join(dir, pre + name + suf)
    243         try:
--> 244             fd = _os.open(file, flags, 0600)
        fd = undefined
        global _os.open = <built-in function open>
        file = '/home/newton/.sage/cache/tmp0Jbxcq'
        flags = 131266
    245             _set_cloexec(fd)
    246             return (fd, _os.path.abspath(file))
    247         except OSError, e:
    248             if e.errno == _errno.EEXIST:
    249                 continue # try again
    250             if (_os.name == 'nt' and e.errno == _errno.EACCES and
    251                 _os.path.isdir(dir) and _os.access(dir, _os.W_OK)):
    252                 # On windows, when a directory with the chosen name 
already
    253                 # exists, EACCES error code is returned instead of 
EEXIST.
    254                 continue
    255             raise
    256 
    257     raise IOError, (_errno.EEXIST, "No usable temporary file name 
found")
    258 
    259 

OSError: [Errno 13] Permission denied: '/home/newton/.sage/cache/tmp0Jbxcq'

***************************************************************************

History of session input:
*** Last line of input (may not be in above history):

Reply via email to