diff --git a/core/ustring.cpp b/core/ustring.cpp index 4dbe41890d9..3c22de35f1f 100644 --- a/core/ustring.cpp +++ b/core/ustring.cpp @@ -2416,6 +2416,23 @@ Vector String::md5_buffer() const { return ret; }; +Vector String::sha256_buffer() const { + CharString cs = utf8(); + unsigned char hash[32]; + sha256_context ctx; + sha256_init(&ctx); + sha256_hash(&ctx, (unsigned char*)cs.ptr(), cs.length()); + sha256_done(&ctx, hash); + + Vector ret; + ret.resize(32); + for (int i = 0; i < 32; i++) { + ret[i] = hash[i]; + } + + return ret; +} + String String::insert(int p_at_pos,String p_string) const { diff --git a/core/ustring.h b/core/ustring.h index 692cb4e37d4..bb57b11d882 100644 --- a/core/ustring.h +++ b/core/ustring.h @@ -196,6 +196,7 @@ public: String md5_text() const; String sha256_text() const; Vector md5_buffer() const; + Vector sha256_buffer() const; inline bool empty() const { return length() == 0; } diff --git a/core/variant_call.cpp b/core/variant_call.cpp index 34e5164b242..c0f8930eedf 100644 --- a/core/variant_call.cpp +++ b/core/variant_call.cpp @@ -271,6 +271,7 @@ static void _call_##m_type##_##m_method(Variant& r_ret,Variant& p_self,const Var VCALL_LOCALMEM0R(String,md5_text); VCALL_LOCALMEM0R(String,sha256_text); VCALL_LOCALMEM0R(String,md5_buffer); + VCALL_LOCALMEM0R(String,sha256_buffer); VCALL_LOCALMEM0R(String,empty); VCALL_LOCALMEM0R(String,is_abs_path); VCALL_LOCALMEM0R(String,is_rel_path); @@ -1322,6 +1323,7 @@ _VariantCall::addfunc(Variant::m_vtype,Variant::m_ret,_SCS(#m_method),VCALL(m_cl ADDFUNC0(STRING,STRING,String,md5_text,varray()); ADDFUNC0(STRING,STRING,String,sha256_text,varray()); ADDFUNC0(STRING,RAW_ARRAY,String,md5_buffer,varray()); + ADDFUNC0(STRING,RAW_ARRAY,String,sha256_buffer,varray()); ADDFUNC0(STRING,BOOL,String,empty,varray()); ADDFUNC0(STRING,BOOL,String,is_abs_path,varray()); ADDFUNC0(STRING,BOOL,String,is_rel_path,varray()); diff --git a/doc/base/classes.xml b/doc/base/classes.xml index 7224ae85540..09554e6a987 100644 --- a/doc/base/classes.xml +++ b/doc/base/classes.xml @@ -7059,8 +7059,11 @@ Draw a textured rectangle region at a given position, optionally modulated by a color. Transpose swaps the x and y coordinates when reading the texture. - + + + + Used for editing, returns an opaque value representing the transform state. @@ -7080,7 +7083,7 @@ - Used for editing, returns an opaque value representing the transform state. + Set the transform state of this CanvasItem. For [Node2D], this is an [Array] with (in order) a [Vector2] for position, a float for rotation and another [Vector2] for scale. For [Control] this is a [Rect2] with the position and size. @@ -7094,6 +7097,7 @@ + Return the [RID] of the [World2D] canvas where this item is in. @@ -7107,55 +7111,63 @@ + Get the transform matrix of this item's canvas. + Get the global position of the mouse. + Get the global transform matrix of this item. + Get the global transform matrix of this item in relation to the canvas. + Get a [Rect2] with the boundaries of this item and its children. - Return a rect containing the editable contents of the item. + Return a rect containing the editable boundaries of the item. + Get this item's light mask number. + Get the mouse position relative to this item's position. + Get the material of this item. @@ -7176,30 +7188,35 @@ + Get the transform matrix of this item. + Get whether this item uses its parent's material. + Get the viewport's boundaries as a [Rect2]. + Get this item's transform in relation to the viewport. + Get the [World2D] where this item is in. @@ -7241,13 +7258,14 @@ + Takes a global input event and convert to this item's coordinate system. - Set as toplevel. This means that it will not inherit transform from parent canvas items. + Set as top level. This means that it will not inherit transform from parent canvas items. @@ -7261,25 +7279,28 @@ - Sets whether the canvas item is drawn behind its parent. + Set whether the canvas item is drawn behind its parent. + Set whether this item should be hidden or not. Note that no matter what is set here this item won't be shown if its parent or grandparents nodes are also hidden. A hidden CanvasItem make all children hidden too. + Set the ligtht mask number of this item. + Set the material of this item. @@ -7300,6 +7321,7 @@ + Set whether or not this item should use its parent's material. @@ -7309,7 +7331,7 @@ - Queue the CanvasItem for update. NOTIFICATION_DRAW will be called on idle time to request redraw. + Queue the CanvasItem for update. [code]NOTIFICATION_DRAW[/code] will be called on idle time to request redraw. @@ -37568,12 +37590,14 @@ A similar effect may be achieved moving this node's descendants. + Return a copy of the string with special characters escaped using the C language standard. + Return a copy of the string with escaped characters replaced by their meanings according to the C language standard. @@ -37605,6 +37629,7 @@ A similar effect may be achieved moving this node's descendants. + Return true if the strings ends with the given string. @@ -37613,6 +37638,7 @@ A similar effect may be achieved moving this node's descendants. + Erase [code]chars[/code] characters from the string starting from [code]pos[/code]. @@ -37712,7 +37738,7 @@ A similar effect may be achieved moving this node's descendants. - Checked whether this string is a subsequence of the given string. + Check whether this string is a subsequence of the given string. @@ -37721,7 +37747,7 @@ A similar effect may be achieved moving this node's descendants. - Checked whether this string is a subsequence of the given string, without considering case. + Check whether this string is a subsequence of the given string, without considering case. @@ -37742,6 +37768,7 @@ A similar effect may be achieved moving this node's descendants. + Check whether the string is a valid identifier. As is common in programming languages, a valid identifier may contain only letters, digits and underscores (_) and the first character may not be a digit. @@ -37762,6 +37789,7 @@ A similar effect may be achieved moving this node's descendants. + Return a copy of the string with special characters escaped using the JSON standard. @@ -37802,12 +37830,14 @@ A similar effect may be achieved moving this node's descendants. + Return the MD5 hash of the string as an array of bytes. + Return the MD5 hash of the string as a string. @@ -37825,7 +37855,7 @@ A similar effect may be achieved moving this node's descendants. - Return the character code at position "at". + Return the character code at position [code]at[/code]. @@ -37834,6 +37864,7 @@ A similar effect may be achieved moving this node's descendants. + Format a number to have an exact number of [code]digits[/code] after the decimal point. @@ -37842,18 +37873,21 @@ A similar effect may be achieved moving this node's descendants. + Format a number to have an exact number of [code]digits[/code] before the decimal point. + Decode a percent-encoded string. See [method percent_encode]. + Percent-encode a string. This is meant to encode parameters in a URL when sending a HTTP GET request and bodies of form-urlencoded POST request. @@ -37862,6 +37896,7 @@ A similar effect may be achieved moving this node's descendants. + If the string is a path, this concatenates [code]file[/code] at the end of the string as a subpath. E.g. [code]"this/is".plus_file("path") == "this/is/path"[/code]. @@ -37917,10 +37952,17 @@ A similar effect may be achieved moving this node's descendants. Return the right side of the string from a given position. + + + + + + + Return the SHA-256 hash of the string as a string. @@ -37940,7 +37982,7 @@ A similar effect may be achieved moving this node's descendants. - Split the string by a divisor string, return an array of the substrings. Example "One,Two,Three" will return \["One","Two","Three"\] if split by ",". + Split the string by a divisor string, return an array of the substrings. Example "One,Two,Three" will return ["One","Two","Three"] if split by ",". @@ -37951,7 +37993,7 @@ A similar effect may be achieved moving this node's descendants. - Split the string in floats by using a divisor string, return an array of the substrings. Example "1,2.5,3" will return \[1,2.5,3\] if split by ",". + Split the string in floats by using a divisor string, return an array of the substrings. Example "1,2.5,3" will return [1,2.5,3] if split by ",". @@ -37973,7 +38015,7 @@ A similar effect may be achieved moving this node's descendants. - Return part of the string from "from", with length "len". + Return part of the string from the position [code]from[/code], with length [code]len[/code]. @@ -37987,14 +38029,14 @@ A similar effect may be achieved moving this node's descendants. - Convert a string, containing a decimal number, into a float. + Convert a string, containing a decimal number, into a [code]float[/code]. - Convert a string, containing an integer number, into an int. + Convert a string, containing an integer number, into an [code]int[/code]. @@ -38022,14 +38064,14 @@ A similar effect may be achieved moving this node's descendants. - Perform XML escaping on the string. + Return a copy of the string with special characters escaped using the XML standard. - Perform XML un-escaping of the string. + Return a copy of the string with escaped characters replaced by their meanings according to the XML standard. @@ -39290,8 +39332,6 @@ A similar effect may be achieved moving this node's descendants. - - @@ -39300,8 +39340,6 @@ A similar effect may be achieved moving this node's descendants. - - diff --git a/scene/2d/canvas_item.cpp b/scene/2d/canvas_item.cpp index eb37634b24c..976a5c4f1ed 100644 --- a/scene/2d/canvas_item.cpp +++ b/scene/2d/canvas_item.cpp @@ -1023,7 +1023,7 @@ void CanvasItem::_bind_methods() { ObjectTypeDB::bind_method(_MD("_is_visible_"),&CanvasItem::_is_visible_); ObjectTypeDB::bind_method(_MD("edit_set_state","state"),&CanvasItem::edit_set_state); - ObjectTypeDB::bind_method(_MD("edit_get"),&CanvasItem::edit_get_state); + ObjectTypeDB::bind_method(_MD("edit_get_state:Variant"),&CanvasItem::edit_get_state); ObjectTypeDB::bind_method(_MD("edit_set_rect","rect"),&CanvasItem::edit_set_rect); ObjectTypeDB::bind_method(_MD("edit_rotate","degrees"),&CanvasItem::edit_rotate);