This repository has been archived on 2024-05-26. You can view files and clone it, but cannot push or open issues or pull requests.
trixy/trixy-parser/example/derives.tri

55 lines
1.4 KiB
Rust

/*
* Copyright (C) 2023 - 2024:
* The Trinitrix Project <soispha@vhack.eu, antifallobst@systemausfall.org>
*
* This file is part of the Trixy crate for Trinitrix.
*
* Trixy is free software: you can redistribute it and/or modify
* it under the terms of the Lesser GNU General Public License as
* published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* and the Lesser GNU General Public License along with this program.
* If not, see <https://www.gnu.org/licenses/>.
*/
/// Call out an outstanding person
fn outstanding(name: String);
enum DogTraining {
Sheep,
Wolf,
Blind,
}
#[derive("Error")]
enum TrainingMistake {
GotBitten,
}
struct Dog {
name: String,
}
struct TrainedDog {
name: String,
training: DogTraining,
}
mod one {
/// Say hi to a name
fn hi(name: String) -> String;
/// Train a dog (if it is there, otherwise do nothing)
fn train_dog(dog: Option<Dog>) -> Result<TrainedDog, TrainingMistake>;
}
// Trixy is a subset of Rust
// vim: syntax=rust cms=//%s