| Index: src/code-stub-assembler.h
|
| diff --git a/src/code-stub-assembler.h b/src/code-stub-assembler.h
|
| index 76bd5dee425d1884140b46c0997fff4abdceadec..0213b6937fb0c9061afc0a30c72d5b0689f0f671 100644
|
| --- a/src/code-stub-assembler.h
|
| +++ b/src/code-stub-assembler.h
|
| @@ -111,7 +111,9 @@ class CodeStubAssembler : public compiler::CodeAssembler {
|
| compiler::Node* SmiSub(compiler::Node* a, compiler::Node* b);
|
| compiler::Node* SmiSubWithOverflow(compiler::Node* a, compiler::Node* b);
|
| compiler::Node* SmiEqual(compiler::Node* a, compiler::Node* b);
|
| + compiler::Node* SmiAbove(compiler::Node* a, compiler::Node* b);
|
| compiler::Node* SmiAboveOrEqual(compiler::Node* a, compiler::Node* b);
|
| + compiler::Node* SmiBelow(compiler::Node* a, compiler::Node* b);
|
| compiler::Node* SmiLessThan(compiler::Node* a, compiler::Node* b);
|
| compiler::Node* SmiLessThanOrEqual(compiler::Node* a, compiler::Node* b);
|
| compiler::Node* SmiMin(compiler::Node* a, compiler::Node* b);
|
| @@ -131,8 +133,10 @@ class CodeStubAssembler : public compiler::CodeAssembler {
|
|
|
| // Check a value for smi-ness
|
| compiler::Node* WordIsSmi(compiler::Node* a);
|
| - // Check that the value is a positive smi.
|
| + // Check that the value is a non-negative smi.
|
| compiler::Node* WordIsPositiveSmi(compiler::Node* a);
|
| + // Check that the value is a negative smi.
|
| + compiler::Node* WordIsNotPositiveSmi(compiler::Node* a);
|
|
|
| void BranchIfSmiEqual(compiler::Node* a, compiler::Node* b, Label* if_true,
|
| Label* if_false) {
|
| @@ -322,6 +326,16 @@ class CodeStubAssembler : public compiler::CodeAssembler {
|
| compiler::Node* AllocateSeqTwoByteString(int length);
|
| compiler::Node* AllocateSeqTwoByteString(compiler::Node* context,
|
| compiler::Node* length);
|
| +
|
| + // Allocate a SlicedOneByteString with the given length, parent and offset.
|
| + compiler::Node* AllocateSlicedOneByteString(compiler::Node* length,
|
| + compiler::Node* parent,
|
| + compiler::Node* offset);
|
| + // Allocate a SlicedTwoByteString with the given length, parent and offset.
|
| + compiler::Node* AllocateSlicedTwoByteString(compiler::Node* length,
|
| + compiler::Node* parent,
|
| + compiler::Node* offset);
|
| +
|
| // Allocate a JSArray without elements and initialize the header fields.
|
| compiler::Node* AllocateUninitializedJSArrayWithoutElements(
|
| ElementsKind kind, compiler::Node* array_map, compiler::Node* length,
|
| @@ -372,6 +386,16 @@ class CodeStubAssembler : public compiler::CodeAssembler {
|
| WriteBarrierMode barrier_mode = UPDATE_WRITE_BARRIER,
|
| ParameterMode mode = INTEGER_PARAMETERS);
|
|
|
| + // Copies |character_count| elements from |from_string| to |to_string|
|
| + // starting at the |from_index|'th character. |from_index| and
|
| + // |character_count| must be Smis s.t.
|
| + // 0 <= |from_index| <= |from_index| + |character_count| < from_string.length.
|
| + void CopyStringCharacters(compiler::Node* from_string,
|
| + compiler::Node* to_string,
|
| + compiler::Node* from_index,
|
| + compiler::Node* character_count,
|
| + String::Encoding encoding);
|
| +
|
| // Loads an element from |array| of |from_kind| elements by given |offset|
|
| // (NOTE: not index!), does a hole check if |if_hole| is provided and
|
| // converts the value so that it becomes ready for storing to array of
|
| @@ -443,6 +467,11 @@ class CodeStubAssembler : public compiler::CodeAssembler {
|
| compiler::Node* smi_index);
|
| // Return the single character string with only {code}.
|
| compiler::Node* StringFromCharCode(compiler::Node* code);
|
| + // Return a new string object which holds a substring containing the range
|
| + // [from,to[ of string.
|
| + compiler::Node* StringSubString(compiler::Node* context,
|
| + compiler::Node* string, compiler::Node* from,
|
| + compiler::Node* to);
|
|
|
| // Type conversion helpers.
|
| // Convert a String to a Number.
|
|
|