Source code for vacumm
#!/usr/bin/env python
# -*- coding: utf8 -*-
#
# Copyright or © or Copr. Actimar/IFREMER (2010-2018)
#
# This software is a computer program whose purpose is to provide
# utilities for handling oceanographic and atmospheric data,
# with the ultimate goal of validating the MARS model from IFREMER.
#
# This software is governed by the CeCILL license under French law and
# abiding by the rules of distribution of free software. You can use,
# modify and/ or redistribute the software under the terms of the CeCILL
# license as circulated by CEA, CNRS and INRIA at the following URL
# "http://www.cecill.info".
#
# As a counterpart to the access to the source code and rights to copy,
# modify and redistribute granted by the license, users are provided only
# with a limited warranty and the software's author, the holder of the
# economic rights, and the successive licensors have only limited
# liability.
#
# In this respect, the user's attention is drawn to the risks associated
# with loading, using, modifying and/or developing or reproducing the
# software by the user in light of its specific status of free software,
# that may mean that it is complicated to manipulate, and that also
# therefore means that it is reserved for developers and experienced
# professionals having in-depth computer knowledge. Users are therefore
# encouraged to load and test the software's suitability as regards their
# requirements in conditions enabling the security of their systems and/or
# data to be ensured and, more generally, to use and operate it in the
# same conditions as regards security.
#
# The fact that you are presently reading this means that you have had
# knowledge of the CeCILL license and that you accept its terms.
#
from warnings import warn
__project__ = 'vacumm'
__version__ = '3.6.0'
__release__ = '0'
__date__ = '2018-07-02'
__author__ = u'Stéphane Raynaud, Jonathan Wilkins, Guillaume Charria'
__email__ = 'stephane.raynaud@gmail.com, wilkins@actimar.fr, charria@ifremer.fr'
__copyright__ = 'Copyright (c) 2010-2016 Actimar/IFREMER'
__description__ = """
VACUMM library
A collection of tools for VACUMM python codes.
Content:
- misc: generic library
- data: data management
- diag: advanced diagnostics
- tide: tidal tools
- sphinxext: extensions to sphinx doc generator
- bathy: bathymetric tools
- data: library to read observations and modelled fields
- validator: tools for model validation
- sphinxext: sphinx extensions
- report: reporting
- markup: tools for html page generation
"""
docfiller_verbose = False
[docs]def help(text=None, recent=False):
"""Open VACUMM website in a web browser and optionally search for a string
:Params:
- **text**, optional: String to search for.
- **recent**, optional: Use the most recent version of the documentation.
"""
from config import get_config_value
key = 'url_recent' if recent else 'url'
url = get_config_value('vacumm', key)
if url is None: url = 'http://umr-lops-vacumm.ifremer.fr'
from webbrowser import open
if text is not None:
if not isinstance(text, basestring):
if hasattr(text, 'func_name'):
text = text.func_name
else:
text = text.__class__.__name__
if not text.startswith('/'):
text = '/search.html?q=%s&check_keywords=yes&area=default'%text
url += text
open(url, new=2)
[docs]class VACUMMError(Exception):
"""Standard VACUMM error (exception)"""
[docs]class VACUMMWarning(UserWarning):
"""Standard VACUMM warning"""
[docs]class VACUMMDepWarning(DeprecationWarning, VACUMMWarning):
"""Deprecation VACUMM warning"""
[docs]def vacumm_warn(message, stacklevel=2):
"""Issue a :class:`VACUMMWarning`"""
warn(message, VACUMMWarning, stacklevel=stacklevel)
vcwarn = vacumm_warning = vacumm_warn
[docs]def vacumm_dep_warn(message, stacklevel=2):
"""Issue a :class:`VACUMMDepWarning`"""
warn(message, VACUMMDepWarning, stacklevel=stacklevel)
vcdwarn = vacumm_dep_warning = vacumm_dep_warn