-        boolean fileChanged = false;
-        boolean dirChanged = false;
-
-        // code before in FileSyncAdapter.fetchData
-        PropFindMethod query = null;
-        try {
-            Log_OC.d(TAG, "Synchronizing " + mAccount.name + ", fetching files in " + mRemotePath);
-
-            // remote request 
-            query = new PropFindMethod(client.getBaseUri() + WebdavUtils.encodePath(mRemotePath));
-            int status = client.executeMethod(query);
-
-            // check and process response   - /// TODO take into account all the possible status per child-resource
-            if (isMultiStatus(status)) { 
-                MultiStatus resp = query.getResponseBodyAsMultiStatus();
-
-                // synchronize properties of the parent folder, if necessary 
-                WebdavEntry we = new WebdavEntry(resp.getResponses()[0], client.getBaseUri().getPath());
-
-                // Properties of server folder
-                OCFile parent = fillOCFile(we);
-                // Properties of local folder
-                OCFile localParent = mStorageManager.getFileByPath(mRemotePath);
-                if (localParent == null || !(parent.getEtag().equalsIgnoreCase(localParent.getEtag())) || mEnforceMetadataUpdate) {
-                    if (localParent != null) {
-                        parent.setParentId(localParent.getParentId());
-                    }
-                    mStorageManager.saveFile(parent);
-                    if (mParentId == DataStorageManager.ROOT_PARENT_ID)
-                        mParentId = parent.getFileId();
-                    dirChanged = true;
-                }
-
-                if (dirChanged) {
-                    // read contents in folder
-                    List<String> filesOnServer = new ArrayList<String> (); // Contains the lists of files on server
-                    List<OCFile> updatedFiles = new Vector<OCFile>(resp.getResponses().length - 1);
-                    List<SynchronizeFileOperation> filesToSyncContents = new Vector<SynchronizeFileOperation>();
-                    for (int i = 1; i < resp.getResponses().length; ++i) {
-                        /// new OCFile instance with the data from the server
-                        we = new WebdavEntry(resp.getResponses()[i], client.getBaseUri().getPath());                        
-                        OCFile file = fillOCFile(we);
-
-                        filesOnServer.add(file.getRemotePath()); // Registry the file in the list
-
-                        /// set data about local state, keeping unchanged former data if existing
-                        file.setLastSyncDateForProperties(mCurrentSyncTime);
-                        OCFile oldFile = mStorageManager.getFileByPath(file.getRemotePath());
-
-                        // Check if it is needed to synchronize the folder
-                        fileChanged = false;
-                        if (oldFile != null) {
-                            if (!file.getEtag().equalsIgnoreCase(oldFile.getEtag())) {
-                                fileChanged = true;                             
-                            }                        
-                        } else 
-                            fileChanged= true;
-
-
-                        if (fileChanged){                    
-                            if (oldFile != null) { 
-                                file.setKeepInSync(oldFile.keepInSync());
-                                file.setLastSyncDateForData(oldFile.getLastSyncDateForData());
-                                file.setModificationTimestampAtLastSyncForData(oldFile.getModificationTimestampAtLastSyncForData());    // must be kept unchanged when the file contents are not updated
-                                checkAndFixForeignStoragePath(oldFile);
-                                file.setStoragePath(oldFile.getStoragePath());
-                                if (file.isDirectory())
-                                    file.setEtag(oldFile.getEtag());
-                            } else
-                                if (file.isDirectory())
-                                    file.setEtag("");
-
-                            /// scan default location if local copy of file is not linked in OCFile instance
-                            if (file.getStoragePath() == null && !file.isDirectory()) {
-                                File f = new File(FileStorageUtils.getDefaultSavePathFor(mAccount.name, file));
-                                if (f.exists()) {
-                                    file.setStoragePath(f.getAbsolutePath());
-                                    file.setLastSyncDateForData(f.lastModified());
-                                }
-                            }
-
-                            /// prepare content synchronization for kept-in-sync files
-                            if (file.keepInSync()) {
-                                SynchronizeFileOperation operation = new SynchronizeFileOperation(  oldFile,        
-                                        file, 
-                                        mStorageManager,
-                                        mAccount,       
-                                        true, 
-                                        false,          
-                                        mContext
-                                        );
-                                filesToSyncContents.add(operation);
-                            }
-
-                            updatedFiles.add(file);
-                        }
-                    }
-
-                    // save updated contents in local database; all at once, trying to get a best performance in database update (not a big deal, indeed)
-                    mStorageManager.saveFiles(updatedFiles);
-
-                    // request for the synchronization of files AFTER saving last properties
-                    RemoteOperationResult contentsResult = null;
-                    for (SynchronizeFileOperation op: filesToSyncContents) {
-                        contentsResult = op.execute(client);   // returns without waiting for upload or download finishes
-                        if (!contentsResult.isSuccess()) {
-                            if (contentsResult.getCode() == ResultCode.SYNC_CONFLICT) {
-                                mConflictsFound++;
-                            } else {
-                                mFailsInFavouritesFound++;
-                                if (contentsResult.getException() != null) {
-                                    Log_OC.e(TAG, "Error while synchronizing favourites : " +  contentsResult.getLogMessage(), contentsResult.getException());
-                                } else {
-                                    Log_OC.e(TAG, "Error while synchronizing favourites : " + contentsResult.getLogMessage());
-                                }
-                            }
-                        }   // won't let these fails break the synchronization process
-                    }
+        
+        result = checkForChanges(client);
+        
+        if (result.isSuccess()) {
+            if (mRemoteFolderChanged) {
+                result = fetchAndSyncRemoteFolder(client);
+            } else {
+                mChildren = mStorageManager.getFolderContent(mLocalFolder);
+            }
+        }
+        
+        if (!mSyncFullAccount) {            
+            sendLocalBroadcast(EVENT_SINGLE_FOLDER_CONTENTS_SYNCED, mLocalFolder.getRemotePath(), result);
+        }
+        
+        if (result.isSuccess() && mRefreshShares) {
+            RemoteOperationResult shareResult = refreshSharesForFolder(client);
+            if (shareResult.getCode() != ResultCode.FILE_NOT_FOUND) {
+                result = shareResult;
+            } // else , keep the previous result ; being conservative for servers where Sharing API is supported, but disabled
+        }
+        
+        if (!mSyncFullAccount) {            
+            sendLocalBroadcast(EVENT_SINGLE_FOLDER_SHARES_SYNCED, mLocalFolder.getRemotePath(), result);
+        }
+        
+        return result;
+        
+    }