mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-19 00:41:43 +00:00
75 lines
2.6 KiB
Python
75 lines
2.6 KiB
Python
#!/usr/bin/env python3
|
|
#
|
|
# Copyright (c) FIRST and other WPILib contributors.
|
|
# Open Source Software; you can modify and/or share it under the terms of
|
|
# the WPILib BSD license file in the root directory of this project.
|
|
#
|
|
|
|
import typing
|
|
|
|
import wpilib
|
|
import commands2
|
|
import commands2.cmd
|
|
|
|
import robotcontainer
|
|
|
|
"""
|
|
The VM is configured to automatically run this class, and to call the functions corresponding to
|
|
each mode, as described in the TimedRobot documentation. If you change the name of this class or
|
|
the package after creating this project, you must also update the build.gradle file in the
|
|
project.
|
|
"""
|
|
|
|
|
|
class MyRobot(commands2.TimedCommandRobot):
|
|
"""
|
|
Command v2 robots are encouraged to inherit from TimedCommandRobot, which
|
|
has an implementation of robotPeriodic which runs the scheduler for you
|
|
"""
|
|
|
|
def __init__(self) -> None:
|
|
"""
|
|
This function is run when the robot is first started up and should be used for any
|
|
initialization code.
|
|
"""
|
|
super().__init__()
|
|
self.autonomousCommand: typing.Optional[commands2.Command] = None
|
|
|
|
# Instantiate our RobotContainer. This will perform all our button bindings, and put our
|
|
# autonomous chooser on the dashboard.
|
|
self.container = robotcontainer.RobotContainer()
|
|
|
|
def disabledInit(self) -> None:
|
|
"""This function is called once each time the robot enters Disabled mode."""
|
|
|
|
def disabledPeriodic(self) -> None:
|
|
"""This function is called periodically when disabled"""
|
|
|
|
def autonomousInit(self) -> None:
|
|
"""This autonomous runs the autonomous command selected by your RobotContainer class."""
|
|
self.autonomousCommand = self.container.getAutonomousCommand()
|
|
|
|
# schedule the autonomous command (example)
|
|
if self.autonomousCommand is not None:
|
|
self.autonomousCommand.schedule()
|
|
else:
|
|
print("no auto command?")
|
|
|
|
def autonomousPeriodic(self) -> None:
|
|
"""This function is called periodically during autonomous"""
|
|
|
|
def teleopInit(self) -> None:
|
|
# This makes sure that the autonomous stops running when
|
|
# teleop starts running. If you want the autonomous to
|
|
# continue until interrupted by another command, remove
|
|
# this line or comment it out.
|
|
if self.autonomousCommand is not None:
|
|
self.autonomousCommand.cancel()
|
|
|
|
def teleopPeriodic(self) -> None:
|
|
"""This function is called periodically during operator control"""
|
|
|
|
def testInit(self) -> None:
|
|
# Cancels all running commands at the start of test mode
|
|
commands2.CommandScheduler.getInstance().cancelAll()
|