Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Licensed under the Apache License, Version 2.0 (the "License");
   * you may not use this file except in compliance with the License.
   * You may obtain a copy of the License at
   *
   *     http://www.apache.org/licenses/LICENSE-2.0
   *
   * Unless required by applicable law or agreed to in writing, software
   * distributed under the License is distributed on an "AS IS" BASIS,
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
 package com.facebook.presto.operator;
 
 
 import java.util.List;
 
 import static com.google.common.base.Preconditions.checkNotNull;
 import static com.google.common.base.Preconditions.checkState;
 
         implements Operator
 {
     private final OperatorContext operatorContext;
     private final List<Typetypes;
 
     private final PageBuilder pageBuilder;
     private final PageProcessor processor;
     private Page currentPage;
     private int currentPosition;
     private boolean finishing;
 
     public FilterAndProjectOperator(OperatorContext operatorContextIterable<? extends TypetypesPageProcessor processor)
     {
         this. = checkNotNull(processor"processor is null");
         this. = checkNotNull(operatorContext"operatorContext is null");
         this. = ImmutableList.copyOf(checkNotNull(types"types is null"));
         this. = new PageBuilder(getTypes());
     }
 
     @Override
     {
         return ;
     }
 
     @Override
     public final List<TypegetTypes()
     {
         return ;
     }
 
     @Override
     public final void finish()
     {
          = true;
     }
 
     @Override
     public final boolean isFinished()
     {
         return  && .isEmpty() &&  == null;
     }
 
     @Override
     public final boolean needsInput()
     {
         return ! && !.isFull() &&  == null;
     }
 
     @Override
     public final void addInput(Page page)
     {
         checkState(!"Operator is already finishing");
         checkNotNull(page"page is null");
         checkState(!.isFull(), "Page buffer is full");
 
          = page;
          = 0;
     }
 
     @Override
     public final Page getOutput()
     {
         if (!.isFull() &&  != null) {
             if ( == .getPositionCount()) {
                  = null;
                  = 0;
             }
         }
 
         if (! && !.isFull() || .isEmpty()) {
             return null;
        }
        Page page = .build();
        .reset();
        return page;
    }
    public static class FilterAndProjectOperatorFactory
            implements OperatorFactory
    {
        private final int operatorId;
        private final PageProcessor processor;
        private final List<Typetypes;
        private boolean closed;
        public FilterAndProjectOperatorFactory(int operatorIdPageProcessor processorList<Typetypes)
        {
            this. = operatorId;
            this. = processor;
            this. = types;
        }
        @Override
        public List<TypegetTypes()
        {
            return ;
        }
        @Override
        public Operator createOperator(DriverContext driverContext)
        {
            checkState(!"Factory is already closed");
            OperatorContext operatorContext = driverContext.addOperatorContext(FilterAndProjectOperator.class.getSimpleName());
            return new FilterAndProjectOperator(operatorContext);
        }
        @Override
        public void close()
        {
             = true;
        }
    }
New to GrepCode? Check out our FAQ X