View source code
							
							
						
								Display the source code in dmd/expression.d from which this
								page was generated on github.
							
						
							Report a bug
							
						
								If you spot a problem with this page, click here to create a
								Bugzilla issue.
							
						
							
								Improve this page
							
							
					
								Quickly fork, edit online, and submit a pull request for this page.
								Requires a signed-in GitHub account. This works well for small changes.
								If you'd like to make larger changes you may want to consider using
								local clone.
							
						Class dmd.expression.StringExp
				
						
					
				Methods
| Name | Description | 
|---|---|
| borrowData() | Borrow a slice of the data, so the caller can modify it in-place (!) | 
| compare(se2) | Compare two StringExpby length, then value | 
| getCodeUnit(i) | Get the code unit at index i | 
| numberOfCodeUnits(tynto) | Return the number of code units the string would be if it were re-encoded as tynto. | 
| peekData() | Get a slice of the data. | 
| setCodeUnit(i, c) | Set the code unit at index i to c | 
| setData(s, len, sz) | Set new string data. thisbecomes the new owner of the data. | 
| toStringz() | Convert string contents to a 0 terminated string, allocated by mem.xmalloc(). | 
| toUTF8(sc) | Convert string to char[]. | 
| writeTo(dest, zero, tyto) | Write the contents of the string to dest. Use numberOfCodeUnits() to determine size of result. | 
| accept(v) | Visits this AST node using the given visitor. | 
| addDtorHook(sc) | Destructors are attached to VarDeclarations. Hence, if expression returns a temp that needs a destructor, make sure and create a VarDeclaration for that temp. | 
| addressOf() | Take address of expression. | 
| checkNogc(sc, f) | Calling function f. Check the @nogc-ness, i.e. if we're in a @nogc function we can only call other @nogc functions. Returns true if error occurs. | 
| checkOverridenDtor(sc, f, check, checkName) | Checks whether fis a generatedDtorDeclarationthat hides a user-defined one
 which passescheckwhilefdoesn't (e.g. when the user defined dtor is pure but
 the generated dtor is not).
 In that case the method will identify and print all members causing the attribute
 missmatch. | 
| checkPostblit(sc, t) | Check that the postblit is callable if t is an array of structs. Returns true if error happens. | 
| checkPurity(sc, f) | Calling function f. Check the purity, i.e. if we're in a pure function we can only call other pure functions. Returns true if error occurs. | 
| checkPurity(sc, v) | Accessing variable v. Check for purity and safety violations. Returns true if error occurs. | 
| checkReadModifyWrite(rmwOp, ex) | Check whether the expression allows RMW operations, error with rmw operator diagnostic if not. ex is the RHS expression, or NULL if ++/-- is used (for diagnostics) Returns true if error occurs. | 
| checkSafety(sc, f) | Calling function f. Check the safety, i.e. if we're in a @safe function we can only call @safe or @trusted functions. Returns true if error occurs. | 
| checkType() | Check that the expression has a valid type. If not, generates an error "... has no type". | 
| checkValue() | Check that the expression has a valid value. If not, generates an error "... has no value". | 
| combine(e1, e2) | Combine e1 and e2 by CommaExp if both are not NULL. | 
| copy() | Does *not* do a deep copy. | 
| deinitialize() | Deinitializes the global state of the compiler. | 
| deref() | If this is a reference, dereference it. | 
| extractLast(e, e0) | If 'e' is a tree of commas, returns the rightmost expression by stripping off it from the tree. The remained part of the tree is returned via e0. Otherwise 'e' is directly returned and e0 is set to NULL. | 
| factory(classname) | Create instance of class specified by the fully qualified name classname. The class must either have no constructors or have a default constructor. | 
| isLvalue() | Return !=0 if expression is an lvalue. | 
| opCmp(o) | Compare with another Object obj. | 
| opEquals(o) | Test whether thisis equal too.
 The default implementation only compares by identity (using theisoperator).
 Generally, overrides and overloads foropEqualsshould attempt to compare objects by their contents.
 A class will most likely want to add an overload that takes your specific type as the argument
 and does the content comparison. Then you can override this and forward it to your specific
 typed overload with a cast. Remember to check fornullon the typed overload. | 
| resolveLoc(loc, sc) | Resolve _FILE__, _LINE__, _MODULE__, _FUNCTION__, _PRETTY_FUNCTION__, _FILE_FULL_PATH__ to loc. | 
| toBool() | Statically evaluate this expression to a boolif possible | 
| toHash() | Compute hash function for Object. | 
| toLvalue(sc, e) | Give error if we're not an lvalue. If we can, convert expression to be an lvalue. | 
| toString() | |
| toString() | Convert Object to a human readable string. | 
https
//dlang.org/spec/expression.html#string_literals
Authors
License
					Copyright © 1999-2024 by the D Language Foundation | Page generated by ddox.