2013-07-29 03:12:41 -05:00
|
|
|
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
|
|
|
//! This is an internal module used by the ifmt! runtime. These structures are
|
|
|
|
//! emitted to static arrays to precompile format strings ahead of time.
|
|
|
|
//!
|
|
|
|
//! These definitions are similar to their `ct` equivalents, but differ in that
|
|
|
|
//! these can be statically allocated and are slightly optimized for the runtime
|
|
|
|
|
2014-05-28 11:24:28 -05:00
|
|
|
|
2014-06-01 12:17:30 -05:00
|
|
|
#[doc(hidden)]
|
2013-12-10 01:16:18 -06:00
|
|
|
pub enum Piece<'a> {
|
|
|
|
String(&'a str),
|
|
|
|
Argument(Argument<'a>),
|
2013-07-29 03:12:41 -05:00
|
|
|
}
|
|
|
|
|
2014-06-01 12:17:30 -05:00
|
|
|
#[doc(hidden)]
|
2013-12-10 01:16:18 -06:00
|
|
|
pub struct Argument<'a> {
|
2014-03-27 17:09:47 -05:00
|
|
|
pub position: Position,
|
|
|
|
pub format: FormatSpec,
|
2013-07-29 03:12:41 -05:00
|
|
|
}
|
|
|
|
|
2014-06-01 12:17:30 -05:00
|
|
|
#[doc(hidden)]
|
2013-10-12 22:00:58 -05:00
|
|
|
pub struct FormatSpec {
|
2014-03-27 17:09:47 -05:00
|
|
|
pub fill: char,
|
2014-05-06 11:52:53 -05:00
|
|
|
pub align: Alignment,
|
2014-03-27 17:09:47 -05:00
|
|
|
pub flags: uint,
|
|
|
|
pub precision: Count,
|
|
|
|
pub width: Count,
|
2013-10-12 22:00:58 -05:00
|
|
|
}
|
|
|
|
|
2014-06-01 12:17:30 -05:00
|
|
|
/// Possible alignments that can be requested as part of a formatting directive.
|
2014-05-29 19:45:07 -05:00
|
|
|
#[deriving(PartialEq)]
|
2014-05-06 11:52:53 -05:00
|
|
|
pub enum Alignment {
|
2014-06-01 12:17:30 -05:00
|
|
|
/// Indication that contents should be left-aligned.
|
2014-05-06 11:52:53 -05:00
|
|
|
AlignLeft,
|
2014-06-01 12:17:30 -05:00
|
|
|
/// Indication that contents should be right-aligned.
|
2014-05-06 11:52:53 -05:00
|
|
|
AlignRight,
|
2014-06-01 12:17:30 -05:00
|
|
|
/// No alignment was requested.
|
2014-05-06 11:52:53 -05:00
|
|
|
AlignUnknown,
|
|
|
|
}
|
|
|
|
|
2014-06-01 12:17:30 -05:00
|
|
|
#[doc(hidden)]
|
2013-10-12 22:00:58 -05:00
|
|
|
pub enum Count {
|
|
|
|
CountIs(uint), CountIsParam(uint), CountIsNextParam, CountImplied,
|
|
|
|
}
|
|
|
|
|
2014-06-01 12:17:30 -05:00
|
|
|
#[doc(hidden)]
|
2013-07-29 03:12:41 -05:00
|
|
|
pub enum Position {
|
|
|
|
ArgumentNext, ArgumentIs(uint)
|
|
|
|
}
|
|
|
|
|
2014-06-01 12:17:30 -05:00
|
|
|
/// Flags which can be passed to formatting via a directive.
|
|
|
|
///
|
|
|
|
/// These flags are discovered through the `flags` field of the `Formatter`
|
|
|
|
/// structure. The flag in that structure is a union of these flags into a
|
|
|
|
/// `uint` where each flag's discriminant is the corresponding bit.
|
2014-05-06 11:52:53 -05:00
|
|
|
pub enum Flag {
|
2014-06-01 12:17:30 -05:00
|
|
|
/// A flag which enables number formatting to always print the sign of a
|
|
|
|
/// number.
|
2014-05-06 11:52:53 -05:00
|
|
|
FlagSignPlus,
|
2014-06-01 12:17:30 -05:00
|
|
|
/// Currently not a used flag
|
2014-05-06 11:52:53 -05:00
|
|
|
FlagSignMinus,
|
2014-06-01 12:17:30 -05:00
|
|
|
/// Indicates that the "alternate formatting" for a type should be used.
|
|
|
|
///
|
|
|
|
/// The meaning of this flag is type-specific.
|
2014-05-06 11:52:53 -05:00
|
|
|
FlagAlternate,
|
2014-06-01 12:17:30 -05:00
|
|
|
/// Indicates that padding should be done with a `0` character as well as
|
|
|
|
/// being aware of the sign to be printed.
|
2014-05-06 11:52:53 -05:00
|
|
|
FlagSignAwareZeroPad,
|
|
|
|
}
|