2014-11-29 22:55:32 +02:00
|
|
|
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
|
|
|
# See LICENSE for details.
|
|
|
|
|
|
|
|
import re
|
|
|
|
from os import remove
|
|
|
|
from os.path import isdir, isfile, join
|
|
|
|
from shutil import rmtree
|
|
|
|
from time import time
|
|
|
|
|
|
|
|
import click
|
|
|
|
|
|
|
|
from platformio import __version__, app, telemetry
|
2014-12-03 20:16:50 +02:00
|
|
|
from platformio.commands.install import cli as cmd_install
|
|
|
|
from platformio.commands.lib import lib_update as cmd_libraries_update
|
2014-11-29 22:55:32 +02:00
|
|
|
from platformio.commands.update import cli as cli_platforms_update
|
|
|
|
from platformio.commands.upgrade import get_latest_version
|
|
|
|
from platformio.exception import UpgraderFailed
|
|
|
|
from platformio.libmanager import LibraryManager
|
|
|
|
from platformio.platforms.base import PlatformFactory
|
|
|
|
from platformio.util import get_home_dir, get_lib_dir
|
|
|
|
|
|
|
|
|
|
|
|
def on_platformio_start(ctx):
|
|
|
|
telemetry.on_command(ctx)
|
|
|
|
after_upgrade(ctx)
|
|
|
|
check_platformio_upgrade()
|
|
|
|
check_internal_updates(ctx, "platforms")
|
|
|
|
check_internal_updates(ctx, "libraries")
|
|
|
|
|
|
|
|
|
|
|
|
def on_platformio_end(ctx, result): # pylint: disable=W0613
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
def on_platformio_exception(e):
|
|
|
|
telemetry.on_exception(e)
|
|
|
|
|
|
|
|
|
|
|
|
class Upgrader(object):
|
|
|
|
|
|
|
|
def __init__(self, from_version, to_version):
|
|
|
|
self.from_version = self.version_to_int(from_version)
|
|
|
|
self.to_version = self.version_to_int(to_version)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def version_to_int(version):
|
|
|
|
return int(re.sub(r"[^\d]+", "", version))
|
|
|
|
|
|
|
|
def run(self, ctx):
|
|
|
|
if self.from_version > self.to_version:
|
|
|
|
return True
|
|
|
|
|
|
|
|
result = [True]
|
2015-02-03 18:45:07 +02:00
|
|
|
for v in (90, 110):
|
2014-11-29 22:55:32 +02:00
|
|
|
if self.from_version >= v:
|
|
|
|
continue
|
|
|
|
result.append(getattr(self, "_upgrade_to_%d" % v)(ctx))
|
|
|
|
|
|
|
|
return all(result)
|
|
|
|
|
|
|
|
def _upgrade_to_90(self, ctx): # pylint: disable=R0201
|
|
|
|
prev_platforms = []
|
|
|
|
|
|
|
|
# remove platform's folder (obsoleted package structure)
|
|
|
|
for name in PlatformFactory.get_platforms().keys():
|
|
|
|
pdir = join(get_home_dir(), name)
|
|
|
|
if not isdir(pdir):
|
|
|
|
continue
|
|
|
|
prev_platforms.append(name)
|
|
|
|
rmtree(pdir)
|
|
|
|
|
|
|
|
# remove unused files
|
|
|
|
for fname in (".pioupgrade", "installed.json"):
|
|
|
|
if isfile(join(get_home_dir(), fname)):
|
|
|
|
remove(join(get_home_dir(), fname))
|
|
|
|
|
|
|
|
if prev_platforms:
|
2014-12-03 20:16:50 +02:00
|
|
|
ctx.invoke(cmd_install, platforms=prev_platforms)
|
2014-11-29 22:55:32 +02:00
|
|
|
|
|
|
|
return True
|
|
|
|
|
2015-02-03 18:45:07 +02:00
|
|
|
def _upgrade_to_110(self, ctx): # pylint: disable=R0201
|
|
|
|
# install "ldscripts" package
|
2015-02-13 19:04:31 +02:00
|
|
|
if "titiva" in PlatformFactory.get_platforms(installed=True).keys():
|
2015-02-03 18:45:07 +02:00
|
|
|
ctx.invoke(cmd_install, platforms=["titiva"])
|
|
|
|
return True
|
|
|
|
|
2014-11-29 22:55:32 +02:00
|
|
|
|
|
|
|
def after_upgrade(ctx):
|
|
|
|
if app.get_state_item("last_version", None) == __version__:
|
|
|
|
return
|
|
|
|
|
|
|
|
# promotion
|
|
|
|
click.echo("\nIf you like %s, please:" % (
|
|
|
|
click.style("PlatformIO", fg="cyan")
|
|
|
|
))
|
|
|
|
click.echo(
|
|
|
|
"- %s us on Twitter to stay up-to-date "
|
|
|
|
"on the latest project news > %s" %
|
|
|
|
(click.style("follow", fg="cyan"),
|
2014-12-30 14:02:20 +02:00
|
|
|
click.style("https://twitter.com/PlatformIO_Org", fg="cyan"))
|
2014-11-29 22:55:32 +02:00
|
|
|
)
|
|
|
|
click.echo("- %s us a star on GitHub > %s" % (
|
|
|
|
click.style("give", fg="cyan"),
|
2014-12-10 21:40:39 +02:00
|
|
|
click.style("https://github.com/ivankravets/platformio", fg="cyan")
|
2014-11-29 22:55:32 +02:00
|
|
|
))
|
2015-01-01 22:57:02 +02:00
|
|
|
click.secho("Thanks a lot!\n", fg="green")
|
2014-11-29 22:55:32 +02:00
|
|
|
|
|
|
|
if not isdir(get_home_dir()):
|
|
|
|
return
|
|
|
|
|
|
|
|
click.secho("Please wait while upgrading PlatformIO ...",
|
|
|
|
fg="yellow")
|
|
|
|
|
|
|
|
last_version = app.get_state_item("last_version", "0.0.0")
|
|
|
|
u = Upgrader(last_version, __version__)
|
|
|
|
if u.run(ctx):
|
|
|
|
app.set_state_item("last_version", __version__)
|
|
|
|
click.secho("PlatformIO has been successfully upgraded to %s!\n" %
|
|
|
|
__version__, fg="green")
|
|
|
|
|
|
|
|
telemetry.on_event(category="Auto", action="Upgrade",
|
|
|
|
label="%s > %s" % (last_version, __version__))
|
|
|
|
else:
|
|
|
|
raise UpgraderFailed()
|
|
|
|
click.echo("")
|
|
|
|
|
|
|
|
|
|
|
|
def check_platformio_upgrade():
|
|
|
|
last_check = app.get_state_item("last_check", {})
|
|
|
|
interval = int(app.get_setting("check_platformio_interval")) * 3600 * 24
|
|
|
|
if (time() - interval) < last_check.get("platformio_upgrade", 0):
|
|
|
|
return
|
|
|
|
|
|
|
|
last_check['platformio_upgrade'] = int(time())
|
|
|
|
app.set_state_item("last_check", last_check)
|
|
|
|
|
|
|
|
latest_version = get_latest_version()
|
2014-12-01 16:33:35 +02:00
|
|
|
if (latest_version == __version__ or
|
|
|
|
Upgrader.version_to_int(latest_version) <
|
|
|
|
Upgrader.version_to_int(__version__)):
|
2014-11-29 22:55:32 +02:00
|
|
|
return
|
|
|
|
|
|
|
|
click.secho("There is a new version %s of PlatformIO available.\n"
|
|
|
|
"Please upgrade it via " % latest_version,
|
|
|
|
fg="yellow", nl=False)
|
2014-12-10 21:40:39 +02:00
|
|
|
click.secho("platformio upgrade", fg="cyan", nl=False)
|
2014-11-29 22:55:32 +02:00
|
|
|
click.secho(" command.\nChanges: ", fg="yellow", nl=False)
|
2014-12-30 23:22:42 +02:00
|
|
|
click.secho("http://docs.platformio.org/en/latest/history.html\n",
|
2014-12-10 21:40:39 +02:00
|
|
|
fg="cyan")
|
2014-11-29 22:55:32 +02:00
|
|
|
|
|
|
|
|
|
|
|
def check_internal_updates(ctx, what):
|
|
|
|
last_check = app.get_state_item("last_check", {})
|
|
|
|
interval = int(app.get_setting("check_%s_interval" % what)) * 3600 * 24
|
|
|
|
if (time() - interval) < last_check.get(what + "_update", 0):
|
|
|
|
return
|
|
|
|
|
|
|
|
last_check[what + '_update'] = int(time())
|
|
|
|
app.set_state_item("last_check", last_check)
|
|
|
|
|
|
|
|
outdated_items = []
|
|
|
|
if what == "platforms":
|
|
|
|
for platform in PlatformFactory.get_platforms(installed=True).keys():
|
2014-12-03 20:16:50 +02:00
|
|
|
p = PlatformFactory.newPlatform(platform)
|
2014-11-29 22:55:32 +02:00
|
|
|
if p.is_outdated():
|
|
|
|
outdated_items.append(platform)
|
|
|
|
elif what == "libraries":
|
|
|
|
lm = LibraryManager(get_lib_dir())
|
|
|
|
outdated_items = lm.get_outdated()
|
|
|
|
|
|
|
|
if not outdated_items:
|
|
|
|
return
|
|
|
|
|
|
|
|
click.secho("There are the new updates for %s (%s)" %
|
|
|
|
(what, ", ".join(outdated_items)), fg="yellow")
|
|
|
|
|
|
|
|
if not app.get_setting("auto_update_" + what):
|
|
|
|
click.secho("Please update them via ", fg="yellow", nl=False)
|
|
|
|
click.secho("`platformio %supdate`" %
|
|
|
|
("lib " if what == "libraries" else ""),
|
|
|
|
fg="cyan", nl=False)
|
|
|
|
click.secho(" command.\n", fg="yellow")
|
|
|
|
else:
|
|
|
|
click.secho("Please wait while updating %s ..." % what, fg="yellow")
|
|
|
|
if what == "platforms":
|
|
|
|
ctx.invoke(cli_platforms_update)
|
|
|
|
elif what == "libraries":
|
2014-12-03 20:16:50 +02:00
|
|
|
ctx.invoke(cmd_libraries_update)
|
2014-11-29 22:55:32 +02:00
|
|
|
click.echo()
|
|
|
|
|
|
|
|
telemetry.on_event(category="Auto", action="Update",
|
|
|
|
label=what.title())
|