本文整理汇总了C++中Peek函数的典型用法代码示例。如果您正苦于以下问题:C++ Peek函数的具体用法?C++ Peek怎么用?C++ Peek使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了Peek函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Insert
void Insert (Item X, int position, List *L) {
ListNode *p, *q;
assert(position >= 0);
assert(position <= L->size);
L->size++;
q=(ListNode *)malloc(sizeof(ListNode));
copyItem(&q->item,X);
if(position==0) {
q->next=L->first;
L->first=q;
}
else {
p=moveTo(position-1,L);
q->next=p->next;
p->next=q;
}
assert(Empty(L) == 0);
assert(Size(L) == L->size);
Peek(position, L, &X);
assert(strcmp(q->item.name, X.name) == 0);
assert(q->item.grade == X.grade);
}
示例2: AttachedTransformation
size_t BufferedTransformation::Peek(byte &outByte) const
{
if (AttachedTransformation())
return AttachedTransformation()->Peek(outByte);
else
return Peek(&outByte, 1);
}
示例3: ReadUntil
nsresult nsScanner::ReadUntil(nsScannerSharedSubstring& aString,
const nsReadEndCondition& aEndCondition,
PRBool addTerminal)
{
if (!mSlidingBuffer) {
return kEOF;
}
nsScannerIterator origin, current;
const PRUnichar* setstart = aEndCondition.mChars;
const PRUnichar* setcurrent;
origin = mCurrentPosition;
current = origin;
PRUnichar theChar=0;
nsresult result=Peek(theChar);
if (NS_FAILED(result)) {
return result;
}
while (current != mEndPosition) {
theChar = *current;
if (theChar == '\0') {
ReplaceCharacter(current, sInvalid);
theChar = sInvalid;
}
// Filter out completely wrong characters
// Check if all bits are in the required area
if(!(theChar & aEndCondition.mFilter)) {
// They were. Do a thorough check.
setcurrent = setstart;
while (*setcurrent) {
if (*setcurrent == theChar) {
if(addTerminal)
++current;
AppendUnicodeTo(origin, current, aString);
SetPosition(current);
//DoErrTest(aString);
return NS_OK;
}
++setcurrent;
}
}
++current;
}
// If we are here, we didn't find any terminator in the string and
// current = mEndPosition
SetPosition(current);
AppendUnicodeTo(origin, current, aString);
return FillBuffer();
}
示例4: ReadTagIdentifier
/**
* Consume characters until you run into space, a '<', a '>', or a '/'.
*
* @param aString - receives new data from stream
* @return error code
*/
nsresult nsScanner::ReadTagIdentifier(nsScannerSharedSubstring& aString) {
if (!mSlidingBuffer) {
return kEOF;
}
PRUnichar theChar=0;
nsresult result=Peek(theChar);
nsScannerIterator current, end;
PRBool found=PR_FALSE;
current = mCurrentPosition;
end = mEndPosition;
// Loop until we find an illegal character. Everything is then appended
// later.
while(current != end && !found) {
theChar=*current;
switch(theChar) {
case '\n':
case '\r':
case ' ' :
case '\t':
case '\v':
case '\f':
case '<':
case '>':
case '/':
found = PR_TRUE;
break;
case '\0':
ReplaceCharacter(current, sInvalid);
break;
default:
break;
}
if (!found) {
++current;
}
}
// Don't bother appending nothing.
if (current != mCurrentPosition) {
AppendUnicodeTo(mCurrentPosition, current, aString);
}
SetPosition(current);
if (current == end) {
result = FillBuffer();
}
//DoErrTest(aString);
return result;
}
示例5: BuildSignatureDatabaseSearchMachine
int BuildSignatureDatabaseSearchMachine(signature_db* SignatureDatabase)
{
if (!SignatureDatabase)
return -1;
if (!SignatureDatabase->Trie && BuildSignatureDatabaseTrie(SignatureDatabase) != 0)
return -1;
InitializeSearchMachine(SignatureDatabase->SearchMachine, SignatureDatabase->Trie);
search_machine* SM = SignatureDatabase->SearchMachine;
// Phase 2
queue* Queue = xcalloc(1, sizeof(queue));
InitializeQueue(Queue);
for (size_t AlphabetIndex = 0; AlphabetIndex < UNIT_CARDINALITY; ++AlphabetIndex)
{
trie* Node = SM->Goto[ROOT_IDENTIFIER][AlphabetIndex];
//if (Node && Node->Identifier != ROOT_IDENTIFIER)
if (!Node || Node->Identifier != ROOT_IDENTIFIER)
{
SM->Fail[Node->Identifier] = SM->Trie;
Enqueue(Queue, Node);
}
}
while (Peek(Queue) != NULL)
{
trie* R = Dequeue(Queue);
for (size_t AlphabetIndex = 0; AlphabetIndex < UNIT_CARDINALITY; ++AlphabetIndex)
{
trie* S = SM->Goto[R->Identifier][AlphabetIndex];
// Not 100% about this
if (S)
{
Enqueue(Queue, S);
trie* ST = SM->Fail[R->Identifier];
// Not 100% about this
while (!SM->Goto[ST->Identifier][AlphabetIndex])
{
ST = SM->Fail[ST->Identifier];
}
SM->Fail[S->Identifier] = SM->Goto[ST->Identifier][AlphabetIndex];
// out(u) = out(u) UNION out(fail(u))
SM->Out[S->Identifier] = UniqExtendList(SM->Out[S->Identifier], SM->Out[SM->Fail[S->Identifier]->Identifier]);
}
}
}
FreeQueue(Queue);
Queue = NULL;
return 0;
}
示例6: MOZ_ASSERT
/**
* Scan an AtKeyword token. Also handles production of Symbol when
* an '@' is not followed by an identifier.
*/
bool
nsCSSScanner::ScanAtKeyword(nsCSSToken& aToken)
{
MOZ_ASSERT(Peek() == '@', "should not have been called");
// Fall back for when '@' isn't followed by an identifier.
aToken.mSymbol = '@';
Advance();
int32_t ch = Peek();
if (StartsIdent(ch, Peek(1))) {
if (GatherText(IS_IDCHAR, aToken.mIdent)) {
aToken.mType = eCSSToken_AtKeyword;
}
}
return true;
}
示例7: showListContent
static void showListContent (List *L) {
int i;
Student S;
for(i=0;i<Size(L);i++) {
Peek(i,L,&S);
printf("\t%s %d%%\n",NameOfStudent(S),GradeOfStudent(S));
FreeStudent(&S);
}
}
示例8: Term
// <bool_term> ::= <bool_not_factor> [<and_op> <bool_not_factor]*
void Term(CPU *cpu, Files file){
NotFactor(cpu, file);
while(Peek("&&", file)){
Match("&&", file);
NotFactor(cpu, file);
cpu->PopValue();
cpu->BooleanAnd();
}
}
示例9: Expression
// <bool_expression> ::= <bool_term> [<or_op> <bool_term]*
void Expression(CPU *cpu, Files file){
Term(cpu, file);
while(Peek("||", file)){
Match("||", file);
Term(cpu, file);
cpu->PopValue();
cpu->BooleanOr();
}
}
示例10: Peek
const Token *TokenStream::PeekIf(const TokenTypeSet &typeSet) const
{
const Token *token = Peek();
if (typeSet.Contains(token->GetTokenType()))
{
return token;
}
return nullptr;
}
示例11: Peek
bool Tokenizer::CondRead(SYMBOL kind) {
const Token* T = Peek();
if (T->kind() == kind) {
Get( );
return true;
} else {
return false;
}
}
示例12: return
double basisfield::PeekWide(int i, int j, int k, FieldIndex fi)
{
if (!(i<0 || j<0 || k<0 || static_cast<unsigned int>(i)>=FieldSz_x() || static_cast<unsigned int>(j)>=FieldSz_y() || static_cast<unsigned int>(k)>=FieldSz_z())) { // Inside "valid" FOV
return(Peek(static_cast<unsigned int>(i),static_cast<unsigned int>(j),static_cast<unsigned int>(k),fi));
}
else {
return(peek_outside_fov(i,j,k,fi));
}
}
示例13: Compare
bool Compare(BufferedLineReader &other) {
if (Peek(0) != other.Peek(0)) {
return false;
}
Skip(1);
other.Skip(1);
return true;
}
示例14: ActorPhysicsSetVelocity
int LuaBinding::ActorPhysicsSetVelocity()
{
int actorId = 0;
Vector2f velocity;
if (!Peek(1, &actorId) || !Peek(2, &velocity))
{
return ERROR_TYPE_PARAMETER;
}
const boost::shared_ptr<ActorPropertyPhysics> property = LuaBinding::GetActorProperty<ActorPropertyPhysics>(actorId);
if (!property)
{
return ERROR_TYPE_STATE;
}
property->SetVelocity(velocity);
return 0;
}
示例15: ActorSetPosition
int LuaBinding::ActorSetPosition()
{
int actorId = 0;
Vector2i position;
if (!Peek(1, &actorId) || !Peek(2, &position))
{
return ERROR_TYPE_PARAMETER;
}
const boost::shared_ptr<Actor> actor = GetActor(actorId);
if (!actor)
{
return ERROR_TYPE_STATE;
}
actor->SetPosition(position);
return 0;
}