Page MenuHomePhabricator

Use setters instead of public properties
ClosedPublic

Authored by joshuaspence on Nov 17 2015, 9:04 PM.
Tags
None
Referenced Files
F14748364: D14504.diff
Tue, Jan 21, 10:35 AM
Unknown Object (File)
Mon, Jan 20, 7:27 AM
Unknown Object (File)
Fri, Jan 17, 7:53 PM
Unknown Object (File)
Mon, Jan 6, 9:14 PM
Unknown Object (File)
Dec 13 2024, 6:22 PM
Unknown Object (File)
Dec 11 2024, 5:00 AM
Unknown Object (File)
Dec 7 2024, 7:09 PM
Unknown Object (File)
Dec 7 2024, 3:02 PM
Subscribers

Details

Summary

Currently a bunch of properties in the AASTNode class are public instead of using explicit setter methods. This doesn't seem to have any effect on performance as far as I can tell

Test Plan

Ran the following script with 100 iterators:

1<?php
2
3require_once __DIR__.'/scripts/__init_script__.php';
4
5$console = PhutilConsole::getConsole();
6$iterations = 10;
7$source = Filesystem::readFile(__DIR__.'/../phabricator/src/__phutil_library_map__.php');
8$start = microtime(true);
9
10for ($ii = 0; $ii < $iterations; $ii++) {
11 XHPASTTree::newFromData($source);
12}
13
14$end = microtime(true);
15$duration = $end - $start;
16
17$console->writeOut("Average: %fs\n", $duration / $iterations);
18$console->writeOut("Total: %fs\n", $duration);

Before
Average: 2.679129s
Total:   267.912916s
After
Average: 2.648229s
Total:   264.822857s

Diff Detail

Repository
rPHU libphutil
Branch
master
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 8899
Build 10420: Run Core Tests
Build 10419: arc lint + arc unit

Event Timeline

joshuaspence retitled this revision from to Use setters instead of public properties.
joshuaspence updated this object.
joshuaspence edited the test plan for this revision. (Show Details)
joshuaspence added a reviewer: epriestley.
epriestley edited edge metadata.

Maybe double check with PhabricatorApplicationTransactionEditor.php? __phutil_library_map__.php has a lot of lines, but the tree isn't actaully that complex.

This revision is now accepted and ready to land.Nov 17 2015, 9:06 PM
src/parser/aast/api/AASTNode.php
92

Hmm, this seems wrong/odd... adding an assert_instances_of call here doesn't seem to impact the execution time;

Average: 2.559327s
Total:   255.932677

With PhabricatorApplicationTransactionEditor:

Before
Average: 0.545871s
Total:   54.587076s
After
Average: 0.542363s
Total:   54.236334s
This revision was automatically updated to reflect the committed changes.