/**
 * This code was GENERATED using the solita package.
 * Please DO NOT EDIT THIS FILE, instead rerun solita to update it or write a wrapper to add functionality.
 *
 * See: https://github.com/metaplex-foundation/solita
 */
import * as web3 from '@solana/web3.js';
import * as beet from '@metaplex-foundation/beet';
import * as beetSolana from '@metaplex-foundation/beet-solana';
import { QuoteAtomsPerBaseAtom } from './QuoteAtomsPerBaseAtom';
import { BaseAtoms } from './BaseAtoms';
import { QuoteAtoms } from './QuoteAtoms';
/**
 * Arguments used to create {@link FillLog}
 * @category Accounts
 * @category generated
 */
export type FillLogArgs = {
    market: web3.PublicKey;
    maker: web3.PublicKey;
    taker: web3.PublicKey;
    baseMint: web3.PublicKey;
    quoteMint: web3.PublicKey;
    price: QuoteAtomsPerBaseAtom;
    baseAtoms: BaseAtoms;
    quoteAtoms: QuoteAtoms;
    makerSequenceNumber: beet.bignum;
    takerSequenceNumber: beet.bignum;
    takerIsBuy: boolean;
    isMakerGlobal: boolean;
    padding: number[];
};
/**
 * Holds the data for the {@link FillLog} Account and provides de/serialization
 * functionality for that data
 *
 * @category Accounts
 * @category generated
 */
export declare class FillLog implements FillLogArgs {
    readonly market: web3.PublicKey;
    readonly maker: web3.PublicKey;
    readonly taker: web3.PublicKey;
    readonly baseMint: web3.PublicKey;
    readonly quoteMint: web3.PublicKey;
    readonly price: QuoteAtomsPerBaseAtom;
    readonly baseAtoms: BaseAtoms;
    readonly quoteAtoms: QuoteAtoms;
    readonly makerSequenceNumber: beet.bignum;
    readonly takerSequenceNumber: beet.bignum;
    readonly takerIsBuy: boolean;
    readonly isMakerGlobal: boolean;
    readonly padding: number[];
    private constructor();
    /**
     * Creates a {@link FillLog} instance from the provided args.
     */
    static fromArgs(args: FillLogArgs): FillLog;
    /**
     * Deserializes the {@link FillLog} from the data of the provided {@link web3.AccountInfo}.
     * @returns a tuple of the account data and the offset up to which the buffer was read to obtain it.
     */
    static fromAccountInfo(accountInfo: web3.AccountInfo<Buffer>, offset?: number): [FillLog, number];
    /**
     * Retrieves the account info from the provided address and deserializes
     * the {@link FillLog} from its data.
     *
     * @throws Error if no account info is found at the address or if deserialization fails
     */
    static fromAccountAddress(connection: web3.Connection, address: web3.PublicKey, commitmentOrConfig?: web3.Commitment | web3.GetAccountInfoConfig): Promise<FillLog>;
    /**
     * Provides a {@link web3.Connection.getProgramAccounts} config builder,
     * to fetch accounts matching filters that can be specified via that builder.
     *
     * @param programId - the program that owns the accounts we are filtering
     */
    static gpaBuilder(programId?: web3.PublicKey): beetSolana.GpaBuilder<{
        baseAtoms: any;
        padding: any;
        baseMint: any;
        quoteMint: any;
        price: any;
        market: any;
        maker: any;
        taker: any;
        quoteAtoms: any;
        makerSequenceNumber: any;
        takerSequenceNumber: any;
        takerIsBuy: any;
        isMakerGlobal: any;
    }>;
    /**
     * Deserializes the {@link FillLog} from the provided data Buffer.
     * @returns a tuple of the account data and the offset up to which the buffer was read to obtain it.
     */
    static deserialize(buf: Buffer, offset?: number): [FillLog, number];
    /**
     * Serializes the {@link FillLog} into a Buffer.
     * @returns a tuple of the created Buffer and the offset up to which the buffer was written to store it.
     */
    serialize(): [Buffer, number];
    /**
     * Returns the byteSize of a {@link Buffer} holding the serialized data of
     * {@link FillLog}
     */
    static get byteSize(): number;
    /**
     * Fetches the minimum balance needed to exempt an account holding
     * {@link FillLog} data from rent
     *
     * @param connection used to retrieve the rent exemption information
     */
    static getMinimumBalanceForRentExemption(connection: web3.Connection, commitment?: web3.Commitment): Promise<number>;
    /**
     * Determines if the provided {@link Buffer} has the correct byte size to
     * hold {@link FillLog} data.
     */
    static hasCorrectByteSize(buf: Buffer, offset?: number): boolean;
    /**
     * Returns a readable version of {@link FillLog} properties
     * and can be used to convert to JSON and/or logging
     */
    pretty(): {
        market: string;
        maker: string;
        taker: string;
        baseMint: string;
        quoteMint: string;
        price: QuoteAtomsPerBaseAtom;
        baseAtoms: BaseAtoms;
        quoteAtoms: QuoteAtoms;
        makerSequenceNumber: number | {
            toNumber: () => number;
        };
        takerSequenceNumber: number | {
            toNumber: () => number;
        };
        takerIsBuy: boolean;
        isMakerGlobal: boolean;
        padding: number[];
    };
}
/**
 * @category Accounts
 * @category generated
 */
export declare const fillLogBeet: beet.BeetStruct<FillLog, FillLogArgs>;
