mirror of https://github.com/odrling/Aegisub
199 lines
6.6 KiB
C++
199 lines
6.6 KiB
C++
// Copyright (c) 2005, Rodrigo Braz Monteiro
|
|
// All rights reserved.
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without
|
|
// modification, are permitted provided that the following conditions are met:
|
|
//
|
|
// * Redistributions of source code must retain the above copyright notice,
|
|
// this list of conditions and the following disclaimer.
|
|
// * Redistributions in binary form must reproduce the above copyright notice,
|
|
// this list of conditions and the following disclaimer in the documentation
|
|
// and/or other materials provided with the distribution.
|
|
// * Neither the name of the Aegisub Group nor the names of its contributors
|
|
// may be used to endorse or promote products derived from this software
|
|
// without specific prior written permission.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
// POSSIBILITY OF SUCH DAMAGE.
|
|
//
|
|
// -----------------------------------------------------------------------------
|
|
//
|
|
// AEGISUB
|
|
//
|
|
// Website: http://aegisub.cellosoft.com
|
|
// Contact: mailto:zeratul@cellosoft.com
|
|
//
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
////////////
|
|
// Includes
|
|
#include <vector>
|
|
#include "ass_entry.h"
|
|
#include "ass_time.h"
|
|
|
|
|
|
//////////////
|
|
// Prototypes
|
|
class AssOverrideParameter;
|
|
class AssOverrideTag;
|
|
class AssDialogueBlockPlain;
|
|
class AssDialogueBlockOverride;
|
|
class AssDialogueBlockDrawing;
|
|
|
|
|
|
///////////////////
|
|
// Block type enum
|
|
enum ASS_BlockType {
|
|
BLOCK_BASE,
|
|
BLOCK_PLAIN,
|
|
BLOCK_OVERRIDE,
|
|
BLOCK_DRAWING
|
|
};
|
|
|
|
|
|
//////////////////////
|
|
// AssDialogue Blocks
|
|
// ------------------
|
|
// A block is each group in the text field of an AssDialogue
|
|
// For example:
|
|
// Yes, I {\i1}am{\i0} here.
|
|
//
|
|
// Gets split in five blocks:
|
|
// "Yes, I " (Plain)
|
|
// "\i1" (Override)
|
|
// "am" (Plain)
|
|
// "\i0" (Override)
|
|
// " here." (Plain)
|
|
//
|
|
// Also note how {}s are discarded.
|
|
// Override blocks are further divided in AssOverrideTag's.
|
|
//
|
|
// The GetText() method generates a new value for the "text" field from
|
|
// the other fields in the specific class, and returns the new value.
|
|
//
|
|
class AssDialogueBlock {
|
|
public:
|
|
wxString text;
|
|
AssDialogue *parent;
|
|
|
|
AssDialogueBlock();
|
|
virtual ~AssDialogueBlock();
|
|
|
|
virtual ASS_BlockType GetType() = 0;
|
|
virtual wxString GetText() { return text; }
|
|
static AssDialogueBlockPlain *GetAsPlain(AssDialogueBlock *base); // Returns a block base as a plain block if it is valid, null otherwise
|
|
static AssDialogueBlockOverride *GetAsOverride(AssDialogueBlock *base); // Returns a block base as an override block if it is valid, null otherwise
|
|
static AssDialogueBlockDrawing *GetAsDrawing(AssDialogueBlock *base); // Returns a block base as a drawing block if it is valid, null otherwise
|
|
};
|
|
|
|
|
|
/////////////////////////////
|
|
// Plain dialogue block text
|
|
// -------------------------
|
|
// This is used for standard text
|
|
// type = BLOCK_PLAIN
|
|
//
|
|
class AssDialogueBlockPlain : public AssDialogueBlock {
|
|
public:
|
|
ASS_BlockType GetType() { return BLOCK_PLAIN; }
|
|
AssDialogueBlockPlain();
|
|
};
|
|
|
|
|
|
/////////////////////////////
|
|
// Plain dialogue block text
|
|
// -------------------------
|
|
// This is used for drawing commands
|
|
// type = BLOCK_DRAWING
|
|
//
|
|
class AssDialogueBlockDrawing : public AssDialogueBlock {
|
|
public:
|
|
int Scale;
|
|
|
|
ASS_BlockType GetType() { return BLOCK_DRAWING; }
|
|
AssDialogueBlockDrawing();
|
|
void TransformCoords(int trans_x,int trans_y,double mult_x,double mult_y);
|
|
};
|
|
|
|
|
|
//////////////////////
|
|
// Override tag block
|
|
// ------------------
|
|
// Used to store ASS overrides
|
|
// Type = BLOCK_OVERRIDE
|
|
//
|
|
class AssDialogueBlockOverride : public AssDialogueBlock {
|
|
public:
|
|
AssDialogueBlockOverride();
|
|
~AssDialogueBlockOverride();
|
|
std::vector<AssOverrideTag*> Tags;
|
|
|
|
ASS_BlockType GetType() { return BLOCK_OVERRIDE; }
|
|
wxString GetText();
|
|
void ParseTags(); // Parses tags
|
|
void ProcessParameters(void (*callback)(wxString,int,AssOverrideParameter*,void *),void *userData);
|
|
};
|
|
|
|
|
|
////////////////////////////////////////
|
|
// Class for Dialogue and Comment lines
|
|
class AssDialogue : public AssEntry {
|
|
private:
|
|
wxString MakeData();
|
|
|
|
public:
|
|
std::vector<AssDialogueBlock*> Blocks; // Contains information about each block of text
|
|
|
|
bool Comment; // Is this a comment line?
|
|
int Layer; // Layer number
|
|
int Margin[4]; // Margins: 0 = Left, 1 = Right, 2 = Top (Vertical), 3 = Bottom
|
|
AssTime Start; // Starting time
|
|
AssTime End; // Ending time
|
|
wxString Style; // Style name
|
|
wxString Actor; // Actor name
|
|
wxString Effect; // Effect name
|
|
wxString Text; // Raw text data
|
|
|
|
ASS_EntryType GetType() { return ENTRY_DIALOGUE; }
|
|
|
|
bool Parse(wxString data,int version=1); // Parses raw ASS data into everything else
|
|
void ParseASSTags(); // Parses text to generate block information (doesn't update data)
|
|
void ParseSRTTags(); // Converts tags to ass format and calls ParseASSTags+UpdateData
|
|
void ClearBlocks(); // Clear all blocks, ALWAYS call this after you're done processing tags
|
|
|
|
void ProcessParameters(void (*callback)(wxString,int,AssOverrideParameter*,void *userData),void *userData=NULL); // Callback to process parameters
|
|
void ConvertTagsToSRT(); // Converts tags to SRT format
|
|
void StripTags(); // Strips all tags from the text
|
|
void StripTag(wxString tagName);// Strips a specific tag from the text
|
|
wxString GetStrippedText(); // Gets text without tags
|
|
|
|
void UpdateData(); // Updates raw data from current values + text
|
|
void UpdateText(); // Generates text from the override tags
|
|
const wxString GetEntryData();
|
|
void SetEntryData(wxString newData);
|
|
void Clear(); // Wipes all data
|
|
|
|
void SetMarginString(const wxString value,int which); // Set string to a margin value (0 = left, 1 = right, 2 = vertical/top, 3 = bottom)
|
|
wxString GetMarginString(int which,bool pad=true); // Returns the string of a margin value (0 = left, 1 = right, 2 = vertical/top, 3 = bottom)
|
|
wxString GetSSAText();
|
|
bool CollidesWith(AssDialogue *target); // Checks if two lines collide
|
|
|
|
AssEntry *Clone();
|
|
|
|
AssDialogue();
|
|
AssDialogue(wxString data,int version=1);
|
|
~AssDialogue();
|
|
};
|